diff options
-rw-r--r-- | src/widgets/qlistview.cpp | 26 |
1 files changed, 21 insertions, 5 deletions
diff --git a/src/widgets/qlistview.cpp b/src/widgets/qlistview.cpp index c83ee40..a292cd3 100644 --- a/src/widgets/qlistview.cpp +++ b/src/widgets/qlistview.cpp @@ -5366,9 +5366,17 @@ void QListView::selectAll( bool select ) QListViewItemIterator it( this ); while ( it.current() ) { QListViewItem *i = it.current(); - if ( (bool)i->selected != select ) { - i->setSelected( select ); - anything = TRUE; + if ( i->isVisible()) { + if ( (bool)i->selected != select ) { + i->setSelected( select ); + anything = TRUE; + } + } + else { + if ( (bool)i->selected != FALSE ) { + i->setSelected( FALSE ); + anything = TRUE; + } } ++it; } @@ -5398,8 +5406,16 @@ void QListView::invertSelection() bool b = signalsBlocked(); blockSignals( TRUE ); QListViewItemIterator it( this ); - for ( ; it.current(); ++it ) - it.current()->setSelected( !it.current()->isSelected() ); + for ( ; it.current(); ++it ) { + if (it.current()->isVisible()) { + it.current()->setSelected( !it.current()->isSelected() ); + } + else { + if ( FALSE != it.current()->isSelected() ) { + it.current()->setSelected( FALSE ); + } + } + } blockSignals( b ); emit selectionChanged(); triggerUpdate(); |