From 99a620d2e2d5225f2b5e29d52617a8a5328081fd Mon Sep 17 00:00:00 2001 From: Stephen Kelly Date: Tue, 17 Apr 2012 19:45:20 +0200 Subject: Take account of spanned items in QTreeView when dragging. Also remove some code which has been unused since it was introduced in 32182d107fa75e5619ecc91a81f50626f429ebe1 Task-number: QTBUG-25140 Change-Id: Ic7053d68d8200f845c1ae330342d27af7275e057 Reviewed-by: Tarja Sundqvist Reviewed-by: David Faure --- src/widgets/itemviews/qtreeview.cpp | 41 ++++++++----------------------------- 1 file changed, 9 insertions(+), 32 deletions(-) (limited to 'src/widgets') diff --git a/src/widgets/itemviews/qtreeview.cpp b/src/widgets/itemviews/qtreeview.cpp index aaec2b1346..04835b63b4 100644 --- a/src/widgets/itemviews/qtreeview.cpp +++ b/src/widgets/itemviews/qtreeview.cpp @@ -1343,39 +1343,16 @@ void QTreeViewPrivate::_q_modelDestroyed() QItemViewPaintPairs QTreeViewPrivate::draggablePaintPairs(const QModelIndexList &indexes, QRect *r) const { Q_ASSERT(r); - return QAbstractItemViewPrivate::draggablePaintPairs(indexes, r); Q_Q(const QTreeView); - QRect &rect = *r; - const QRect viewportRect = viewport->rect(); - int itemOffset = 0; - int row = firstVisibleItem(&itemOffset); - QPair startEnd = startAndEndColumns(viewportRect); - QVector columns; - for (int i = startEnd.first; i <= startEnd.second; ++i) { - int logical = header->logicalIndex(i); - if (!header->isSectionHidden(logical)) - columns += logical; - } - QSet visibleIndexes; - for (; itemOffset < viewportRect.bottom() && row < viewItems.count(); ++row) { - const QModelIndex &index = viewItems.at(row).index; - for (int colIndex = 0; colIndex < columns.count(); ++colIndex) - visibleIndexes += index.sibling(index.row(), columns.at(colIndex)); - itemOffset += itemHeight(row); - } - - //now that we have the visible indexes, we can try to find those which are selected - QItemViewPaintPairs ret; - for (int i = 0; i < indexes.count(); ++i) { - const QModelIndex &index = indexes.at(i); - if (visibleIndexes.contains(index)) { - const QRect current = q->visualRect(index); - ret += qMakePair(current, index); - rect |= current; - } - } - rect &= viewportRect; - return ret; + if (spanningIndexes.isEmpty()) + return QAbstractItemViewPrivate::draggablePaintPairs(indexes, r); + QModelIndexList list; + foreach (const QModelIndex &idx, indexes) { + if (idx.column() > 0 && q->isFirstColumnSpanned(idx.row(), idx.parent())) + continue; + list << idx; + } + return QAbstractItemViewPrivate::draggablePaintPairs(list, r); } void QTreeViewPrivate::adjustViewOptionsForIndex(QStyleOptionViewItemV4 *option, const QModelIndex ¤t) const -- cgit v1.2.3