diff options
author | Martin Jones <martin.jones@nokia.com> | 2012-07-26 13:14:50 +1000 |
---|---|---|
committer | Qt by Nokia <qt-info@nokia.com> | 2012-07-27 03:08:24 +0200 |
commit | 3a045419ba588107d7730978c14643d68340f24b (patch) | |
tree | 2d9d84b06b4ae762dfc46a5bfbea5ee31f560e8d /src/quick/items/qquickitemview.cpp | |
parent | 4dcd5ae1e27252755a51dec139269bc4f998adb4 (diff) |
Add SnapPosition mode to positionViewAtIndex() in List/GridView.
This allows the view to be positioned on a snap boundary, which is
generally what is wanted when strict highlight mode s set or snapping
is enabled.
Task-number: QTBUG-26605
Change-Id: I6288dc8be4ff16c412b56ab449b6a9fb7b7ea889
Reviewed-by: Bea Lam <bea.lam@nokia.com>
Diffstat (limited to 'src/quick/items/qquickitemview.cpp')
-rw-r--r-- | src/quick/items/qquickitemview.cpp | 26 |
1 files changed, 25 insertions, 1 deletions
diff --git a/src/quick/items/qquickitemview.cpp b/src/quick/items/qquickitemview.cpp index 8f1687f4e6..240027e312 100644 --- a/src/quick/items/qquickitemview.cpp +++ b/src/quick/items/qquickitemview.cpp @@ -613,6 +613,10 @@ void QQuickItemView::setHighlightRangeMode(HighlightRangeMode mode) return; d->highlightRange = mode; d->haveHighlightRange = d->highlightRange != NoHighlightRange && d->highlightRangeStart <= d->highlightRangeEnd; + if (isComponentComplete()) { + d->updateViewport(); + d->fixupPosition(); + } emit highlightRangeModeChanged(); } @@ -631,6 +635,10 @@ void QQuickItemView::setPreferredHighlightBegin(qreal start) return; d->highlightRangeStart = start; d->haveHighlightRange = d->highlightRange != NoHighlightRange && d->highlightRangeStart <= d->highlightRangeEnd; + if (isComponentComplete()) { + d->updateViewport(); + d->fixupPosition(); + } emit preferredHighlightBeginChanged(); } @@ -641,6 +649,10 @@ void QQuickItemView::resetPreferredHighlightBegin() if (d->highlightRangeStart == 0) return; d->highlightRangeStart = 0; + if (isComponentComplete()) { + d->updateViewport(); + d->fixupPosition(); + } emit preferredHighlightBeginChanged(); } @@ -658,6 +670,10 @@ void QQuickItemView::setPreferredHighlightEnd(qreal end) return; d->highlightRangeEnd = end; d->haveHighlightRange = d->highlightRange != NoHighlightRange && d->highlightRangeStart <= d->highlightRangeEnd; + if (isComponentComplete()) { + d->updateViewport(); + d->fixupPosition(); + } emit preferredHighlightEndChanged(); } @@ -668,6 +684,10 @@ void QQuickItemView::resetPreferredHighlightEnd() if (d->highlightRangeEnd == 0) return; d->highlightRangeEnd = 0; + if (isComponentComplete()) { + d->updateViewport(); + d->fixupPosition(); + } emit preferredHighlightEndChanged(); } @@ -819,7 +839,7 @@ void QQuickItemViewPrivate::positionViewAtIndex(int index, int mode) Q_Q(QQuickItemView); if (!isValid()) return; - if (mode < QQuickItemView::Beginning || mode > QQuickItemView::Contain) + if (mode < QQuickItemView::Beginning || mode > QQuickItemView::SnapPosition) return; applyPendingChanges(); @@ -871,6 +891,10 @@ void QQuickItemViewPrivate::positionViewAtIndex(int index, int mode) pos = itemPos - size() + item->size(); if (itemPos < pos) pos = itemPos; + break; + case QQuickItemView::SnapPosition: + pos = itemPos - highlightRangeStart; + break; } pos = qMin(pos, maxExtent); qreal minExtent; |