diff options
author | Michele Calgaro <[email protected]> | 2015-01-09 13:44:48 +0900 |
---|---|---|
committer | Michele Calgaro <[email protected]> | 2015-01-09 13:45:41 +0900 |
commit | 6d346d4d84e88aa98ee5f06e94b64199c992213e (patch) | |
tree | 64faeefedd96e66312a253c2afd698adb601c12d /src/iconview/qiconview.cpp | |
parent | fbf8ee2262d6b55fdd6844504fb69af25b6d9eac (diff) | |
download | tqt3-6d346d4d84e88aa98ee5f06e94b64199c992213e.tar.gz tqt3-6d346d4d84e88aa98ee5f06e94b64199c992213e.zip |
Fixed Multicolumn view filtering item arrangement. This relates to bug 146.
Signed-off-by: Michele Calgaro <[email protected]>
(cherry picked from commit 38e12d6e1287df570c8908b6722597b2e951a738)
Signed-off-by: Michele Calgaro <[email protected]>
Diffstat (limited to 'src/iconview/qiconview.cpp')
-rw-r--r-- | src/iconview/qiconview.cpp | 21 |
1 files changed, 12 insertions, 9 deletions
diff --git a/src/iconview/qiconview.cpp b/src/iconview/qiconview.cpp index a15a098f4..f6b2ae132 100644 --- a/src/iconview/qiconview.cpp +++ b/src/iconview/qiconview.cpp @@ -2347,14 +2347,15 @@ void TQIconViewItem::checkRect() When an item is inserted the TQIconView allocates a position for it. Existing items are rearranged if autoArrange() is TRUE. The - default arrangement is \c LeftToRight -- the TQIconView fills up - the \e left-most column from top to bottom, then moves one column - \e right and fills that from top to bottom and so on. The + default arrangement is \c LeftToRight -- the TQIconView fills + the \e top-most row from left to right, then moves one row \e down + and fills that row from left to right and so on. The arrangement can be modified with any of the following approaches: \list - \i Call setArrangement(), e.g. with \c TopToBottom which will fill - the \e top-most row from left to right, then moves one row \e down - and fills that row from left to right and so on. + \i Call setArrangement(), e.g. with \c TopToBottom which will fill up + the \e left-most column from top to bottom, then moves one column + \e right and fills that from top to bottom and so on. + \i Construct each TQIconViewItem using a constructor which allows you to specify which item the new one is to follow. \i Call setSorting() or sort() to sort the items. @@ -6040,7 +6041,7 @@ TQIconViewItem *TQIconView::makeRowLayout( TQIconViewItem *begin, int &y, bool & } - } else { // -------------------------------- SOUTH ------------------------------ + } else { // -------------------------------- TopToBottom ------------------------------ int x = y; @@ -6075,6 +6076,7 @@ TQIconViewItem *TQIconView::makeRowLayout( TQIconViewItem *begin, int &y, bool & // now move the items item = begin; + TQIconViewItem *prevVisibleItem = NULL; for (;;) { item->dirty = FALSE; if ( d->itemTextPos == Bottom ) { @@ -6082,15 +6084,16 @@ TQIconViewItem *TQIconView::makeRowLayout( TQIconViewItem *begin, int &y, bool & changed = item->move( x + ( w - item->width() ) / 2, d->spacing ) || changed; else changed = item->move( x + ( w - item->width() ) / 2, - item->prev->y() + item->prev->height() + d->spacing ) || changed; + prevVisibleItem->y() + prevVisibleItem->height() + d->spacing ) || changed; } else { if ( item == begin ) changed = item->move( x, d->spacing ) || changed; else - changed = item->move( x, item->prev->y() + item->prev->height() + d->spacing ) || changed; + changed = item->move( x, prevVisibleItem->y() + prevVisibleItem->height() + d->spacing ) || changed; } if ( item == end ) break; + prevVisibleItem = item; item = item->next; while (item && (item->isVisible() == FALSE)) { item = item->next; |