summaryrefslogtreecommitdiffstats
path: root/src/widgets
diff options
context:
space:
mode:
authorStephen Kelly <stephen.kelly@kdab.com>2012-08-06 11:34:56 +0200
committerQt by Nokia <qt-info@nokia.com>2012-08-20 11:24:55 +0200
commit799ceebad8a2dbe1ca0e60a11c7d6ca0c2c8b7a9 (patch)
treeafe48112b9903cabf3a8f0f8d10fbd4622fd2bcc /src/widgets
parent79f660d3748ba98601b1da5d80094e83e615c4d4 (diff)
Take account of hidden items in QListView when using scrollTo.
Task-number: QTBUG-21804 Change-Id: I475166f3f60b1278089baa255ace4e18baeb568e Reviewed-by: Jani Honkonen <jani.honkonen@digia.com> Reviewed-by: Stephen Kelly <stephen.kelly@kdab.com>
Diffstat (limited to 'src/widgets')
-rw-r--r--src/widgets/itemviews/qlistview.cpp12
1 files changed, 9 insertions, 3 deletions
diff --git a/src/widgets/itemviews/qlistview.cpp b/src/widgets/itemviews/qlistview.cpp
index 80d9e27159..1b41b5f0fa 100644
--- a/src/widgets/itemviews/qlistview.cpp
+++ b/src/widgets/itemviews/qlistview.cpp
@@ -2108,10 +2108,16 @@ int QListModeViewBase::verticalScrollToValue(int index, QListView::ScrollHint hi
{
if (verticalScrollMode() == QAbstractItemView::ScrollPerItem) {
int value;
- if (scrollValueMap.isEmpty())
+ if (scrollValueMap.isEmpty()) {
value = 0;
- else
- value = qBound(0, scrollValueMap.at(verticalScrollBar()->value()), flowPositions.count() - 1);
+ } else {
+ int scrollBarValue = verticalScrollBar()->value();
+ int numHidden = 0;
+ for (int i = 0; i < flowPositions.count() - 1 && i <= scrollBarValue; ++i)
+ if (isHidden(i))
+ ++numHidden;
+ value = qBound(0, scrollValueMap.at(verticalScrollBar()->value()) - numHidden, flowPositions.count() - 1);
+ }
if (above)
hint = QListView::PositionAtTop;
else if (below)