aboutsummaryrefslogtreecommitdiffstats
path: root/src/quick/items/qquickitemview.cpp
diff options
context:
space:
mode:
authorMartin Jones <martin.jones@nokia.com>2012-07-26 13:14:50 +1000
committerQt by Nokia <qt-info@nokia.com>2012-07-27 03:08:24 +0200
commit3a045419ba588107d7730978c14643d68340f24b (patch)
tree2d9d84b06b4ae762dfc46a5bfbea5ee31f560e8d /src/quick/items/qquickitemview.cpp
parent4dcd5ae1e27252755a51dec139269bc4f998adb4 (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.cpp26
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;