diff options
| author | Frank Reininghaus <[email protected]> | 2009-12-13 18:18:08 +0000 |
|---|---|---|
| committer | Frank Reininghaus <[email protected]> | 2009-12-13 18:18:08 +0000 |
| commit | a2365b6ed82a4d85fffaa06e51c1c458c301e79d (patch) | |
| tree | e952a71ed4cf8c567bb135c0c67b1db69be92627 | |
| parent | 5d5d5c8e803159857bc29a7f83077426d5694a17 (diff) | |
Reimplement visualRegionForSelection in DolpinDetailsView.
Fixes the problem that not the entire area affected by changing the
selection gets updated. QTreeView::visualRegionForSelection assumes
implicitly that the visualRects of all items have the same width,
which is not the case here.
Fix will be in KDE 4.4 Beta 2.
BUG: 218114
svn path=/trunk/KDE/kdebase/apps/; revision=1062076
| -rw-r--r-- | src/dolphindetailsview.cpp | 17 | ||||
| -rw-r--r-- | src/dolphindetailsview.h | 2 |
2 files changed, 18 insertions, 1 deletions
diff --git a/src/dolphindetailsview.cpp b/src/dolphindetailsview.cpp index 1bf5f75e0..53d7fb951 100644 --- a/src/dolphindetailsview.cpp +++ b/src/dolphindetailsview.cpp @@ -1,4 +1,4 @@ -/*************************************************************************** + /*************************************************************************** * Copyright (C) 2006 by Peter Penz ([email protected]) * * Copyright (C) 2008 by Simon St. James ([email protected]) * * * @@ -171,6 +171,21 @@ QSet<KUrl> DolphinDetailsView::expandedUrls() const return m_expandedUrls; } +QRegion DolphinDetailsView::visualRegionForSelection(const QItemSelection &selection) const +{ + // We have to make sure that the visualRect of each model index is inside the region. + // QTreeView::visualRegionForSelection does not do it right because it assumes implicitly + // that all visualRects have the same width, which is in general not the case here. + QRegion selectionRegion; + const QModelIndexList indexes = selection.indexes(); + + foreach(const QModelIndex& index, indexes) { + selectionRegion += visualRect(index); + } + + return selectionRegion; +} + bool DolphinDetailsView::event(QEvent* event) { if (event->type() == QEvent::Polish) { diff --git a/src/dolphindetailsview.h b/src/dolphindetailsview.h index 30e126cd4..3bd62d33f 100644 --- a/src/dolphindetailsview.h +++ b/src/dolphindetailsview.h @@ -52,6 +52,8 @@ public: */ QSet<KUrl> expandedUrls() const; + virtual QRegion visualRegionForSelection(const QItemSelection & selection) const; + protected: virtual bool event(QEvent* event); virtual QStyleOptionViewItem viewOptions() const; |
