summaryrefslogtreecommitdiffstats
path: root/src/widgets/qlistview.cpp
diff options
context:
space:
mode:
authorMichele Calgaro <michele.calgaro@yahoo.it>2024-08-12 22:02:11 +0900
committerMichele Calgaro <michele.calgaro@yahoo.it>2024-08-12 22:02:11 +0900
commit42957a3f812a1db64a9ae452baa2d3fbc35f2466 (patch)
tree0928f4e01a3dcc0698b46c7608d8310e471bdb49 /src/widgets/qlistview.cpp
parentfef846914f8db6dc117e206ef913d519bf6bb33e (diff)
downloadtqt3-42957a3f812a1db64a9ae452baa2d3fbc35f2466.tar.gz
tqt3-42957a3f812a1db64a9ae452baa2d3fbc35f2466.zip
Rename more widget nt* related files to equivalent tq*
Signed-off-by: Michele Calgaro <michele.calgaro@yahoo.it>
Diffstat (limited to 'src/widgets/qlistview.cpp')
-rw-r--r--src/widgets/qlistview.cpp8206
1 files changed, 0 insertions, 8206 deletions
diff --git a/src/widgets/qlistview.cpp b/src/widgets/qlistview.cpp
deleted file mode 100644
index 5c00bca11..000000000
--- a/src/widgets/qlistview.cpp
+++ /dev/null
@@ -1,8206 +0,0 @@
-/****************************************************************************
-**
-** Implementation of TQListView widget class
-**
-** Created : 970809
-**
-** Copyright (C) 1992-2008 Trolltech ASA. All rights reserved.
-**
-** This file is part of the widgets module of the TQt GUI Toolkit.
-**
-** This file may be used under the terms of the GNU General
-** Public License versions 2.0 or 3.0 as published by the Free
-** Software Foundation and appearing in the files LICENSE.GPL2
-** and LICENSE.GPL3 included in the packaging of this file.
-** Alternatively you may (at your option) use any later version
-** of the GNU General Public License if such license has been
-** publicly approved by Trolltech ASA (or its successors, if any)
-** and the KDE Free TQt Foundation.
-**
-** Please review the following information to ensure GNU General
-** Public Licensing requirements will be met:
-** http://trolltech.com/products/qt/licenses/licensing/opensource/.
-** If you are unsure which license is appropriate for your use, please
-** review the following information:
-** http://trolltech.com/products/qt/licenses/licensing/licensingoverview
-** or contact the sales department at sales@trolltech.com.
-**
-** This file may be used under the terms of the Q Public License as
-** defined by Trolltech ASA and appearing in the file LICENSE.TQPL
-** included in the packaging of this file. Licensees holding valid TQt
-** Commercial licenses may use this file in accordance with the TQt
-** Commercial License Agreement provided with the Software.
-**
-** This file is provided "AS IS" with NO WARRANTY OF ANY KIND,
-** INCLUDING THE WARRANTIES OF DESIGN, MERCHANTABILITY AND FITNESS FOR
-** A PARTICULAR PURPOSE. Trolltech reserves all rights not granted
-** herein.
-**
-**********************************************************************/
-
-#include "ntqlistview.h"
-#ifndef TQT_NO_LISTVIEW
-#include "tqtimer.h"
-#include "ntqheader.h"
-#include "tqpainter.h"
-#include "ntqcursor.h"
-#include "tqptrstack.h"
-#include "tqptrlist.h"
-#include "tqstrlist.h"
-#include "ntqapplication.h"
-#include "tqbitmap.h"
-#include "tqdatetime.h"
-#include "tqptrdict.h"
-#include "tqptrvector.h"
-#include "tqiconset.h"
-#include "ntqcleanuphandler.h"
-#include "tqpixmapcache.h"
-#include "tqpopupmenu.h"
-#include "ntqtl.h"
-#include "tqdragobject.h"
-#include "tqlineedit.h"
-#include "ntqvbox.h"
-#include "tqtooltip.h"
-#include "tqstyle.h"
-#include "tqstylesheet.h"
-#include "../kernel/qinternal_p.h"
-#if defined(QT_ACCESSIBILITY_SUPPORT)
-#include "ntqaccessible.h"
-#endif
-
-const int Unsorted = 16383;
-
-static TQCleanupHandler<TQBitmap> qlv_cleanup_bitmap;
-
-struct TQListViewItemIteratorPrivate
-{
- TQListViewItemIteratorPrivate( uint f ) : flags( f )
- {
- // nothing yet
- }
-
- uint flags;
-};
-
-static TQPtrDict<TQListViewItemIteratorPrivate> *qt_iteratorprivate_dict = 0;
-
-struct TQListViewPrivate
-{
- // classes that are here to avoid polluting the global name space
-
- // the magical hidden mother of all items
- class Root: public TQListViewItem {
- public:
- Root( TQListView * parent );
-
- void setHeight( int );
- void invalidateHeight();
- void setup();
- TQListView * theListView() const;
-
- TQListView * lv;
- };
-
- // for the stack used in drawContentsOffset()
- class Pending {
- public:
- Pending( int level, int ypos, TQListViewItem * item)
- : l(level), y(ypos), i(item) {};
-
- int l; // level of this item; root is -1 or 0
- int y; // level of this item in the tree
- TQListViewItem * i; // the item itself
- };
-
- // to remember what's on screen
- class DrawableItem {
- public:
- DrawableItem( Pending * pi ) { y = pi->y; l = pi->l; i = pi->i; };
- int y;
- int l;
- TQListViewItem * i;
- };
-
- // for sorting
- class SortableItem {
- public:
- /*
- We could be smarter and keep a pointer to the TQListView
- item instead of numCols, col and asc. This would then allow
- us to use the physical ordering of columns rather than the
- logical. Microsoft uses the logical ordering, so there is
- some virtue in doing so, although it prevents the user from
- chosing the secondary key.
- */
- TQListViewItem * item;
- int numCols;
- int col;
- bool asc;
-
- int cmp( const SortableItem& i ) const {
- int diff = item->compare( i.item, col, asc );
- if ( diff == 0 && numCols != 1 ) {
- for ( int j = 0; j < numCols; j++ ) {
- if ( j != col ) {
- diff = item->compare( i.item, j, asc );
- if ( diff != 0 )
- break;
- }
- }
- }
- return diff;
- }
- bool operator<( const SortableItem& i ) const { return cmp( i ) < 0; }
- bool operator<=( const SortableItem& i ) const { return cmp( i ) <= 0; }
- bool operator>( const SortableItem& i ) const { return cmp( i ) > 0; }
- };
-
- class ItemColumnInfo {
- public:
- ItemColumnInfo(): pm( 0 ), next( 0 ), truncated( FALSE ), dirty( FALSE ), allow_rename( FALSE ), width( 0 ) {}
- ~ItemColumnInfo() { delete pm; delete next; }
- TQString text, tmpText;
- TQPixmap * pm;
- ItemColumnInfo * next;
- uint truncated : 1;
- uint dirty : 1;
- uint allow_rename : 1;
- int width;
- };
-
- class ViewColumnInfo {
- public:
- ViewColumnInfo(): align(TQt::AlignAuto), sortable(TRUE), next( 0 ) {}
- ~ViewColumnInfo() { delete next; }
- int align;
- bool sortable;
- ViewColumnInfo * next;
- };
-
- // private variables used in TQListView
- ViewColumnInfo * vci;
- TQHeader * h;
- Root * r;
- uint rootIsExpandable : 1;
- int margin;
-
- TQListViewItem * focusItem, *highlighted, *oldFocusItem;
-
- TQTimer * timer;
- TQTimer * dirtyItemTimer;
- TQTimer * visibleTimer;
- int levelWidth;
-
- // the list of drawables, and the range drawables covers entirely
- // (it may also include a few items above topPixel)
- TQPtrList<DrawableItem> * drawables;
- int topPixel;
- int bottomPixel;
-
- TQPtrDict<void> * dirtyItems;
-
- TQListView::SelectionMode selectionMode;
-
- // Per-column structure for information not in the TQHeader
- struct Column {
- TQListView::WidthMode wmode;
- };
- TQPtrVector<Column> column;
-
- // suggested height for the items
- int fontMetricsHeight;
- int minLeftBearing, minRightBearing;
- int ellipsisWidth;
-
- // currently typed prefix for the keyboard interface, and the time
- // of the last key-press
- TQString currentPrefix;
- TQTime currentPrefixTime;
-
- // holds a list of iterators
- TQPtrList<TQListViewItemIterator> *iterators;
- TQListViewItem *pressedItem, *selectAnchor;
-
- TQTimer *scrollTimer;
- TQTimer *renameTimer;
- TQTimer *autoopenTimer;
-
- // sort column and order #### may need to move to TQHeader [subclass]
- int sortcolumn;
- bool ascending :1;
- bool sortIndicator :1;
- // whether to select or deselect during this mouse press.
- bool allColumnsShowFocus :1;
- bool select :1;
-
- // TRUE if the widget should take notice of mouseReleaseEvent
- bool buttonDown :1;
- // TRUE if the widget should ignore a double-click
- bool ignoreDoubleClick :1;
-
- bool clearing :1;
- bool pressedSelected :1;
- bool pressedEmptyArea :1;
-
- bool useDoubleBuffer :1;
- bool toolTips :1;
- bool fullRepaintOnComlumnChange:1;
- bool updateHeader :1;
-
- bool startEdit : 1;
- bool ignoreEditAfterFocus : 1;
- bool inMenuMode :1;
-
- TQListView::RenameAction defRenameAction;
-
- TQListViewItem *startDragItem;
- TQPoint dragStartPos;
- TQListViewToolTip *toolTip;
- int pressedColumn;
- TQListView::ResizeMode resizeMode;
-};
-
-#ifndef TQT_NO_TOOLTIP
-class TQListViewToolTip : public TQToolTip
-{
-public:
- TQListViewToolTip( TQWidget *parent, TQListView *lv );
- virtual ~TQListViewToolTip();
-
- void maybeTip( const TQPoint &pos );
-
-private:
- TQListView *view;
-
-};
-
-TQListViewToolTip::TQListViewToolTip( TQWidget *parent, TQListView *lv )
- : TQToolTip( parent ), view( lv )
-{
-}
-
-TQListViewToolTip::~TQListViewToolTip()
-{
-}
-
-void TQListViewToolTip::maybeTip( const TQPoint &pos )
-{
- if ( !parentWidget() || !view || !view->showToolTips() )
- return;
-
- TQListViewItem *item = view->itemAt( pos );
- TQPoint contentsPos = view->viewportToContents( pos );
- if ( !item || !item->columns )
- return;
- int col = view->header()->sectionAt( contentsPos.x() );
- TQListViewPrivate::ItemColumnInfo *ci = (TQListViewPrivate::ItemColumnInfo*)item->columns;
- for ( int i = 0; ci && ( i < col ); ++i )
- ci = ci->next;
-
- if ( !ci || !ci->truncated )
- return;
-
- TQRect r = view->itemRect( item );
- int headerPos = view->header()->sectionPos( col );
- r.setLeft( headerPos );
- r.setRight( headerPos + view->header()->sectionSize( col ) );
- tip( r, TQStyleSheet::escape(item->text( col ) ) );
-}
-#endif
-
-// these should probably be in TQListViewPrivate, for future thread safety
-static bool activatedByClick;
-
-// Holds the position of activation. The position is relative to the top left corner in the row minus the root decoration and its branches/depth.
-// Used to track the point clicked for CheckBoxes and RadioButtons.
-static TQPoint activatedP;
-
-#if defined(QT_ACCESSIBILITY_SUPPORT)
-static int indexOfItem( TQListViewItem *item )
-{
- if ( !TQAccessible::isActive() )
- return 0;
-
- static TQListViewItem *lastItem = 0;
- static int lastIndex = 0;
-
- if ( !item || !item->listView() )
- return 0;
-
- if ( item == lastItem )
- return lastIndex;
-
- lastItem = item;
- int index = 1;
-
- TQListViewItemIterator it( item->listView() );
- while ( it.current() ) {
- if ( it.current() == item ) {
- lastIndex = index;
- return index;
- }
- ++it;
- ++index;
- }
- lastIndex = 0;
- return 0;
-}
-#endif
-
-/*!
- \internal
- Creates a string with ... like "Trollte..." or "...olltech" depending on the alignment
-*/
-
-static TQString qEllipsisText( const TQString &org, const TQFontMetrics &fm, int width, int align )
-{
- int ellWidth = fm.width( "..." );
- TQString text = TQString::fromLatin1("");
- int i = 0;
- int len = org.length();
- int offset = (align & TQt::AlignRight) ? (len-1) - i : i;
- while ( i < len && fm.width( text + org[ offset ] ) + ellWidth < width ) {
- if ( align & TQt::AlignRight )
- text.prepend( org[ offset ] );
- else
- text += org[ offset ];
- offset = (align & TQt::AlignRight) ? (len-1) - ++i : ++i;
- }
- if ( text.isEmpty() )
- text = ( align & TQt::AlignRight ) ? org.right( 1 ) : text = org.left( 1 );
- if ( align & TQt::AlignRight )
- text.prepend( "..." );
- else
- text += "...";
- return text;
-}
-
-/*!
- \class TQListViewItem
- \brief The TQListViewItem class implements a list view item.
-
- \ingroup advanced
-
- A list view item is a multi-column object capable of displaying
- itself in a TQListView.
-
- The easiest way to use TQListViewItem is to construct one with a
- few constant strings, and either a TQListView or another
- TQListViewItem as parent.
- \code
- (void) new TQListViewItem( listView, "Column 1", "Column 2" );
- (void) new TQListViewItem( listView->firstChild(), "A", "B", "C" );
- \endcode
- We've discarded the pointers to the items since we can still access
- them via their parent \e listView. By default, TQListView sorts its
- items; this can be switched off with TQListView::setSorting(-1).
-
- The parent must be another TQListViewItem or a TQListView. If the
- parent is a TQListView, the item becomes a top-level item within
- that TQListView. If the parent is another TQListViewItem, the item
- becomes a child of that list view item.
-
- If you keep the pointer, you can set or change the texts using
- setText(), add pixmaps using setPixmap(), change its mode using
- setSelectable(), setSelected(), setOpen() and setExpandable().
- You'll also be able to change its height using setHeight(), and
- traverse its sub-items. You don't have to keep the pointer since
- you can get a pointer to any TQListViewItem in a TQListView using
- TQListView::selectedItem(), TQListView::currentItem(),
- TQListView::firstChild(), TQListView::lastItem() and
- TQListView::findItem().
-
- If you call \c delete on a list view item, it will be deleted as
- expected, and as usual for \l{TQObject}s, if it has any child items
- (to any depth), all these will be deleted too.
-
- \l{TQCheckListItem}s are list view items that have a checkbox or
- radio button and can be used in place of plain TQListViewItems.
-
- You can traverse the tree as if it were a doubly-linked list using
- itemAbove() and itemBelow(); they return pointers to the items
- directly above and below this item on the screen (even if none of
- them are actually visible at the moment).
-
- Here's how to traverse all of an item's children (but not its
- children's children, etc.):
- Example:
- \code
- TQListViewItem * myChild = myItem->firstChild();
- while( myChild ) {
- doSomething( myChild );
- myChild = myChild->nextSibling();
- }
- \endcode
-
- If you want to iterate over every item, to any level of depth use
- an iterator. To iterate over the entire tree, initialize the
- iterator with the list view itself; to iterate starting from a
- particular item, initialize the iterator with the item:
-
- \code
- TQListViewItemIterator it( listview );
- while ( it.current() ) {
- TQListViewItem *item = it.current();
- doSomething( item );
- ++it;
- }
- \endcode
-
- Note that the order of the children will change when the sorting
- order changes and is undefined if the items are not visible. You
- can, however, call enforceSortOrder() at any time; TQListView will
- always call it before it needs to show an item.
-
- Many programs will need to reimplement TQListViewItem. The most
- commonly reimplemented functions are:
- \table
- \header \i Function \i Description
- \row \i \l text()
- \i Returns the text in a column. Many subclasses will compute
- this on the fly.
- \row \i \l key()
- \i Used for sorting. The default key() simply calls
- text(), but judicious use of key() can give you fine
- control over sorting; for example, TQFileDialog
- reimplements key() to sort by date.
- \row \i \l setup()
- \i Called before showing the item and whenever the list
- view's font changes, for example.
- \row \i \l activate()
- \i Called whenever the user clicks on the item or presses
- Space when the item is the current item.
- \endtable
-
- Some subclasses call setExpandable(TRUE) even when they have no
- children, and populate themselves when setup() or setOpen(TRUE) is
- called. The \c dirview/dirview.cpp example program uses this
- technique to start up quickly: The files and subdirectories in a
- directory aren't inserted into the tree until they're actually
- needed.
-
- \img qlistviewitems.png List View Items
-
- \sa TQCheckListItem TQListView
-*/
-
-/*!
- \fn int TQCheckListItem::rtti() const
-
- Returns 1.
-
- Make your derived classes return their own values for rtti(), and
- you can distinguish between list view items. You should use values
- greater than 1000, to allow for extensions to this class.
-*/
-
-/*!
- Constructs a new top-level list view item with no parent
-*/
-
-TQListViewItem::TQListViewItem( )
-{
- init();
-}
-
-/*!
- Constructs a new top-level list view item in the TQListView \a
- parent.
-*/
-
-TQListViewItem::TQListViewItem( TQListView * parent )
-{
- init();
- parent->insertItem( this );
-}
-
-
-/*!
- Constructs a new list view item that is a child of \a parent and
- first in the parent's list of children.
-*/
-
-TQListViewItem::TQListViewItem( TQListViewItem * parent )
-{
- init();
- parent->insertItem( this );
-}
-
-
-
-
-/*!
- Constructs an empty list view item that is a child of \a parent
- and is after item \a after in the parent's list of children. Since
- \a parent is a TQListView the item will be a top-level item.
-*/
-
-TQListViewItem::TQListViewItem( TQListView * parent, TQListViewItem * after )
-{
- init();
- parent->insertItem( this );
- moveToJustAfter( after );
-}
-
-
-/*!
- Constructs an empty list view item that is a child of \a parent
- and is after item \a after in the parent's list of children.
-*/
-
-TQListViewItem::TQListViewItem( TQListViewItem * parent, TQListViewItem * after )
-{
- init();
- parent->insertItem( this );
- moveToJustAfter( after );
-}
-
-
-
-/*!
- Constructs a new top-level list view item in the TQListView \a
- parent, with up to eight constant strings, \a label1, \a label2, \a
- label3, \a label4, \a label5, \a label6, \a label7 and \a label8
- defining its columns' contents.
-
- \sa setText()
-*/
-
-TQListViewItem::TQListViewItem( TQListView * parent,
- TQString label1,
- TQString label2,
- TQString label3,
- TQString label4,
- TQString label5,
- TQString label6,
- TQString label7,
- TQString label8 )
-{
- init();
- parent->insertItem( this );
-
- setText( 0, label1 );
- setText( 1, label2 );
- setText( 2, label3 );
- setText( 3, label4 );
- setText( 4, label5 );
- setText( 5, label6 );
- setText( 6, label7 );
- setText( 7, label8 );
-}
-
-
-/*!
- Constructs a new list view item as a child of the TQListViewItem \a
- parent with up to eight constant strings, \a label1, \a label2, \a
- label3, \a label4, \a label5, \a label6, \a label7 and \a label8
- as columns' contents.
-
- \sa setText()
-*/
-
-TQListViewItem::TQListViewItem( TQListViewItem * parent,
- TQString label1,
- TQString label2,
- TQString label3,
- TQString label4,
- TQString label5,
- TQString label6,
- TQString label7,
- TQString label8 )
-{
- init();
- parent->insertItem( this );
-
- setText( 0, label1 );
- setText( 1, label2 );
- setText( 2, label3 );
- setText( 3, label4 );
- setText( 4, label5 );
- setText( 5, label6 );
- setText( 6, label7 );
- setText( 7, label8 );
-}
-
-/*!
- Constructs a new list view item in the TQListView \a parent that is
- included after item \a after and that has up to eight column
- texts, \a label1, \a label2, \a label3, \a label4, \a label5, \a
- label6, \a label7 and\a label8.
-
- Note that the order is changed according to TQListViewItem::key()
- unless the list view's sorting is disabled using
- TQListView::setSorting(-1).
-
- \sa setText()
-*/
-
-TQListViewItem::TQListViewItem( TQListView * parent, TQListViewItem * after,
- TQString label1,
- TQString label2,
- TQString label3,
- TQString label4,
- TQString label5,
- TQString label6,
- TQString label7,
- TQString label8 )
-{
- init();
- parent->insertItem( this );
- moveToJustAfter( after );
-
- setText( 0, label1 );
- setText( 1, label2 );
- setText( 2, label3 );
- setText( 3, label4 );
- setText( 4, label5 );
- setText( 5, label6 );
- setText( 6, label7 );
- setText( 7, label8 );
-}
-
-
-/*!
- Constructs a new list view item as a child of the TQListViewItem \a
- parent. It is inserted after item \a after and may contain up to
- eight strings, \a label1, \a label2, \a label3, \a label4, \a
- label5, \a label6, \a label7 and \a label8 as column entries.
-
- Note that the order is changed according to TQListViewItem::key()
- unless the list view's sorting is disabled using
- TQListView::setSorting(-1).
-
- \sa setText()
-*/
-
-TQListViewItem::TQListViewItem( TQListViewItem * parent, TQListViewItem * after,
- TQString label1,
- TQString label2,
- TQString label3,
- TQString label4,
- TQString label5,
- TQString label6,
- TQString label7,
- TQString label8 )
-{
- init();
- parent->insertItem( this );
- moveToJustAfter( after );
-
- setText( 0, label1 );
- setText( 1, label2 );
- setText( 2, label3 );
- setText( 3, label4 );
- setText( 4, label5 );
- setText( 5, label6 );
- setText( 6, label7 );
- setText( 7, label8 );
-}
-
-/*!
- Sorts all this item's child items using the current sorting
- configuration (sort column and direction).
-
- \sa enforceSortOrder()
-*/
-
-void TQListViewItem::sort()
-{
- if ( !listView() )
- return;
- lsc = Unsorted;
- enforceSortOrder();
- listView()->triggerUpdate();
-}
-
-int TQListViewItem::RTTI = 0;
-
-/*!
- Returns 0.
-
- Make your derived classes return their own values for rtti(), so
- that you can distinguish between different kinds of list view
- items. You should use values greater than 1000 to allow for
- extensions to this class.
-*/
-
-int TQListViewItem::rtti() const
-{
- return RTTI;
-}
-
-/*
- Performs the initializations that's common to the constructors.
-*/
-
-void TQListViewItem::init()
-{
- ownHeight = 0;
- maybeTotalHeight = -1;
- open = FALSE;
-
- nChildren = 0;
- parentItem = 0;
- siblingItem = childItem = 0;
-
- columns = 0;
-
- selected = 0;
-
- lsc = Unsorted;
- lso = TRUE; // unsorted in ascending order :)
- configured = FALSE;
- expandable = FALSE;
- selectable = TRUE;
- is_root = FALSE;
- allow_drag = FALSE;
- allow_drop = FALSE;
- visible = TRUE;
- renameBox = 0;
- enabled = TRUE;
- mlenabled = FALSE;
-}
-
-/*!
- If \a b is TRUE, the item is made visible; otherwise it is hidden.
-
- If the item is not visible, itemAbove() and itemBelow() will never
- return this item, although you still can reach it by using e.g.
- TQListViewItemIterator.
-*/
-
-void TQListViewItem::setVisible( bool b )
-{
- if ( b == (bool)visible )
- return;
- TQListView *lv = listView();
- if ( !lv )
- return;
- if ( b && parent() && !parent()->isVisible() )
- return;
- visible = b;
- configured = FALSE;
- setHeight( 0 );
- invalidateHeight();
- if ( parent() )
- parent()->invalidateHeight();
- else
- lv->d->r->invalidateHeight();
- for ( TQListViewItem *i = childItem; i; i = i->siblingItem )
- i->setVisible( b );
- if ( lv )
- lv->triggerUpdate();
-}
-
-/*!
- Returns TRUE if the item is visible; otherwise returns FALSE.
-
- \sa setVisible()
-*/
-
-bool TQListViewItem::isVisible() const
-{
- return (bool)visible;
-}
-
-/*!
- If \a b is TRUE, this item can be in-place renamed in the column
- \a col by the user; otherwise it cannot be renamed in-place.
-*/
-
-void TQListViewItem::setRenameEnabled( int col, bool b )
-{
- TQListViewPrivate::ItemColumnInfo * l = (TQListViewPrivate::ItemColumnInfo*)columns;
- if ( !l ) {
- l = new TQListViewPrivate::ItemColumnInfo;
- columns = (void*)l;
- }
- for( int c = 0; c < col; c++ ) {
- if ( !l->next )
- l->next = new TQListViewPrivate::ItemColumnInfo;
- l = l->next;
- }
-
- if ( !l )
- return;
- l->allow_rename = b;
-}
-
-/*!
- Returns TRUE if this item can be in-place renamed in column \a
- col; otherwise returns FALSE.
-*/
-
-bool TQListViewItem::renameEnabled( int col ) const
-{
- TQListViewPrivate::ItemColumnInfo * l = (TQListViewPrivate::ItemColumnInfo*)columns;
- if ( !l )
- return FALSE;
-
- while( col && l ) {
- l = l->next;
- col--;
- }
-
- if ( !l )
- return FALSE;
- return (bool)l->allow_rename;
-}
-
-/*!
- If \a b is TRUE the item is enabled; otherwise it is disabled.
- Disabled items are drawn differently (e.g. grayed-out) and are not
- accessible by the user.
-*/
-
-void TQListViewItem::setEnabled( bool b )
-{
- if ( (bool)enabled == b )
- return;
- enabled = b;
- if ( !enabled )
- selected = FALSE;
- TQListView *lv = listView();
- if ( lv ) {
- lv->triggerUpdate();
-#if defined(QT_ACCESSIBILITY_SUPPORT)
- TQAccessible::updateAccessibility( lv->viewport(), indexOfItem( this ), TQAccessible::StateChanged );
-#endif
- }
-}
-
-/*!
- Returns TRUE if this item is enabled; otherwise returns FALSE.
-
- \sa setEnabled()
-*/
-
-bool TQListViewItem::isEnabled() const
-{
- return (bool)enabled;
-}
-
-/*!
- If in-place renaming of this item is enabled (see
- renameEnabled()), this function starts renaming the item in column
- \a col, by creating and initializing an edit box.
-*/
-
-void TQListViewItem::startRename( int col )
-{
- if ( !renameEnabled( col ) )
- return;
- if ( renameBox )
- cancelRename( col );
- TQListView *lv = listView();
- if ( !lv )
- return;
-
- if ( lv->d->renameTimer )
- lv->d->renameTimer->stop();
-
- lv->ensureItemVisible( this );
-
- if ( lv->d->timer->isActive() ) {
- // make sure that pending calculations get finished
- lv->d->timer->stop();
- lv->updateContents();
- }
-
- if ( lv->currentItem() && lv->currentItem()->renameBox ) {
- if ( lv->d->defRenameAction == TQListView::Reject )
- lv->currentItem()->cancelRename( lv->currentItem()->renameCol );
- else
- lv->currentItem()->okRename( lv->currentItem()->renameCol );
- }
-
- if ( this != lv->currentItem() )
- lv->setCurrentItem( this );
-
- TQRect r = lv->itemRect( this );
- r = TQRect( lv->viewportToContents( r.topLeft() ), r.size() );
- r.setLeft( lv->header()->sectionPos( col ) );
- r.setWidth(TQMIN(lv->header()->sectionSize(col) - 1,
- lv->contentsX() + lv->visibleWidth() - r.left()));
- if ( col == 0 )
- r.setLeft( r.left() + lv->itemMargin() + ( depth() + ( lv->rootIsDecorated() ? 1 : 0 ) ) * lv->treeStepSize() - 1 );
- if ( pixmap( col ) )
- r.setLeft( r.left() + pixmap( col )->width() );
- if ( r.x() - lv->contentsX() < 0 ) {
- lv->scrollBy( r.x() - lv->contentsX(), 0 );
- r.setX( lv->contentsX() );
- } else if ( ( lv->contentsX() + lv->visibleWidth() ) < ( r.x() + r.width() ) ) {
- lv->scrollBy( ( r.x() + r.width() ) - ( lv->contentsX() + lv->visibleWidth() ), 0 );
- }
- if ( r.width() > lv->visibleWidth() )
- r.setWidth( lv->visibleWidth() );
- renameBox = new TQLineEdit( lv->viewport(), "qt_renamebox" );
- renameBox->setFrameStyle( TQFrame::Box | TQFrame::Plain );
- renameBox->setLineWidth( 1 );
- renameBox->setText( text( col ) );
- renameBox->selectAll();
- renameBox->installEventFilter( lv );
- lv->addChild( renameBox, r.x(), r.y() );
- renameBox->resize( r.size() );
- lv->viewport()->setFocusProxy( renameBox );
- renameBox->setFocus();
- renameBox->show();
- renameCol = col;
-}
-
-/*!
- This function removes the rename box.
-*/
-
-void TQListViewItem::removeRenameBox()
-{
- // Sanity, it should be checked by the functions calling this first anyway
- TQListView *lv = listView();
- if ( !lv || !renameBox )
- return;
- const bool resetFocus = lv->viewport()->focusProxy() == renameBox;
- const bool renameBoxHadFocus = renameBox->hasFocus();
- delete renameBox;
- renameBox = 0;
- if ( resetFocus )
- lv->viewport()->setFocusProxy( lv );
- if (renameBoxHadFocus)
- lv->setFocus();
-}
-
-/*!
- This function is called if the user presses Enter during in-place
- renaming of the item in column \a col.
-
- \sa cancelRename()
-*/
-
-void TQListViewItem::okRename( int col )
-{
- TQListView *lv = listView();
- if ( !lv || !renameBox )
- return;
- setText( col, renameBox->text() );
- removeRenameBox();
-
- // we set the parent lsc to Unsorted if that column is the sorted one
- if ( parent() && (int)parent()->lsc == col )
- parent()->lsc = Unsorted;
-
- emit lv->itemRenamed( this, col );
- emit lv->itemRenamed( this, col, text( col ) );
-}
-
-/*!
- This function is called if the user cancels in-place renaming of
- this item in column \a col (e.g. by pressing Esc).
-
- \sa okRename()
-*/
-
-void TQListViewItem::cancelRename( int )
-{
- TQListView *lv = listView();
- if ( !lv || !renameBox )
- return;
- removeRenameBox();
-}
-
-/*!
- Destroys the item, deleting all its children and freeing up all
- allocated resources.
-*/
-
-TQListViewItem::~TQListViewItem()
-{
- if ( renameBox ) {
- delete renameBox;
- renameBox = 0;
- }
-
- TQListView *lv = listView();
-
- if ( lv ) {
- if ( lv->d->oldFocusItem == this )
- lv->d->oldFocusItem = 0;
- if ( lv->d->iterators ) {
- TQListViewItemIterator *i = lv->d->iterators->first();
- while ( i ) {
- if ( i->current() == this )
- i->currentRemoved();
- i = lv->d->iterators->next();
- }
- }
- }
-
- if ( parentItem )
- parentItem->takeItem( this );
- TQListViewItem * i = childItem;
- childItem = 0;
- while ( i ) {
- i->parentItem = 0;
- TQListViewItem * n = i->siblingItem;
- delete i;
- i = n;
- }
- delete (TQListViewPrivate::ItemColumnInfo *)columns;
-}
-
-
-/*!
- If \a b is TRUE each of the item's columns may contain multiple
- lines of text; otherwise each of them may only contain a single
- line.
-*/
-
-void TQListViewItem::setMultiLinesEnabled( bool b )
-{
- mlenabled = b;
-}
-
-/*!
- Returns TRUE if the item can display multiple lines of text in its
- columns; otherwise returns FALSE.
-*/
-
-bool TQListViewItem::multiLinesEnabled() const
-{
- return mlenabled;
-}
-
-/*!
- If \a allow is TRUE, the list view starts a drag (see
- TQListView::dragObject()) when the user presses and moves the mouse
- on this item.
-*/
-
-
-void TQListViewItem::setDragEnabled( bool allow )
-{
- allow_drag = (uint)allow;
-}
-
-/*!
- If \a allow is TRUE, the list view accepts drops onto the item;
- otherwise drops are not allowed.
-*/
-
-void TQListViewItem::setDropEnabled( bool allow )
-{
- allow_drop = (uint)allow;
-}
-
-/*!
- Returns TRUE if this item can be dragged; otherwise returns FALSE.
-
- \sa setDragEnabled()
-*/
-
-bool TQListViewItem::dragEnabled() const
-{
- return (bool)allow_drag;
-}
-
-/*!
- Returns TRUE if this item accepts drops; otherwise returns FALSE.
-
- \sa setDropEnabled(), acceptDrop()
-*/
-
-bool TQListViewItem::dropEnabled() const
-{
- return (bool)allow_drop;
-}
-
-/*!
- Returns TRUE if the item can accept drops of type TQMimeSource \a
- mime; otherwise returns FALSE.
-
- The default implementation does nothing and returns FALSE. A
- subclass must reimplement this to accept drops.
-*/
-
-bool TQListViewItem::acceptDrop( const TQMimeSource * ) const
-{
- return FALSE;
-}
-
-#ifndef TQT_NO_DRAGANDDROP
-
-/*!
- This function is called when something was dropped on the item. \a e
- contains all the information about the drop.
-
- The default implementation does nothing, subclasses may need to
- reimplement this function.
-*/
-
-void TQListViewItem::dropped( TQDropEvent *e )
-{
- Q_UNUSED( e );
-}
-
-#endif
-
-/*!
- This function is called when a drag enters the item's bounding
- rectangle.
-
- The default implementation does nothing, subclasses may need to
- reimplement this function.
-*/
-
-void TQListViewItem::dragEntered()
-{
-}
-
-/*!
- This function is called when a drag leaves the item's bounding
- rectangle.
-
- The default implementation does nothing, subclasses may need to
- reimplement this function.
-*/
-
-void TQListViewItem::dragLeft()
-{
-}
-
-/*!
- Inserts \a newChild into this list view item's list of children.
- You should not need to call this function; it is called
- automatically by the constructor of \a newChild.
-
- \warning If you are using \c Single selection mode, then you
- should only insert unselected items.
-*/
-
-void TQListViewItem::insertItem( TQListViewItem * newChild )
-{
- TQListView *lv = listView();
- if ( lv && lv->currentItem() && lv->currentItem()->renameBox ) {
- if ( lv->d->defRenameAction == TQListView::Reject )
- lv->currentItem()->cancelRename( lv->currentItem()->renameCol );
- else
- lv->currentItem()->okRename( lv->currentItem()->renameCol );
- }
-
- if ( !newChild || newChild->parentItem == this )
- return;
- if ( newChild->parentItem )
- newChild->parentItem->takeItem( newChild );
- if ( open )
- invalidateHeight();
- newChild->siblingItem = childItem;
- childItem = newChild;
- nChildren++;
- newChild->parentItem = this;
- lsc = Unsorted;
- newChild->ownHeight = 0;
- newChild->configured = FALSE;
-
- if ( lv && !lv->d->focusItem ) {
- lv->d->focusItem = lv->firstChild();
- lv->d->selectAnchor = lv->d->focusItem;
- lv->repaintItem( lv->d->focusItem );
- }
-}
-
-
-/*!
- \fn void TQListViewItem::removeItem( TQListViewItem * )
- \obsolete
-
- This function has been renamed takeItem().
-*/
-
-
-/*!
- Removes \a item from this object's list of children and causes an
- update of the screen display. The item is not deleted. You should
- not normally need to call this function because
- TQListViewItem::~TQListViewItem() calls it.
-
- The normal way to delete an item is to use \c delete.
-
- If you need to move an item from one place in the hierarchy to
- another you can use takeItem() to remove the item from the list
- view and then insertItem() to put the item back in its new
- position.
-
- If a taken item is part of a selection in \c Single selection
- mode, it is unselected and selectionChanged() is emitted. If a
- taken item is part of a selection in \c Multi or \c Extended
- selection mode, it remains selected.
-
- \warning This function leaves \a item and its children in a state
- where most member functions are unsafe. Only a few functions work
- correctly on an item in this state, most notably insertItem(). The
- functions that work on taken items are explicitly documented as
- such.
-
- \sa TQListViewItem::insertItem()
-*/
-
-void TQListViewItem::takeItem( TQListViewItem * item )
-{
- if ( !item )
- return;
-
- TQListView *lv = listView();
- if ( lv && lv->currentItem() && lv->currentItem()->renameBox ) {
- if ( lv->d->defRenameAction == TQListView::Reject )
- lv->currentItem()->cancelRename( lv->currentItem()->renameCol );
- else
- lv->currentItem()->okRename( lv->currentItem()->renameCol );
- }
- bool emit_changed = FALSE;
- if ( lv && !lv->d->clearing ) {
- if ( lv->d->oldFocusItem == this )
- lv->d->oldFocusItem = 0;
-
- if ( lv->d->iterators ) {
- TQListViewItemIterator *i = lv->d->iterators->first();
- while ( i ) {
- if ( i->current() == item )
- i->currentRemoved();
- i = lv->d->iterators->next();
- }
- }
-
- invalidateHeight();
-
- if ( lv->d && lv->d->drawables ) {
- delete lv->d->drawables;
- lv->d->drawables = 0;
- }
-
- if ( lv->d->dirtyItems ) {
- if ( item->childItem ) {
- delete lv->d->dirtyItems;
- lv->d->dirtyItems = 0;
- lv->d->dirtyItemTimer->stop();
- lv->triggerUpdate();
- } else {
- lv->d->dirtyItems->take( (void *)item );
- }
- }
-
- if ( lv->d->focusItem ) {
- const TQListViewItem * c = lv->d->focusItem;
- while( c && c != item )
- c = c->parentItem;
- if ( c == item ) {
- if ( lv->selectedItem() ) {
- // for Single, setSelected( FALSE ) when selectedItem() is taken
- lv->selectedItem()->setSelected( FALSE );
- // we don't emit selectionChanged( 0 )
- emit lv->selectionChanged();
- }
- if ( item->nextSibling() )
- lv->d->focusItem = item->nextSibling();
- else if ( item->itemAbove() )
- lv->d->focusItem = item->itemAbove();
- else
- lv->d->focusItem = 0;
- emit_changed = TRUE;
- }
- }
-
- // reset anchors etc. if they are set to this or any child
- // items
- const TQListViewItem *ptr = lv->d->selectAnchor;
- while (ptr && ptr != item)
- ptr = ptr->parentItem;
- if (ptr == item)
- lv->d->selectAnchor = lv->d->focusItem;
-
- ptr = lv->d->startDragItem;
- while (ptr && ptr != item)
- ptr = ptr->parentItem;
- if (ptr == item)
- lv->d->startDragItem = 0;
-
- ptr = lv->d->pressedItem;
- while (ptr && ptr != item)
- ptr = ptr->parentItem;
- if (ptr == item)
- lv->d->pressedItem = 0;
-
- ptr = lv->d->highlighted;
- while (ptr && ptr != item)
- ptr = ptr->parentItem;
- if (ptr == item)
- lv->d->highlighted = 0;
- }
-
- nChildren--;
-
- TQListViewItem ** nextChild = &childItem;
- while( nextChild && *nextChild && item != *nextChild )
- nextChild = &((*nextChild)->siblingItem);
-
- if ( nextChild && item == *nextChild )
- *nextChild = (*nextChild)->siblingItem;
- item->parentItem = 0;
- item->siblingItem = 0;
- item->ownHeight = 0;
- item->maybeTotalHeight = -1;
- item->configured = FALSE;
-
- if ( emit_changed ) {
- emit lv->currentChanged( lv->d->focusItem );
-#if defined(QT_ACCESSIBILITY_SUPPORT)
- TQAccessible::updateAccessibility( lv->viewport(), 0, TQAccessible::Focus );
-#endif
- }
-}
-
-
-/*!
- \fn TQString TQListViewItem::key( int column, bool ascending ) const
-
- Returns a key that can be used for sorting by column \a column.
- The default implementation returns text(). Derived classes may
- also incorporate the order indicated by \a ascending into this
- key, although this is not recommended.
-
- If you want to sort on non-alphabetical data, e.g. dates, numbers,
- etc., it is more efficient to reimplement compare().
-
- \sa compare(), sortChildItems()
-*/
-
-TQString TQListViewItem::key( int column, bool ) const
-{
- return text( column );
-}
-
-
-/*!
- Compares this list view item to \a i using the column \a col in \a
- ascending order. Returns \< 0 if this item is less than \a i, 0 if
- they are equal and \> 0 if this item is greater than \a i.
-
- This function is used for sorting.
-
- The default implementation compares the item keys (key()) using
- TQString::localeAwareCompare(). A reimplementation can use
- different values and a different comparison function. Here is a
- reimplementation that uses plain Unicode comparison:
-
- \code
- int MyListViewItem::compare( TQListViewItem *i, int col,
- bool ascending ) const
- {
- return key( col, ascending ).compare( i->key( col, ascending) );
- }
- \endcode
- We don't recommend using \a ascending so your code can safely
- ignore it.
-
- \sa key() TQString::localeAwareCompare() TQString::compare()
-*/
-
-int TQListViewItem::compare( TQListViewItem *i, int col, bool ascending ) const
-{
- return key( col, ascending ).localeAwareCompare( i->key( col, ascending ) );
-}
-
-/*!
- Sorts this item's children using column \a column. This is done in
- ascending order if \a ascending is TRUE and in descending order if
- \a ascending is FALSE.
-
- Asks some of the children to sort their children. (TQListView and
- TQListViewItem ensure that all on-screen objects are properly
- sorted but may avoid or defer sorting other objects in order to be
- more responsive.)
-
- \sa key() compare()
-*/
-
-void TQListViewItem::sortChildItems( int column, bool ascending )
-{
- // we try HARD not to sort. if we're already sorted, don't.
- if ( column == (int)lsc && ascending == (bool)lso )
- return;
-
- if ( column < 0 )
- return;
-
- lsc = column;
- lso = ascending;
-
- const int nColumns = ( listView() ? listView()->columns() : 0 );
-
- // only sort if the item have more than one child.
- if ( column > nColumns || childItem == 0 || (childItem->siblingItem == 0 && childItem->childItem == 0))
- return;
-
- // make an array for qHeapSort()
- TQListViewPrivate::SortableItem * siblings
- = new TQListViewPrivate::SortableItem[nChildren];
- TQListViewItem * s = childItem;
- int i = 0;
- while ( s && i < nChildren ) {
- siblings[i].numCols = nColumns;
- siblings[i].col = column;
- siblings[i].asc = ascending;
- siblings[i].item = s;
- s = s->siblingItem;
- i++;
- }
-
- // and sort it.
- qHeapSort( siblings, siblings + nChildren );
-
- // build the linked list of siblings, in the appropriate
- // direction, and finally set this->childItem to the new top
- // child.
- if ( ascending ) {
- for( i = 0; i < nChildren - 1; i++ )
- siblings[i].item->siblingItem = siblings[i+1].item;
- siblings[nChildren-1].item->siblingItem = 0;
- childItem = siblings[0].item;
- } else {
- for( i = nChildren - 1; i > 0; i-- )
- siblings[i].item->siblingItem = siblings[i-1].item;
- siblings[0].item->siblingItem = 0;
- childItem = siblings[nChildren-1].item;
- }
- for ( i = 0; i < nChildren; i++ ) {
- if ( siblings[i].item->isOpen() )
- siblings[i].item->sort();
- }
- delete[] siblings;
-}
-
-
-/*!
- Sets this item's height to \a height pixels. This implicitly
- changes totalHeight(), too.
-
- Note that a font change causes this height to be overwritten
- unless you reimplement setup().
-
- For best results in Windows style we suggest using an even number
- of pixels.
-
- \sa height() totalHeight() isOpen();
-*/
-
-void TQListViewItem::setHeight( int height )
-{
- if ( ownHeight != height ) {
- if ( visible )
- ownHeight = height;
- else
- ownHeight = 0;
- invalidateHeight();
- }
-}
-
-
-/*!
- Invalidates the cached total height of this item, including all
- open children.
-
- \sa setHeight() height() totalHeight()
-*/
-
-void TQListViewItem::invalidateHeight()
-{
- if ( maybeTotalHeight < 0 )
- return;
- maybeTotalHeight = -1;
- if ( parentItem && parentItem->isOpen() )
- parentItem->invalidateHeight();
-}
-
-
-/*!
- Opens or closes an item, i.e. shows or hides an item's children.
-
- If \a o is TRUE all child items are shown initially. The user can
- hide them by clicking the <b>-</b> icon to the left of the item.
- If \a o is FALSE, the children of this item are initially hidden.
- The user can show them by clicking the <b>+</b> icon to the left
- of the item.
-
- \sa height() totalHeight() isOpen()
-*/
-
-void TQListViewItem::setOpen( bool o )
-{
- if ( o == (bool)open || !enabled )
- return;
- open = o;
-
- // If no children to show simply emit signals and return
- if ( !nChildren ) {
- TQListView *lv = listView();
- if ( lv && this != lv->d->r ) {
- if ( o )
- emit lv->expanded( this );
- else
- emit lv->collapsed( this );
-#if defined(QT_ACCESSIBILITY_SUPPORT)
- TQAccessible::updateAccessibility( lv->viewport(), indexOfItem( this ), TQAccessible::StateChanged );
-#endif
- }
- return;
- }
- invalidateHeight();
-
- if ( !configured ) {
- TQListViewItem * l = this;
- TQPtrStack<TQListViewItem> s;
- while( l ) {
- if ( l->open && l->childItem ) {
- s.push( l->childItem );
- } else if ( l->childItem ) {
- // first invisible child is unconfigured
- TQListViewItem * c = l->childItem;
- while( c ) {
- c->configured = FALSE;
- c = c->siblingItem;
- }
- }
- l->configured = TRUE;
- l->setup();
- l = (l == this) ? 0 : l->siblingItem;
- if ( !l && !s.isEmpty() )
- l = s.pop();
- }
- }
-
- TQListView *lv = listView();
-
- if ( open && lv)
- enforceSortOrder();
-
- if ( isVisible() && lv && lv->d && lv->d->drawables ) {
- lv->d->drawables->clear();
- lv->buildDrawableList();
- }
-
- if ( lv && this != lv->d->r ) {
- if ( o )
- emit lv->expanded( this );
- else
- emit lv->collapsed( this );
-#if defined(QT_ACCESSIBILITY_SUPPORT)
- TQAccessible::updateAccessibility( lv->viewport(), indexOfItem( this ), TQAccessible::StateChanged );
-#endif
- }
-}
-
-
-/*!
- This virtual function is called before the first time TQListView
- needs to know the height or any other graphical attribute of this
- object, and whenever the font, GUI style, or colors of the list
- view change.
-
- The default calls widthChanged() and sets the item's height to the
- height of a single line of text in the list view's font. (If you
- use icons, multi-line text, etc., you will probably need to call
- setHeight() yourself or reimplement it.)
-*/
-
-void TQListViewItem::setup()
-{
- widthChanged();
- TQListView *lv = listView();
-
- int ph = 0;
- int h = 0;
- if ( lv ) {
- for ( uint i = 0; i < lv->d->column.size(); ++i ) {
- if ( pixmap( i ) )
- ph = TQMAX( ph, pixmap( i )->height() );
- }
-
- if ( mlenabled ) {
- h = ph;
- for ( int c = 0; c < lv->columns(); ++c ) {
- int lines = text( c ).contains( TQChar('\n') ) + 1;
- int tmph = lv->d->fontMetricsHeight
- + lv->fontMetrics().lineSpacing() * ( lines - 1 );
- h = TQMAX( h, tmph );
- }
- h += 2*lv->itemMargin();
- } else {
- h = TQMAX( lv->d->fontMetricsHeight, ph ) + 2*lv->itemMargin();
- }
- }
-
- h = TQMAX( h, TQApplication::globalStrut().height());
-
- if ( h % 2 > 0 )
- h++;
- setHeight( h );
-}
-
-
-
-
-/*!
- This virtual function is called whenever the user presses the mouse
- on this item or presses Space on it.
-
- \sa activatedPos()
-*/
-
-void TQListViewItem::activate()
-{
-}
-
-
-/*!
- When called from a reimplementation of activate(), this function
- gives information on how the item was activated. Otherwise the
- behavior is undefined.
-
- If activate() was caused by a mouse press, the function sets \a
- pos to where the user clicked and returns TRUE; otherwise it
- returns FALSE and does not change \a pos.
-
- \a pos is relative to the top-left corner of this item.
-
- \warning We recommend that you ignore this function; it is
- scheduled to become obsolete.
-
- \sa activate()
-*/
-
-bool TQListViewItem::activatedPos( TQPoint &pos )
-{
- if ( activatedByClick )
- pos = activatedP;
- return activatedByClick;
-}
-
-
-/*!
- \fn bool TQListViewItem::isSelectable() const
-
- Returns TRUE if the item is selectable (as it is by default);
- otherwise returns FALSE
-
- \sa setSelectable()
-*/
-
-
-/*!
- Sets this item to be selectable if \a enable is TRUE (the
- default) or not to be selectable if \a enable is FALSE.
-
- The user is not able to select a non-selectable item using either
- the keyboard or the mouse. This also applies for the application
- programmer (e.g. setSelected() respects this value).
-
- \sa isSelectable()
-*/
-
-void TQListViewItem::setSelectable( bool enable )
-{
- selectable = enable;
-}
-
-
-/*!
- \fn bool TQListViewItem::isExpandable() const
-
- Returns TRUE if this item is expandable even when it has no
- children; otherwise returns FALSE.
-*/
-
-/*!
- Sets this item to be expandable even if it has no children if \a
- enable is TRUE, and to be expandable only if it has children if \a
- enable is FALSE (the default).
-
- The dirview example uses this in the canonical fashion. It checks
- whether the directory is empty in setup() and calls
- setExpandable(TRUE) if not; in setOpen() it reads the contents of
- the directory and inserts items accordingly. This strategy means
- that dirview can display the entire file system without reading
- very much at startup.
-
- Note that root items are not expandable by the user unless
- TQListView::setRootIsDecorated() is set to TRUE.
-
- \sa setSelectable()
-*/
-
-void TQListViewItem::setExpandable( bool enable )
-{
- expandable = enable;
-}
-
-
-/*!
- Makes sure that this object's children are sorted appropriately.
-
- This only works if every item from the root item down to this item
- is already sorted.
-
- \sa sortChildItems()
-*/
-
-void TQListViewItem::enforceSortOrder() const
-{
- TQListView *lv = listView();
- if ( !lv || (lv && (lv->d->clearing || lv->d->sortcolumn == Unsorted)) )
- return;
- if ( parentItem &&
- (parentItem->lsc != lsc || parentItem->lso != lso) )
- ((TQListViewItem *)this)->sortChildItems( (int)parentItem->lsc,
- (bool)parentItem->lso );
- else if ( !parentItem &&
- ( (int)lsc != lv->d->sortcolumn || (bool)lso != lv->d->ascending ) )
- ((TQListViewItem *)this)->sortChildItems( lv->d->sortcolumn, lv->d->ascending );
-}
-
-
-/*!
- \fn bool TQListViewItem::isSelected() const
-
- Returns TRUE if this item is selected; otherwise returns FALSE.
-
- \sa setSelected() TQListView::setSelected() TQListView::selectionChanged()
-*/
-
-
-/*!
- If \a s is TRUE this item is selected; otherwise it is deselected.
-
- This function does not maintain any invariants or repaint anything
- -- TQListView::setSelected() does that.
-
- \sa height() totalHeight()
-*/
-
-void TQListViewItem::setSelected( bool s )
-{
- bool old = selected;
-
- TQListView *lv = listView();
- if ( lv && lv->selectionMode() != TQListView::NoSelection) {
- if ( s && isSelectable() )
- selected = TRUE;
- else
- selected = FALSE;
-
-#if defined(QT_ACCESSIBILITY_SUPPORT)
- if ( old != (bool)selected ) {
- int ind = indexOfItem( this );
- TQAccessible::updateAccessibility( lv->viewport(), ind, TQAccessible::StateChanged );
- TQAccessible::updateAccessibility( lv->viewport(), ind, selected ? TQAccessible::SelectionAdd : TQAccessible::SelectionRemove );
- }
-#else
- Q_UNUSED( old );
-#endif
- }
-}
-
-/*!
- Returns the total height of this object, including any visible
- children. This height is recomputed lazily and cached for as long
- as possible.
-
- Functions which can affect the total height are, setHeight() which
- is used to set an item's height, setOpen() to show or hide an
- item's children, and invalidateHeight() to invalidate the cached
- height.
-
- \sa height()
-*/
-
-int TQListViewItem::totalHeight() const
-{
- if ( !visible )
- return 0;
- if ( maybeTotalHeight >= 0 )
- return maybeTotalHeight;
- TQListViewItem * that = (TQListViewItem *)this;
- if ( !that->configured ) {
- that->configured = TRUE;
- that->setup(); // ### virtual non-const function called in const
- }
- that->maybeTotalHeight = that->ownHeight;
-
- if ( !that->isOpen() || !that->childCount() )
- return that->ownHeight;
-
- TQListViewItem * child = that->childItem;
- while ( child != 0 ) {
- that->maybeTotalHeight += child->totalHeight();
- child = child->siblingItem;
- }
- return that->maybeTotalHeight;
-}
-
-
-/*!
- Returns the text in column \a column, or TQString::null if there is
- no text in that column.
-
- \sa key() paintCell()
-*/
-
-TQString TQListViewItem::text( int column ) const
-{
- TQListViewPrivate::ItemColumnInfo * l
- = (TQListViewPrivate::ItemColumnInfo*) columns;
-
- while( column && l ) {
- l = l->next;
- column--;
- }
-
- return l ? l->text : TQString::null;
-}
-
-
-/*!
- Sets the text in column \a column to \a text, if \a column is a
- valid column number and \a text is different from the existing
- text.
-
- If \a text() has been reimplemented, this function may be a no-op.
-
- \sa text() key()
-*/
-
-void TQListViewItem::setText( int column, const TQString &text )
-{
- if ( column < 0 )
- return;
-
- TQListViewPrivate::ItemColumnInfo * l
- = (TQListViewPrivate::ItemColumnInfo*) columns;
- if ( !l ) {
- l = new TQListViewPrivate::ItemColumnInfo;
- columns = (void*)l;
- }
- for( int c = 0; c < column; c++ ) {
- if ( !l->next )
- l->next = new TQListViewPrivate::ItemColumnInfo;
- l = l->next;
- }
- if ( l->text == text )
- return;
-
- int oldLc = 0;
- int newLc = 0;
- if ( mlenabled ) {
- if ( !l->text.isEmpty() )
- oldLc = l->text.contains( TQChar( '\n' ) ) + 1;
- if ( !text.isEmpty() )
- newLc = text.contains( TQChar( '\n' ) ) + 1;
- }
-
- l->dirty = TRUE;
- l->text = text;
- if ( column == (int)lsc )
- lsc = Unsorted;
-
- if ( mlenabled && oldLc != newLc )
- setup();
- else
- widthChanged( column );
-
- TQListView * lv = listView();
- if ( lv ) {
- lv->d->useDoubleBuffer = TRUE;
- lv->triggerUpdate();
-#if defined(QT_ACCESSIBILITY_SUPPORT)
- if ( lv->isVisible() )
- TQAccessible::updateAccessibility( lv->viewport(), indexOfItem(this), TQAccessible::NameChanged );
-#endif
- }
-}
-
-
-/*!
- Sets the pixmap in column \a column to \a pm, if \a pm is non-null
- and different from the current pixmap, and if \a column is
- non-negative.
-
- \sa pixmap() setText()
-*/
-
-void TQListViewItem::setPixmap( int column, const TQPixmap & pm )
-{
- if ( column < 0 )
- return;
-
- int oldW = 0;
- int oldH = 0;
- if ( pixmap( column ) ) {
- oldW = pixmap( column )->width();
- oldH = pixmap( column )->height();
- }
-
- TQListViewPrivate::ItemColumnInfo * l
- = (TQListViewPrivate::ItemColumnInfo*) columns;
- if ( !l ) {
- l = new TQListViewPrivate::ItemColumnInfo;
- columns = (void*)l;
- }
-
- for( int c = 0; c < column; c++ ) {
- if ( !l->next )
- l->next = new TQListViewPrivate::ItemColumnInfo;
- l = l->next;
- }
-
- if ( ( pm.isNull() && ( !l->pm || l->pm->isNull() ) ) ||
- ( l->pm && pm.serialNumber() == l->pm->serialNumber() ) )
- return;
-
- if ( pm.isNull() ) {
- delete l->pm;
- l->pm = 0;
- } else {
- if ( l->pm )
- *(l->pm) = pm;
- else
- l->pm = new TQPixmap( pm );
- }
-
- int newW = 0;
- int newH = 0;
- if ( pixmap( column ) ) {
- newW = pixmap( column )->width();
- newH = pixmap( column )->height();
- }
-
- if ( oldW != newW || oldH != newH ) {
- setup();
- widthChanged( column );
- invalidateHeight();
- }
- TQListView *lv = listView();
- if ( lv ) {
- lv->d->useDoubleBuffer = TRUE;
- lv->triggerUpdate();
- }
-}
-
-
-/*!
- Returns the pixmap for \a column, or 0 if there is no pixmap for
- \a column.
-
- \sa setText() setPixmap()
-*/
-
-const TQPixmap * TQListViewItem::pixmap( int column ) const
-{
- TQListViewPrivate::ItemColumnInfo * l
- = (TQListViewPrivate::ItemColumnInfo*) columns;
-
- while( column && l ) {
- l = l->next;
- column--;
- }
-
- return (l && l->pm) ? l->pm : 0;
-}
-
-
-/*!
- This virtual function paints the contents of one column of an item
- and aligns it as described by \a align.
-
- \a p is a TQPainter open on the relevant paint device. \a p is
- translated so (0, 0) is the top-left pixel in the cell and \a
- width-1, height()-1 is the bottom-right pixel \e in the cell. The
- other properties of \a p (pen, brush, etc) are undefined. \a cg is
- the color group to use. \a column is the logical column number
- within the item that is to be painted; 0 is the column which may
- contain a tree.
-
- This function may use TQListView::itemMargin() for readability
- spacing on the left and right sides of data such as text, and
- should honor isSelected() and TQListView::allColumnsShowFocus().
-
- If you reimplement this function, you should also reimplement
- width().
-
- The rectangle to be painted is in an undefined state when this
- function is called, so you \e must draw on all the pixels. The
- painter \a p has the right font on entry.
-
- \sa paintBranches(), TQListView::drawContentsOffset()
-*/
-
-void TQListViewItem::paintCell( TQPainter * p, const TQColorGroup & cg,
- int column, int width, int align )
-{
- // Change width() if you change this.
-
- if ( !p )
- return;
-
- TQListView *lv = listView();
- if ( !lv )
- return;
- TQFontMetrics fm( p->fontMetrics() );
-
- // had, but we _need_ the column info for the ellipsis thingy!!!
- if ( !columns ) {
- for ( uint i = 0; i < lv->d->column.size(); ++i ) {
- setText( i, text( i ) );
- }
- }
-
- TQString t = text( column );
-
- if ( columns ) {
- TQListViewPrivate::ItemColumnInfo *ci = 0;
- // try until we have a column info....
- while ( !ci ) {
- ci = (TQListViewPrivate::ItemColumnInfo*)columns;
- for ( int i = 0; ci && (i < column); ++i )
- ci = ci->next;
-
- if ( !ci ) {
- setText( column, t );
- ci = 0;
- }
- }
-
- // if the column width changed and this item was not painted since this change
- if ( ci && ( ci->width != width || ci->text != t || ci->dirty ) ) {
- ci->text = t;
- ci->dirty = FALSE;
- ci->width = width;
- ci->truncated = FALSE;
- // if we have to do the ellipsis thingy calc the truncated text
- int pw = lv->itemMargin()*2 - lv->d->minLeftBearing - lv->d->minRightBearing;
- pw += pixmap( column ) ? pixmap( column )->width() + lv->itemMargin() : 0;
- if ( !mlenabled && fm.width( t ) + pw > width ) {
- // take care of arabic shaping in width calculation (lars)
- ci->truncated = TRUE;
- ci->tmpText = qEllipsisText( t, fm, width - pw, align );
- } else if ( mlenabled && fm.width( t ) + pw > width ) {
-#ifndef TQT_NO_STRINGLIST
- TQStringList list = TQStringList::split( TQChar('\n'), t, TRUE );
- for ( TQStringList::Iterator it = list.begin(); it != list.end(); ++it ) {
- TQString z = *it;
- if ( fm.width( z ) + pw > width ) {
- ci->truncated = TRUE;
- *it = qEllipsisText( z, fm, width - pw, align );
- }
- }
-
- if ( ci->truncated )
- ci->tmpText = list.join( TQString("\n") );
-#endif
- }
- }
-
- // if we have to draw the ellipsis thingy, use the truncated text
- if ( ci && ci->truncated )
- t = ci->tmpText;
- }
-
- int marg = lv->itemMargin();
- int r = marg;
- const TQPixmap * icon = pixmap( column );
-
- const BackgroundMode bgmode = lv->viewport()->backgroundMode();
- const TQColorGroup::ColorRole crole = TQPalette::backgroundRoleFromMode( bgmode );
- if ( cg.brush( crole ) != lv->colorGroup().brush( crole ) )
- p->fillRect( 0, 0, width, height(), cg.brush( crole ) );
- else
- lv->paintEmptyArea( p, TQRect( 0, 0, width, height() ) );
-
-
- // (lars) what does this do???
-#if 0 // RS: ####
- if ( align != AlignLeft )
- marg -= lv->d->minRightBearing;
-#endif
- if ( isSelected() &&
- (column == 0 || lv->allColumnsShowFocus()) ) {
- p->fillRect( r - marg, 0, width - r + marg, height(),
- cg.brush( TQColorGroup::Highlight ) );
- if ( enabled || !lv )
- p->setPen( cg.highlightedText() );
- else if ( !enabled && lv)
- p->setPen( lv->palette().disabled().highlightedText() );
- } else {
- if ( enabled || !lv )
- p->setPen( cg.text() );
- else if ( !enabled && lv)
- p->setPen( lv->palette().disabled().text() );
- }
-
-
-#if 0
- bool reverse = TQApplication::reverseLayout();
-#else
- bool reverse = FALSE;
-#endif
- int iconWidth = 0;
-
- if ( icon ) {
- iconWidth = icon->width() + lv->itemMargin();
- int xo = r;
- // we default to AlignVCenter.
- int yo = ( height() - icon->height() ) / 2;
-
- // I guess we may as well always respect vertical alignment.
- if ( align & AlignBottom )
- yo = height() - icon->height();
- else if ( align & AlignTop )
- yo = 0;
-
- // respect horizontal alignment when there is no text for an item.
- if ( text(column).isEmpty() ) {
- if ( align & AlignRight )
- xo = width - 2 * marg - iconWidth;
- else if ( align & AlignHCenter )
- xo = ( width - iconWidth ) / 2;
- }
- if ( reverse )
- xo = width - 2 * marg - iconWidth;
- p->drawPixmap( xo, yo, *icon );
- }
-
- if ( !t.isEmpty() ) {
- if ( !mlenabled ) {
- if ( !(align & AlignTop || align & AlignBottom) )
- align |= AlignVCenter;
- } else {
- if ( !(align & AlignVCenter || align & AlignBottom) )
- align |= AlignTop;
- }
- if ( !reverse )
- r += iconWidth;
-
- if ( !mlenabled ) {
- p->drawText( r, 0, width-marg-r, height(), align, t );
- } else {
- p->drawText( r, marg, width-marg-r, height(), align, t );
- }
- }
-
- if ( mlenabled && column == 0 && isOpen() && childCount() ) {
- int textheight = fm.size( align, t ).height() + 2 * lv->itemMargin();
- textheight = TQMAX( textheight, TQApplication::globalStrut().height() );
- if ( textheight % 2 > 0 )
- textheight++;
- if ( textheight < height() ) {
- int w = lv->treeStepSize() / 2;
- lv->style().drawComplexControl( TQStyle::CC_ListView, p, lv,
- TQRect( 0, textheight, w + 1, height() - textheight + 1 ), cg,
- lv->isEnabled() ? TQStyle::Style_Enabled : TQStyle::Style_Default,
- TQStyle::SC_ListViewExpand,
- (uint)TQStyle::SC_All, TQStyleOption( this ) );
- }
- }
-}
-
-/*!
- Returns the number of pixels of width required to draw column \a c
- of list view \a lv, using the metrics \a fm without cropping. The
- list view containing this item may use this information depending
- on the TQListView::WidthMode settings for the column.
-
- The default implementation returns the width of the bounding
- rectangle of the text of column \a c.
-
- \sa listView() widthChanged() TQListView::setColumnWidthMode()
- TQListView::itemMargin()
-*/
-int TQListViewItem::width( const TQFontMetrics& fm,
- const TQListView* lv, int c ) const
-{
- int w;
- if ( mlenabled )
- w = fm.size( AlignVCenter, text( c ) ).width() + lv->itemMargin() * 2
- - lv->d->minLeftBearing - lv->d->minRightBearing;
- else
- w = fm.width( text( c ) ) + lv->itemMargin() * 2
- - lv->d->minLeftBearing - lv->d->minRightBearing;
- const TQPixmap * pm = pixmap( c );
- if ( pm )
- w += pm->width() + lv->itemMargin(); // ### correct margin stuff?
- return TQMAX( w, TQApplication::globalStrut().width() );
-}
-
-
-/*!
- Paints a focus indicator on the rectangle \a r using painter \a p
- and colors \a cg.
-
- \a p is already clipped.
-
- \sa paintCell() paintBranches() TQListView::setAllColumnsShowFocus()
-*/
-
-void TQListViewItem::paintFocus( TQPainter *p, const TQColorGroup &cg,
- const TQRect & r )
-{
- TQListView *lv = listView();
- if ( lv )
- lv->style().drawPrimitive( TQStyle::PE_FocusRect, p, r, cg,
- (isSelected() ?
- TQStyle::Style_FocusAtBorder :
- TQStyle::Style_Default),
- TQStyleOption(isSelected() ? cg.highlight() : cg.base() ));
-}
-
-
-/*!
- Paints a set of branches from this item to (some of) its children.
-
- Painter \a p is set up with clipping and translation so that you
- can only draw in the rectangle that needs redrawing; \a cg is the
- color group to use; the update rectangle is at (0, 0) and has size
- width \a w by height \a h. The top of the rectangle you own is at
- \a y (which is never greater than 0 but can be outside the window
- system's allowed coordinate range).
-
- The update rectangle is in an undefined state when this function
- is called; this function must draw on \e all of the pixels.
-
- \sa paintCell(), TQListView::drawContentsOffset()
-*/
-
-void TQListViewItem::paintBranches( TQPainter * p, const TQColorGroup & cg,
- int w, int y, int h )
-{
- TQListView *lv = listView();
- if ( lv )
- lv->paintEmptyArea( p, TQRect( 0, 0, w, h ) );
- if ( !visible || !lv )
- return;
- lv->style().drawComplexControl( TQStyle::CC_ListView, p, lv,
- TQRect( 0, y, w, h ),
- cg,
- lv->isEnabled() ? TQStyle::Style_Enabled :
- TQStyle::Style_Default,
- (TQStyle::SC_ListViewBranch |
- TQStyle::SC_ListViewExpand),
- TQStyle::SC_None, TQStyleOption(this) );
-}
-
-
-TQListViewPrivate::Root::Root( TQListView * parent )
- : TQListViewItem( parent )
-{
- lv = parent;
- setHeight( 0 );
- setOpen( TRUE );
-}
-
-
-void TQListViewPrivate::Root::setHeight( int )
-{
- TQListViewItem::setHeight( 0 );
-}
-
-
-void TQListViewPrivate::Root::invalidateHeight()
-{
- TQListViewItem::invalidateHeight();
- lv->triggerUpdate();
-}
-
-
-TQListView * TQListViewPrivate::Root::theListView() const
-{
- return lv;
-}
-
-
-void TQListViewPrivate::Root::setup()
-{
- // explicitly nothing
-}
-
-
-
-/*!
-\internal
-If called after a mouse click, tells the list view to ignore a
-following double click. This state is reset after the next mouse click.
-*/
-
-void TQListViewItem::ignoreDoubleClick()
-{
- TQListView *lv = listView();
- if ( lv )
- lv->d->ignoreDoubleClick = TRUE;
-}
-
-
-
-/*!
- \fn void TQListView::onItem( TQListViewItem *i )
-
- This signal is emitted when the user moves the mouse cursor onto
- item \a i, similar to the TQWidget::enterEvent() function.
-*/
-
-// ### bug here too? see tqiconview.cpp onItem/onViewport
-
-/*!
- \fn void TQListView::onViewport()
-
- This signal is emitted when the user moves the mouse cursor from
- an item to an empty part of the list view.
-*/
-
-/*!
- \enum TQListView::SelectionMode
-
- This enumerated type is used by TQListView to indicate how it
- reacts to selection by the user.
-
- \value Single When the user selects an item, any already-selected
- item becomes unselected. The user can unselect the selected
- item by clicking on some empty space within the view.
-
- \value Multi When the user selects an item in the usual way, the
- selection status of that item is toggled and the other items are
- left alone. Also, multiple items can be selected by dragging the
- mouse while the left mouse button stays pressed.
-
- \value Extended When the user selects an item in the usual way,
- the selection is cleared and the new item selected. However, if
- the user presses the Ctrl key when clicking on an item, the
- clicked item gets toggled and all other items are left untouched.
- And if the user presses the Shift key while clicking on an item,
- all items between the current item and the clicked item get
- selected or unselected, depending on the state of the clicked
- item. Also, multiple items can be selected by dragging the mouse
- over them.
-
- \value NoSelection Items cannot be selected.
-
- In other words, \c Single is a real single-selection list view, \c
- Multi a real multi-selection list view, \c Extended is a list view
- where users can select multiple items but usually want to select
- either just one or a range of contiguous items, and \c NoSelection
- is a list view where the user can look but not touch.
-*/
-
-/*!
- \enum TQListView::ResizeMode
-
- This enum describes how the list view's header adjusts to resize
- events which affect the width of the list view.
-
- \value NoColumn The columns do not get resized in resize events.
-
- \value AllColumns All columns are resized equally to fit the width
- of the list view.
-
- \value LastColumn The last column is resized to fit the width of
- the list view.
-*/
-
-/*!
- \enum TQListView::RenameAction
-
- This enum describes whether a rename operation is accepted if the
- rename editor loses focus without the user pressing Enter.
-
- \value Accept Rename if Enter is pressed or focus is lost.
-
- \value Reject Discard the rename operation if focus is lost (and
- Enter has not been pressed).
-*/
-
-/*!
- \class TQListView
- \brief The TQListView class implements a list/tree view.
-
- \ingroup advanced
- \mainclass
-
- It can display and control a hierarchy of multi-column items, and
- provides the ability to add new items at any time. The user may
- select one or many items (depending on the \c SelectionMode) and
- sort the list in increasing or decreasing order by any column.
-
- The simplest pattern of use is to create a TQListView, add some
- column headers using addColumn() and create one or more
- TQListViewItem or TQCheckListItem objects with the TQListView as
- parent:
-
- \quotefile xml/tagreader-with-features/structureparser.h
- \skipto TQListView * table
- \printline
- \quotefile xml/tagreader-with-features/structureparser.cpp
- \skipto addColumn
- \printline addColumn
- \printline
- \skipto new TQListViewItem( table
- \printline
-
- Further nodes can be added to the list view object (the root of the
- tree) or as child nodes to TQListViewItems:
-
- \skipto for ( int i = 0 ; i < attributes.length();
- \printuntil }
-
- (From \link xml/tagreader-with-features/structureparser.cpp
- xml/tagreader-with-features/structureparser.cpp\endlink)
-
- The main setup functions are:
- \table
- \header \i Function \i Action
- \row \i \l addColumn()
- \i Adds a column with a text label and perhaps width. Columns
- are counted from the left starting with column 0.
- \row \i \l setColumnWidthMode()
- \i Sets the column to be resized automatically or not.
- \row \i \l setAllColumnsShowFocus()
- \i Sets whether items should show keyboard focus using all
- columns or just column 0. The default is to show focus
- just using column 0.
- \row \i \l setRootIsDecorated()
- \i Sets whether root items should show open/close decoration to their left.
- The default is FALSE.
- \row \i \l setTreeStepSize()
- \i Sets how many pixels an item's children are indented
- relative to their parent. The default is 20. This is
- mostly a matter of taste.
- \row \i \l setSorting()
- \i Sets whether the items should be sorted, whether it should
- be in ascending or descending order, and by what column
- they should be sorted. By default the list view is sorted
- by the first column; to switch this off call setSorting(-1).
- \endtable
-
- To handle events such as mouse presses on the list view, derived
- classes can reimplement the TQScrollView functions:
- \link TQScrollView::contentsMousePressEvent() contentsMousePressEvent\endlink,
- \link TQScrollView::contentsMouseReleaseEvent() contentsMouseReleaseEvent\endlink,
- \link TQScrollView::contentsMouseDoubleClickEvent() contentsMouseDoubleClickEvent\endlink,
- \link TQScrollView::contentsMouseMoveEvent() contentsMouseMoveEvent\endlink,
- \link TQScrollView::contentsDragEnterEvent() contentsDragEnterEvent\endlink,
- \link TQScrollView::contentsDragMoveEvent() contentsDragMoveEvent\endlink,
- \link TQScrollView::contentsDragLeaveEvent() contentsDragLeaveEvent\endlink,
- \link TQScrollView::contentsDropEvent() contentsDropEvent\endlink, and
- \link TQScrollView::contentsWheelEvent() contentsWheelEvent\endlink.
-
- There are also several functions for mapping between items and
- coordinates. itemAt() returns the item at a position on-screen,
- itemRect() returns the rectangle an item occupies on the screen,
- and itemPos() returns the position of any item (whether it is
- on-screen or not). firstChild() returns the list view's first item
- (not necessarily visible on-screen).
-
- You can iterate over visible items using
- TQListViewItem::itemBelow(); over a list view's top-level items
- using TQListViewItem::firstChild() and
- TQListViewItem::nextSibling(); or every item using a
- TQListViewItemIterator. See
- the TQListViewItem documentation for examples of traversal.
-
- An item can be moved amongst its siblings using
- TQListViewItem::moveItem(). To move an item in the hierarchy use
- takeItem() and insertItem(). Item's (and all their child items)
- are deleted with \c delete; to delete all the list view's items
- use clear().
-
- There are a variety of selection modes described in the
- TQListView::SelectionMode documentation. The default is \c Single
- selection, which you can change using setSelectionMode().
-
- Because TQListView offers multiple selection it must display
- keyboard focus and selection state separately. Therefore there are
- functions both to set the selection state of an item
- (setSelected()) and to set which item displays keyboard focus
- (setCurrentItem()).
-
- TQListView emits two groups of signals; one group signals changes
- in selection/focus state and one indicates selection. The first
- group consists of selectionChanged() (applicable to all list
- views), selectionChanged(TQListViewItem*) (applicable only to a
- \c Single selection list view), and currentChanged(TQListViewItem*).
- The second group consists of doubleClicked(TQListViewItem*),
- returnPressed(TQListViewItem*),
- rightButtonClicked(TQListViewItem*, const TQPoint&, int), etc.
-
- Note that changing the state of the list view in a slot connected
- to a list view signal may cause unexpected side effects. If you
- need to change the list view's state in response to a signal, use
- a \link TQTimer::singleShot() single shot timer\endlink with a
- time out of 0, and connect this timer to a slot that modifies the
- list view's state.
-
- In Motif style, TQListView deviates fairly strongly from the look
- and feel of the Motif hierarchical tree view. This is done mostly
- to provide a usable keyboard interface and to make the list view
- look better with a white background.
-
- If selectionMode() is \c Single (the default) the user can select
- one item at a time, e.g. by clicking an item with the mouse, see
- \l TQListView::SelectionMode for details.
-
- The list view can be navigated either using the mouse or the
- keyboard. Clicking a <b>-</b> icon closes an item (hides its
- children) and clicking a <b>+</b> icon opens an item (shows its
- children). The keyboard controls are these:
- \table
- \header \i Keypress \i Action
- \row \i Home
- \i Make the first item current and visible.
- \row \i End
- \i Make the last item current and visible.
- \row \i Page Up
- \i Make the item above the top visible item current and visible.
- \row \i Page Down
- \i Make the item below the bottom visible item current and visible.
- \row \i Up Arrow
- \i Make the item above the current item current and visible.
- \row \i Down Arrow
- \i Make the item below the current item current and visible.
- \row \i Left Arrow
- \i If the current item is closed (<b>+</b> icon) or has no
- children, make its parent item current and visible. If the
- current item is open (<b>-</b> icon) close it, i.e. hide its
- children. Exception: if the current item is the first item
- and is closed and the horizontal scrollbar is offset to
- the right the list view will be scrolled left.
- \row \i Right Arrow
- \i If the current item is closed (<b>+</b> icon) and has
- children, the item is opened. If the current item is
- opened (<b>-</b> icon) and has children the item's first
- child is made current and visible. If the current item has
- no children the list view is scrolled right.
- \endtable
-
- If the user starts typing letters with the focus in the list view
- an incremental search will occur. For example if the user types
- 'd' the current item will change to the first item that begins
- with the letter 'd'; if they then type 'a', the current item will
- change to the first item that begins with 'da', and so on. If no
- item begins with the letters they type the current item doesn't
- change.
-
- \warning The list view assumes ownership of all list view items
- and will delete them when it does not need them any more.
-
- <img src=qlistview-m.png> <img src=qlistview-w.png>
-
- \sa TQListViewItem TQCheckListItem
-*/
-
-/*!
- \fn void TQListView::itemRenamed( TQListViewItem * item, int col )
-
- \overload
-
- This signal is emitted when \a item has been renamed, e.g. by
- in-place renaming, in column \a col.
-
- \sa TQListViewItem::setRenameEnabled()
-*/
-
-/*!
- \fn void TQListView::itemRenamed( TQListViewItem * item, int col, const TQString &text)
-
- This signal is emitted when \a item has been renamed to \a text,
- e.g. by in in-place renaming, in column \a col.
-
- \sa TQListViewItem::setRenameEnabled()
-*/
-
-/*!
- Constructs a new empty list view called \a name with parent \a
- parent.
-
- Performance is boosted by modifying the widget flags \a f so that
- only part of the TQListViewItem children is redrawn. This may be
- unsuitable for custom TQListViewItem classes, in which case \c
- WStaticContents and \c WNoAutoErase should be cleared.
-
- \sa TQWidget::clearWFlags() TQt::WidgetFlags
-*/
-TQListView::TQListView( TQWidget * parent, const char *name, WFlags f )
- : TQScrollView( parent, name, f | WStaticContents | WNoAutoErase )
-{
- init();
-}
-
-void TQListView::init()
-{
- d = new TQListViewPrivate;
- d->vci = 0;
- d->timer = new TQTimer( this );
- d->levelWidth = 20;
- d->r = 0;
- d->rootIsExpandable = 0;
- d->h = new TQHeader( this, "list view header" );
- d->h->installEventFilter( this );
- d->focusItem = 0;
- d->oldFocusItem = 0;
- d->drawables = 0;
- d->dirtyItems = 0;
- d->dirtyItemTimer = new TQTimer( this );
- d->visibleTimer = new TQTimer( this );
- d->renameTimer = new TQTimer( this );
- d->autoopenTimer = new TQTimer( this );
- d->margin = 1;
- d->selectionMode = TQListView::Single;
- d->sortcolumn = 0;
- d->ascending = TRUE;
- d->allColumnsShowFocus = FALSE;
- d->fontMetricsHeight = fontMetrics().height();
- d->h->setTracking(TRUE);
- d->buttonDown = FALSE;
- d->ignoreDoubleClick = FALSE;
- d->column.setAutoDelete( TRUE );
- d->iterators = 0;
- d->scrollTimer = 0;
- d->sortIndicator = FALSE;
- d->clearing = FALSE;
- d->minLeftBearing = fontMetrics().minLeftBearing();
- d->minRightBearing = fontMetrics().minRightBearing();
- d->ellipsisWidth = fontMetrics().width( "..." ) * 2;
- d->highlighted = 0;
- d->pressedItem = 0;
- d->selectAnchor = 0;
- d->select = TRUE;
- d->useDoubleBuffer = FALSE;
- d->startDragItem = 0;
- d->toolTips = TRUE;
-#ifndef TQT_NO_TOOLTIP
- d->toolTip = new TQListViewToolTip( viewport(), this );
-#endif
- d->updateHeader = FALSE;
- d->fullRepaintOnComlumnChange = FALSE;
- d->resizeMode = NoColumn;
- d->defRenameAction = Reject;
- d->pressedEmptyArea = FALSE;
- d->startEdit = TRUE;
- d->ignoreEditAfterFocus = FALSE;
- d->inMenuMode = FALSE;
- d->pressedSelected = FALSE;
-
- setMouseTracking( TRUE );
- viewport()->setMouseTracking( TRUE );
-
- connect( d->timer, TQ_SIGNAL(timeout()),
- this, TQ_SLOT(updateContents()) );
- connect( d->dirtyItemTimer, TQ_SIGNAL(timeout()),
- this, TQ_SLOT(updateDirtyItems()) );
- connect( d->visibleTimer, TQ_SIGNAL(timeout()),
- this, TQ_SLOT(makeVisible()) );
- connect( d->renameTimer, TQ_SIGNAL(timeout()),
- this, TQ_SLOT(startRename()) );
- connect( d->autoopenTimer, TQ_SIGNAL(timeout()),
- this, TQ_SLOT(openFocusItem()) );
-
- connect( d->h, TQ_SIGNAL(sizeChange(int,int,int)),
- this, TQ_SLOT(handleSizeChange(int,int,int)) );
- connect( d->h, TQ_SIGNAL(indexChange(int,int,int)),
- this, TQ_SLOT(handleIndexChange()) );
- connect( d->h, TQ_SIGNAL(sectionClicked(int)),
- this, TQ_SLOT(changeSortColumn(int)) );
- connect( d->h, TQ_SIGNAL(sectionHandleDoubleClicked(int)),
- this, TQ_SLOT(adjustColumn(int)) );
- connect( horizontalScrollBar(), TQ_SIGNAL(sliderMoved(int)),
- d->h, TQ_SLOT(setOffset(int)) );
- connect( horizontalScrollBar(), TQ_SIGNAL(valueChanged(int)),
- d->h, TQ_SLOT(setOffset(int)) );
-
- // will access d->r
- TQListViewPrivate::Root * r = new TQListViewPrivate::Root( this );
- r->is_root = TRUE;
- d->r = r;
- d->r->setSelectable( FALSE );
-
- viewport()->setFocusProxy( this );
- viewport()->setFocusPolicy( WheelFocus );
- viewport()->setBackgroundMode( PaletteBase );
- setBackgroundMode( PaletteBackground, PaletteBase );
-}
-
-/*!
- \property TQListView::showSortIndicator
- \brief whether the list view header should display a sort indicator.
-
- If this property is TRUE, an arrow is drawn in the header of the
- list view to indicate the sort order of the list view contents.
- The arrow will be drawn in the correct column and will point up or
- down, depending on the current sort direction. The default is
- FALSE (don't show an indicator).
-
- \sa TQHeader::setSortIndicator()
-*/
-
-void TQListView::setShowSortIndicator( bool show )
-{
- if ( show == d->sortIndicator )
- return;
-
- d->sortIndicator = show;
- if ( d->sortcolumn != Unsorted && d->sortIndicator )
- d->h->setSortIndicator( d->sortcolumn, d->ascending );
- else
- d->h->setSortIndicator( -1 );
-}
-
-bool TQListView::showSortIndicator() const
-{
- return d->sortIndicator;
-}
-
-/*!
- \property TQListView::showToolTips
- \brief whether this list view should show tooltips for truncated column texts
-
- The default is TRUE.
-*/
-
-void TQListView::setShowToolTips( bool b )
-{
- d->toolTips = b;
-}
-
-bool TQListView::showToolTips() const
-{
- return d->toolTips;
-}
-
-/*!
- \property TQListView::resizeMode
- \brief whether all, none or the only the last column should be resized
-
- Specifies whether all, none or only the last column should be
- resized to fit the full width of the list view. The values for this
- property can be one of: \c NoColumn (the default), \c AllColumns
- or \c LastColumn.
-
- \warning Setting the resize mode should be done after all necessary
- columns have been added to the list view, otherwise the behavior is
- undefined.
-
- \sa TQHeader, header()
-*/
-
-void TQListView::setResizeMode( ResizeMode m )
-{
- d->resizeMode = m;
- if ( m == NoColumn )
- header()->setStretchEnabled( FALSE );
- else if ( m == AllColumns )
- header()->setStretchEnabled( TRUE );
- else
- header()->setStretchEnabled( TRUE, header()->count() - 1 );
-}
-
-TQListView::ResizeMode TQListView::resizeMode() const
-{
- return d->resizeMode;
-}
-
-/*!
- Destroys the list view, deleting all its items, and frees up all
- allocated resources.
-*/
-
-TQListView::~TQListView()
-{
- if ( d->iterators ) {
- TQListViewItemIterator *i = d->iterators->first();
- while ( i ) {
- i->listView = 0;
- i = d->iterators->next();
- }
- delete d->iterators;
- d->iterators = 0;
- }
-
- d->focusItem = 0;
- delete d->r;
- d->r = 0;
- delete d->dirtyItems;
- d->dirtyItems = 0;
- delete d->drawables;
- d->drawables = 0;
- delete d->vci;
- d->vci = 0;
-#ifndef TQT_NO_TOOLTIP
- delete d->toolTip;
- d->toolTip = 0;
-#endif
- delete d;
- d = 0;
-}
-
-
-/*!
- Calls TQListViewItem::paintCell() and
- TQListViewItem::paintBranches() as necessary for all list view
- items that require repainting in the \a cw pixels wide and \a ch
- pixels high bounding rectangle starting at position \a cx, \a cy
- with offset \a ox, \a oy. Uses the painter \a p.
-*/
-
-void TQListView::drawContentsOffset( TQPainter * p, int ox, int oy,
- int cx, int cy, int cw, int ch )
-{
- if ( columns() == 0 ) {
- paintEmptyArea( p, TQRect( cx, cy, cw, ch ) );
- return;
- }
-
- if ( !d->drawables ||
- d->drawables->isEmpty() ||
- d->topPixel > cy ||
- d->bottomPixel < cy + ch - 1 ||
- d->r->maybeTotalHeight < 0 )
- buildDrawableList();
-
- if ( d->dirtyItems ) {
- TQRect br( cx - ox, cy - oy, cw, ch );
- TQPtrDictIterator<void> it( *(d->dirtyItems) );
- TQListViewItem * i;
- while( (i = (TQListViewItem *)(it.currentKey())) != 0 ) {
- ++it;
- TQRect ir = itemRect( i ).intersect( viewport()->rect() );
- if ( ir.isEmpty() || br.contains( ir ) )
- // we're painting this one, or it needs no painting: forget it
- d->dirtyItems->remove( (void *)i );
- }
- if ( d->dirtyItems->count() ) {
- // there are still items left that need repainting
- d->dirtyItemTimer->start( 0, TRUE );
- } else {
- // we're painting all items that need to be painted
- delete d->dirtyItems;
- d->dirtyItems = 0;
- d->dirtyItemTimer->stop();
- }
- }
-
- p->setFont( font() );
-
- TQPtrListIterator<TQListViewPrivate::DrawableItem> it( *(d->drawables) );
-
- TQRect r;
- int fx = -1, x, fc = 0, lc = 0;
- int tx = -1;
- TQListViewPrivate::DrawableItem * current;
-
- while ( (current = it.current()) != 0 ) {
- ++it;
- if ( !current->i->isVisible() )
- continue;
- int ih = current->i->height();
- int ith = current->i->totalHeight();
- int c;
- int cs;
-
- // need to paint current?
- if ( ih > 0 && current->y < cy+ch && current->y+ih > cy ) {
- if ( fx < 0 ) {
- // find first interesting column, once
- x = 0;
- c = 0;
- cs = d->h->cellSize( 0 );
- while ( x + cs <= cx && c < d->h->count() ) {
- x += cs;
- c++;
- if ( c < d->h->count() )
- cs = d->h->cellSize( c );
- }
- fx = x;
- fc = c;
- while( x < cx + cw && c < d->h->count() ) {
- x += cs;
- c++;
- if ( c < d->h->count() )
- cs = d->h->cellSize( c );
- }
- lc = c;
- }
-
- x = fx;
- c = fc;
- // draw to last interesting column
-
- bool drawActiveSelection = hasFocus() || d->inMenuMode ||
- !style().styleHint( TQStyle::SH_ItemView_ChangeHighlightOnFocus, this ) ||
- ( currentItem() && currentItem()->renameBox && currentItem()->renameBox->hasFocus() );
- const TQColorGroup &cg = ( drawActiveSelection ? colorGroup() : palette().inactive() );
-
- while ( c < lc && d->drawables ) {
- int i = d->h->mapToLogical( c );
- cs = d->h->cellSize( c );
- r.setRect( x - ox, current->y - oy, cs, ih );
- if ( i == 0 && current->i->parentItem )
- r.setLeft( r.left() + current->l * treeStepSize() );
-
- p->save();
- // No need to paint if the cell isn't technically visible
- if ( !( r.width() == 0 || r.height() == 0 ) ) {
- p->translate( r.left(), r.top() );
- int ac = d->h->mapToLogical( c );
- // map to Left currently. This should change once we
- // can really reverse the listview.
- int align = columnAlignment( ac );
- if ( align == AlignAuto ) align = AlignLeft;
- if ( d->useDoubleBuffer ) {
- TQRect a( 0, 0, r.width(), current->i->height() );
- TQSharedDoubleBuffer buffer( p, a, TQSharedDoubleBuffer::Force );
- if ( buffer.isBuffered() )
- paintEmptyArea( buffer.painter(), a );
- buffer.painter()->setFont( p->font() );
- buffer.painter()->setPen( p->pen() );
- buffer.painter()->setBrush( p->brush() );
- buffer.painter()->setBrushOrigin( -r.left(), -r.top() );
- current->i->paintCell( buffer.painter(), cg, ac, r.width(),
- align );
- } else {
- current->i->paintCell( p, cg, ac, r.width(),
- align );
- }
- }
- p->restore();
- x += cs;
- c++;
- }
-
- if ( current->i == d->focusItem && hasFocus() &&
- !d->allColumnsShowFocus ) {
- p->save();
- int cell = d->h->mapToActual( 0 );
- TQRect r( d->h->cellPos( cell ) - ox, current->y - oy, d->h->cellSize( cell ), ih );
- if ( current->i->parentItem )
- r.setLeft( r.left() + current->l * treeStepSize() );
- if ( r.left() < r.right() )
- current->i->paintFocus( p, colorGroup(), r );
- p->restore();
- }
- }
-
- const int cell = d->h->mapToActual( 0 );
-
- // does current need focus indication?
- if ( current->i == d->focusItem && hasFocus() &&
- d->allColumnsShowFocus ) {
- p->save();
- int x = -contentsX();
- int w = header()->cellPos( header()->count() - 1 ) +
- header()->cellSize( header()->count() - 1 );
-
- r.setRect( x, current->y - oy, w, ih );
- if ( d->h->mapToActual( 0 ) == 0 || ( current->l == 0 && !rootIsDecorated() ) ) {
- int offsetx = TQMIN( current->l * treeStepSize(), d->h->cellSize( cell ) );
- r.setLeft( r.left() + offsetx );
- current->i->paintFocus( p, colorGroup(), r );
- } else {
- int xdepth = TQMIN( treeStepSize() * ( current->i->depth() + ( rootIsDecorated() ? 1 : 0) )
- + itemMargin(), d->h->cellSize( cell ) );
- xdepth += d->h->cellPos( cell );
- TQRect r1( r );
- r1.setRight( d->h->cellPos( cell ) - 1 );
- TQRect r2( r );
- r2.setLeft( xdepth - 1 );
- current->i->paintFocus( p, colorGroup(), r1 );
- current->i->paintFocus( p, colorGroup(), r2 );
- }
- p->restore();
- }
-
- if ( tx < 0 )
- tx = d->h->cellPos( cell );
-
- // do any children of current need to be painted?
- if ( ih != ith &&
- (current->i != d->r || d->rootIsExpandable) &&
- current->y + ith > cy &&
- current->y + ih < cy + ch &&
- tx + current->l * treeStepSize() < cx + cw &&
- tx + (current->l+1) * treeStepSize() > cx ) {
- // compute the clip rectangle the safe way
-
- int rtop = current->y + ih;
- int rbottom = current->y + ith;
- int rleft = tx + current->l*treeStepSize();
- int rright = rleft + treeStepSize();
-
- int crtop = TQMAX( rtop, cy );
- int crbottom = TQMIN( rbottom, cy+ch );
- int crleft = TQMAX( rleft, cx );
- int crright = TQMIN( rright, cx+cw );
-
- r.setRect( crleft-ox, crtop-oy,
- crright-crleft, crbottom-crtop );
-
- if ( r.isValid() ) {
- p->save();
- p->translate( rleft-ox, crtop-oy );
- current->i->paintBranches( p, colorGroup(), treeStepSize(),
- rtop - crtop, r.height() );
- p->restore();
- }
- }
- }
-
- if ( d->r->totalHeight() < cy + ch )
- paintEmptyArea( p, TQRect( cx - ox, d->r->totalHeight() - oy,
- cw, cy + ch - d->r->totalHeight() ) );
-
- int c = d->h->count()-1;
- if ( c >= 0 &&
- d->h->cellPos( c ) + d->h->cellSize( c ) < cx + cw ) {
- c = d->h->cellPos( c ) + d->h->cellSize( c );
- paintEmptyArea( p, TQRect( c - ox, cy - oy, cx + cw - c, ch ) );
- }
-}
-
-
-
-/*!
- Paints \a rect so that it looks like empty background using
- painter \a p. \a rect is in widget coordinates, ready to be fed to
- \a p.
-
- The default function fills \a rect with the
- viewport()->backgroundBrush().
-*/
-
-void TQListView::paintEmptyArea( TQPainter * p, const TQRect & rect )
-{
- TQStyleOption opt( d->sortcolumn, 0 ); // ### hack; in 3.1, add a property in TQListView and TQHeader
- TQStyle::SFlags how = TQStyle::Style_Default;
- if ( isEnabled() )
- how |= TQStyle::Style_Enabled;
-
- style().drawComplexControl( TQStyle::CC_ListView,
- p, this, rect, colorGroup(),
- how, TQStyle::SC_ListView, TQStyle::SC_None,
- opt );
-}
-
-
-/*
- Rebuilds the list of drawable TQListViewItems. This function is
- const so that const functions can call it without requiring
- d->drawables to be mutable.
-*/
-
-void TQListView::buildDrawableList() const
-{
- d->r->enforceSortOrder();
-
- TQPtrStack<TQListViewPrivate::Pending> stack;
- stack.push( new TQListViewPrivate::Pending( ((int)d->rootIsExpandable)-1,
- 0, d->r ) );
-
- // could mess with cy and ch in order to speed up vertical
- // scrolling
- int cy = contentsY();
- int ch = ((TQListView *)this)->visibleHeight();
- d->topPixel = cy + ch; // one below bottom
- d->bottomPixel = cy - 1; // one above top
-
- TQListViewPrivate::Pending * cur;
-
- // used to work around lack of support for mutable
- TQPtrList<TQListViewPrivate::DrawableItem> * dl;
-
- dl = new TQPtrList<TQListViewPrivate::DrawableItem>;
- dl->setAutoDelete( TRUE );
- if ( d->drawables )
- delete ((TQListView *)this)->d->drawables;
- ((TQListView *)this)->d->drawables = dl;
-
- while ( !stack.isEmpty() ) {
- cur = stack.pop();
-
- int ih = cur->i->height();
- int ith = cur->i->totalHeight();
-
- // if this is not true, buildDrawableList has been called recursivly
- Q_ASSERT( dl == d->drawables );
-
- // is this item, or its branch symbol, inside the viewport?
- if ( cur->y + ith >= cy && cur->y < cy + ch ) {
- dl->append( new TQListViewPrivate::DrawableItem(cur));
- // perhaps adjust topPixel up to this item? may be adjusted
- // down again if any children are not to be painted
- if ( cur->y < d->topPixel )
- d->topPixel = cur->y;
- // bottompixel is easy: the bottom item drawn contains it
- d->bottomPixel = cur->y + ih - 1;
- }
-
- // push younger sibling of cur on the stack?
- if ( cur->y + ith < cy+ch && cur->i->siblingItem )
- stack.push( new TQListViewPrivate::Pending(cur->l,
- cur->y + ith,
- cur->i->siblingItem));
-
- // do any children of cur need to be painted?
- if ( cur->i->isOpen() && cur->i->childCount() &&
- cur->y + ith > cy &&
- cur->y + ih < cy + ch ) {
- cur->i->enforceSortOrder();
-
- TQListViewItem * c = cur->i->childItem;
- int y = cur->y + ih;
-
- // if any of the children are not to be painted, skip them
- // and invalidate topPixel
- while ( c && y + c->totalHeight() <= cy ) {
- y += c->totalHeight();
- c = c->siblingItem;
- d->topPixel = cy + ch;
- }
-
- // push one child on the stack, if there is at least one
- // needing to be painted
- if ( c && y < cy+ch )
- stack.push( new TQListViewPrivate::Pending( cur->l + 1,
- y, c ) );
- }
-
- delete cur;
- }
-}
-
-/*!
- \property TQListView::treeStepSize
- \brief the number of pixels a child is offset from its parent
-
- The default is 20 pixels.
-
- Of course, this property is only meaningful for hierarchical list
- views.
-*/
-
-int TQListView::treeStepSize() const
-{
- return d->levelWidth;
-}
-
-void TQListView::setTreeStepSize( int size )
-{
- if ( size != d->levelWidth ) {
- d->levelWidth = size;
- viewport()->repaint( FALSE );
- }
-}
-
-/*!
- Inserts item \a i into the list view as a top-level item. You do
- not need to call this unless you've called takeItem(\a i) or
- TQListViewItem::takeItem(\a i) and need to reinsert \a i elsewhere.
-
- \sa TQListViewItem::takeItem() takeItem()
-*/
-
-void TQListView::insertItem( TQListViewItem * i )
-{
- if ( d->r ) // not for d->r itself
- d->r->insertItem( i );
-}
-
-
-/*!
- Removes and deletes all the items in this list view and triggers
- an update.
-
- Note that the currentChanged() signal is not emitted when this slot is invoked.
- \sa triggerUpdate()
-*/
-
-void TQListView::clear()
-{
- bool wasUpdatesEnabled = viewport()->isUpdatesEnabled();
- viewport()->setUpdatesEnabled( FALSE );
- setContentsPos( 0, 0 );
- viewport()->setUpdatesEnabled( wasUpdatesEnabled );
- bool block = signalsBlocked();
- blockSignals( TRUE );
- d->clearing = TRUE;
- clearSelection();
- if ( d->iterators ) {
- TQListViewItemIterator *i = d->iterators->first();
- while ( i ) {
- i->curr = 0;
- i = d->iterators->next();
- }
- }
-
- if ( d->drawables )
- d->drawables->clear();
- delete d->dirtyItems;
- d->dirtyItems = 0;
- d->dirtyItemTimer->stop();
-
- d->focusItem = 0;
- d->selectAnchor = 0;
- d->pressedItem = 0;
- d->highlighted = 0;
- d->startDragItem = 0;
-
- // if it's down its downness makes no sense, so undown it
- d->buttonDown = FALSE;
-
- TQListViewItem *c = (TQListViewItem *)d->r->firstChild();
- TQListViewItem *n;
- while( c ) {
- n = (TQListViewItem *)c->nextSibling();
- delete c;
- c = n;
- }
- resizeContents( d->h->sizeHint().width(), contentsHeight() );
- delete d->r;
- d->r = 0;
- TQListViewPrivate::Root * r = new TQListViewPrivate::Root( this );
- r->is_root = TRUE;
- d->r = r;
- d->r->setSelectable( FALSE );
- blockSignals( block );
- triggerUpdate();
- d->clearing = FALSE;
-}
-
-/*!
- \reimp
-*/
-
-void TQListView::setContentsPos( int x, int y )
-{
- updateGeometries();
- TQScrollView::setContentsPos( x, y );
-}
-
-/*!
- Adds a \a width pixels wide column with the column header \a label
- to the list view, and returns the index of the new column.
-
- All columns apart from the first one are inserted to the right of
- the existing ones.
-
- If \a width is negative, the new column's \l WidthMode is set to
- \c Maximum instead of \c Manual.
-
- \sa setColumnText() setColumnWidth() setColumnWidthMode()
-*/
-int TQListView::addColumn( const TQString &label, int width )
-{
- int c = d->h->addLabel( label, width );
- d->column.resize( c+1 );
- d->column.insert( c, new TQListViewPrivate::Column );
- d->column[c]->wmode = width >=0 ? Manual : Maximum;
- updateGeometries();
- updateGeometry();
- return c;
-}
-
-/*!
- \overload
-
- Adds a \a width pixels wide new column with the header \a label
- and the \a iconset to the list view, and returns the index of the
- column.
-
- If \a width is negative, the new column's \l WidthMode is set to
- \c Maximum, and to \c Manual otherwise.
-
- \sa setColumnText() setColumnWidth() setColumnWidthMode()
-*/
-int TQListView::addColumn( const TQIconSet& iconset, const TQString &label, int width )
-{
- int c = d->h->addLabel( iconset, label, width );
- d->column.resize( c+1 );
- d->column.insert( c, new TQListViewPrivate::Column );
- d->column[c]->wmode = width >=0 ? Manual : Maximum;
- updateGeometries();
- updateGeometry();
- return c;
-}
-
-/*!
- \property TQListView::columns
- \brief the number of columns in this list view
-
- \sa addColumn(), removeColumn()
-*/
-
-int TQListView::columns() const
-{
- return d->column.count();
-}
-
-/*!
- Removes the column at position \a index.
-
- If no columns remain after the column is removed, the
- list view will be cleared.
-
- \sa clear()
-*/
-
-void TQListView::removeColumn( int index )
-{
- if ( index < 0 || index > (int)d->column.count() - 1 )
- return;
-
- if ( d->vci ) {
- TQListViewPrivate::ViewColumnInfo *vi = d->vci, *prev = 0, *next = 0;
- for ( int i = 0; i < index; ++i ) {
- if ( vi ) {
- prev = vi;
- vi = vi->next;
- }
- }
- if ( vi ) {
- next = vi->next;
- if ( prev )
- prev->next = next;
- vi->next = 0;
- delete vi;
- if ( index == 0 )
- d->vci = next;
- }
- }
-
- TQListViewItemIterator it( this );
- for ( ; it.current(); ++it ) {
- TQListViewPrivate::ItemColumnInfo *ci = (TQListViewPrivate::ItemColumnInfo*)it.current()->columns;
- if ( ci ) {
- TQListViewPrivate::ItemColumnInfo *prev = 0, *next = 0;
- for ( int i = 0; i < index; ++i ) {
- if ( ci ) {
- prev = ci;
- ci = ci->next;
- }
- }
- if ( ci ) {
- next = ci->next;
- if ( prev )
- prev->next = next;
- ci->next = 0;
- delete ci;
- if ( index == 0 )
- it.current()->columns = next;
- }
- }
- }
-
- for ( int i = index; i < (int)d->column.size(); ++i ) {
- TQListViewPrivate::Column *c = d->column.take( i );
- if ( i == index )
- delete c;
- if ( i < (int)d->column.size()-1 )
- d->column.insert( i, d->column[ i + 1 ] );
- }
- d->column.resize( d->column.size() - 1 );
-
- d->h->removeLabel( index );
- if (d->resizeMode == LastColumn)
- d->h->setStretchEnabled( TRUE, d->h->count() - 1 );
-
- updateGeometries();
- if ( d->column.count() == 0 )
- clear();
- updateGeometry();
- viewport()->update();
-}
-
-/*!
- Sets the heading of column \a column to \a label.
-
- \sa columnText()
-*/
-void TQListView::setColumnText( int column, const TQString &label )
-{
- if ( column < d->h->count() ) {
- d->h->setLabel( column, label );
- updateGeometries();
- updateGeometry();
- }
-}
-
-/*!
- \overload
-
- Sets the heading of column \a column to \a iconset and \a label.
-
- \sa columnText()
-*/
-void TQListView::setColumnText( int column, const TQIconSet& iconset, const TQString &label )
-{
- if ( column < d->h->count() ) {
- d->h->setLabel( column, iconset, label );
- updateGeometries();
- }
-}
-
-/*!
- Sets the width of column \a column to \a w pixels. Note that if
- the column has a \c WidthMode other than \c Manual, this width
- setting may be subsequently overridden.
-
- \sa columnWidth()
-*/
-void TQListView::setColumnWidth( int column, int w )
-{
- int oldw = d->h->sectionSize( column );
- if ( column < d->h->count() && oldw != w ) {
- d->h->resizeSection( column, w );
- disconnect( d->h, TQ_SIGNAL(sizeChange(int,int,int)),
- this, TQ_SLOT(handleSizeChange(int,int,int)) );
- emit d->h->sizeChange( column, oldw, w);
- connect( d->h, TQ_SIGNAL(sizeChange(int,int,int)),
- this, TQ_SLOT(handleSizeChange(int,int,int)) );
- updateGeometries();
- viewport()->update();
- }
-}
-
-
-/*!
- Returns the text of column \a c.
-
- \sa setColumnText()
-*/
-
-TQString TQListView::columnText( int c ) const
-{
- return d->h->label(c);
-}
-
-/*!
- Returns the width of column \a c.
-
- \sa setColumnWidth()
-*/
-
-int TQListView::columnWidth( int c ) const
-{
- int actual = d->h->mapToActual( c );
- return d->h->cellSize( actual );
-}
-
-
-/*!
- \enum TQListView::WidthMode
-
- This enum type describes how the width of a column in the view
- changes.
-
- \value Manual the column width does not change automatically.
-
- \value Maximum the column is automatically sized according to the
- widths of all items in the column. (Note: The column never shrinks
- in this case.) This means that the column is always resized to the
- width of the item with the largest width in the column.
-
- \sa setColumnWidth() setColumnWidthMode() columnWidth()
-*/
-
-
-/*!
- Sets column \a{c}'s width mode to \a mode. The default depends on
- the original width argument to addColumn().
-
- \sa TQListViewItem::width()
-*/
-
-void TQListView::setColumnWidthMode( int c, WidthMode mode )
-{
- if ( c < d->h->count() )
- d->column[c]->wmode = mode;
-}
-
-
-/*!
- Returns the \c WidthMode for column \a c.
-
- \sa setColumnWidthMode()
-*/
-
-TQListView::WidthMode TQListView::columnWidthMode( int c ) const
-{
- if ( c < d->h->count() )
- return d->column[c]->wmode;
- else
- return Manual;
-}
-
-
-/*!
- Sets column \a{column}'s alignment to \a align. The alignment is
- ultimately passed to TQListViewItem::paintCell() for each item in
- the list view. For horizontally aligned text with TQt::AlignLeft or
- TQt::AlignHCenter the ellipsis (...) will be to the right, for
- TQt::AlignRight the ellipsis will be to the left.
-
- \sa TQt::AlignmentFlags
-*/
-
-void TQListView::setColumnAlignment( int column, int align )
-{
- if ( column < 0 )
- return;
- if ( !d->vci )
- d->vci = new TQListViewPrivate::ViewColumnInfo;
- TQListViewPrivate::ViewColumnInfo * l = d->vci;
- while( column ) {
- if ( !l->next )
- l->next = new TQListViewPrivate::ViewColumnInfo;
- l = l->next;
- column--;
- }
- if ( l->align == align )
- return;
- l->align = align;
- triggerUpdate();
-}
-
-
-/*!
- Returns the alignment of column \a column. The default is \c
- AlignAuto.
-
- \sa TQt::AlignmentFlags
-*/
-
-int TQListView::columnAlignment( int column ) const
-{
- if ( column < 0 || !d->vci )
- return AlignAuto;
- TQListViewPrivate::ViewColumnInfo * l = d->vci;
- while( column ) {
- if ( !l->next )
- l->next = new TQListViewPrivate::ViewColumnInfo;
- l = l->next;
- column--;
- }
- return l ? l->align : AlignAuto;
-}
-
-
-
-/*!
- \reimp
- */
-void TQListView::show()
-{
- // Reimplemented to setx the correct background mode and viewed
- // area size.
- if ( !isVisible() ) {
- reconfigureItems();
- updateGeometries();
- }
- TQScrollView::show();
-}
-
-
-/*!
- Updates the sizes of the viewport, header, scroll bars and so on.
-
- \warning Don't call this directly; call triggerUpdate() instead.
-*/
-
-void TQListView::updateContents()
-{
- if ( d->updateHeader )
- header()->adjustHeaderSize();
- d->updateHeader = FALSE;
- if ( !isVisible() ) {
- // Not in response to a setText/setPixmap any more.
- d->useDoubleBuffer = FALSE;
-
- return;
- }
- if ( d->drawables ) {
- delete d->drawables;
- d->drawables = 0;
- }
- viewport()->setUpdatesEnabled( FALSE );
- updateGeometries();
- viewport()->setUpdatesEnabled( TRUE );
- viewport()->repaint( FALSE );
- d->useDoubleBuffer = FALSE;
-}
-
-
-void TQListView::updateGeometries()
-{
- int th = d->r->totalHeight();
- int tw = d->h->headerWidth();
- if ( d->h->offset() &&
- tw < d->h->offset() + d->h->width() )
- horizontalScrollBar()->setValue( tw - TQListView::d->h->width() );
-#if 0
- if ( TQApplication::reverseLayout() && d->h->offset() != horizontalScrollBar()->value() )
- horizontalScrollBar()->setValue( d->h->offset() );
-#endif
- verticalScrollBar()->raise();
- resizeContents( tw, th );
- if ( d->h->isHidden() ) {
- setMargins( 0, 0, 0, 0 );
- } else {
- TQSize hs( d->h->sizeHint() );
- setMargins( 0, hs.height(), 0, 0 );
- d->h->setGeometry( viewport()->x(), viewport()->y()-hs.height(),
- visibleWidth(), hs.height() );
- }
-}
-
-
-/*!
- Updates the display when the section \a section has changed size
- from the old size, \a os, to the new size, \a ns.
-*/
-
-void TQListView::handleSizeChange( int section, int os, int ns )
-{
- bool upe = viewport()->isUpdatesEnabled();
- viewport()->setUpdatesEnabled( FALSE );
- int sx = horizontalScrollBar()->value();
- bool sv = horizontalScrollBar()->isVisible();
- updateGeometries();
- bool fullRepaint = d->fullRepaintOnComlumnChange || sx != horizontalScrollBar()->value()
- || sv != horizontalScrollBar()->isVisible();
- d->fullRepaintOnComlumnChange = FALSE;
- viewport()->setUpdatesEnabled( upe );
-
- if ( fullRepaint ) {
- viewport()->repaint( FALSE );
- return;
- }
-
- int actual = d->h->mapToActual( section );
- int dx = ns - os;
- int left = d->h->cellPos( actual ) - contentsX() + d->h->cellSize( actual );
- if ( dx > 0 )
- left -= dx;
- if ( left < visibleWidth() )
- viewport()->scroll( dx, 0, TQRect( left, 0, visibleWidth() - left, visibleHeight() ) );
- viewport()->repaint( left - 4 - d->ellipsisWidth, 0, 4 + d->ellipsisWidth,
- visibleHeight(), FALSE ); // border between the items and ellipses width
-
- // map auto to left for now. Need to fix this once we support
- // reverse layout on the listview.
- int align = columnAlignment( section );
- if ( align == AlignAuto ) align = AlignLeft;
- if ( align != AlignAuto && align != AlignLeft )
- viewport()->repaint( d->h->cellPos( actual ) - contentsX(), 0,
- d->h->cellSize( actual ), visibleHeight() );
-
- if ( currentItem() && currentItem()->renameBox ) {
- TQRect r = itemRect( currentItem() );
- r = TQRect( viewportToContents( r.topLeft() ), r.size() );
- r.setLeft( header()->sectionPos( currentItem()->renameCol ) );
- r.setWidth( header()->sectionSize( currentItem()->renameCol ) - 1 );
- if ( currentItem()->renameCol == 0 )
- r.setLeft( r.left() + itemMargin() + ( currentItem()->depth() +
- ( rootIsDecorated() ? 1 : 0 ) ) * treeStepSize() - 1 );
- if ( currentItem()->pixmap( currentItem()->renameCol ) )
- r.setLeft( r.left() + currentItem()->pixmap( currentItem()->renameCol )->width() );
- if ( r.x() - contentsX() < 0 )
- r.setX( contentsX() );
- if ( r.width() > visibleWidth() )
- r.setWidth( visibleWidth() );
- addChild( currentItem()->renameBox, r.x(), r.y() );
- currentItem()->renameBox->resize( r.size() );
- }
-}
-
-
-/*
- Very smart internal slot that repaints \e only the items that need
- to be repainted. Don't use this directly; call repaintItem()
- instead.
-*/
-
-void TQListView::updateDirtyItems()
-{
- if ( d->timer->isActive() || !d->dirtyItems )
- return;
- TQRect ir;
- TQPtrDictIterator<void> it( *(d->dirtyItems) );
- TQListViewItem * i;
- while( (i = (TQListViewItem *)(it.currentKey())) != 0 ) {
- ++it;
- ir = ir.unite( itemRect(i) );
- }
- if ( !ir.isEmpty() ) { // rectangle to be repainted
- if ( ir.x() < 0 )
- ir.moveBy( -ir.x(), 0 );
- viewport()->repaint( ir, FALSE );
- }
-}
-
-
-void TQListView::makeVisible()
-{
- if ( d->focusItem )
- ensureItemVisible( d->focusItem );
-}
-
-
-/*!
- Ensures that the header is correctly sized and positioned when the
- resize event \a e occurs.
-*/
-
-void TQListView::resizeEvent( TQResizeEvent *e )
-{
- TQScrollView::resizeEvent( e );
- d->fullRepaintOnComlumnChange = TRUE;
- d->h->resize( visibleWidth(), d->h->height() );
-}
-
-/*! \reimp */
-
-void TQListView::viewportResizeEvent( TQResizeEvent *e )
-{
- TQScrollView::viewportResizeEvent( e );
- d->h->resize( visibleWidth(), d->h->height() );
- if ( resizeMode() != NoColumn && currentItem() && currentItem()->renameBox ) {
- TQRect r = itemRect( currentItem() );
- r = TQRect( viewportToContents( r.topLeft() ), r.size() );
- r.setLeft( header()->sectionPos( currentItem()->renameCol ) );
- r.setWidth( header()->sectionSize( currentItem()->renameCol ) - 1 );
- if ( currentItem()->renameCol == 0 )
- r.setLeft( r.left() + itemMargin() + ( currentItem()->depth() +
- ( rootIsDecorated() ? 1 : 0 ) ) * treeStepSize() - 1 );
- if ( currentItem()->pixmap( currentItem()->renameCol ) )
- r.setLeft( r.left() + currentItem()->pixmap( currentItem()->renameCol )->width() );
- if ( r.x() - contentsX() < 0 )
- r.setX( contentsX() );
- if ( r.width() > visibleWidth() )
- r.setWidth( visibleWidth() );
- addChild( currentItem()->renameBox, r.x(), r.y() );
- currentItem()->renameBox->resize( r.size() );
- }
-}
-
-/*!
- Triggers a size, geometry and content update during the next
- iteration of the event loop. Ensures that there'll be just one
- update to avoid flicker.
-*/
-
-void TQListView::triggerUpdate()
-{
- if ( !isVisible() || !isUpdatesEnabled() ) {
- // Not in response to a setText/setPixmap any more.
- d->useDoubleBuffer = FALSE;
-
- return; // it will update when shown, or something.
- }
-
- d->timer->start( 0, TRUE );
-}
-
-
-/*!
- Redirects the event \a e relating to object \a o, for the viewport
- to mousePressEvent(), keyPressEvent() and friends.
-*/
-
-bool TQListView::eventFilter( TQObject * o, TQEvent * e )
-{
- if ( o == d->h &&
- e->type() >= TQEvent::MouseButtonPress &&
- e->type() <= TQEvent::MouseMove ) {
- TQMouseEvent * me = (TQMouseEvent *)e;
- TQMouseEvent me2( me->type(),
- TQPoint( me->pos().x(),
- me->pos().y() - d->h->height() ),
- me->button(), me->state() );
- switch( me2.type() ) {
- case TQEvent::MouseButtonDblClick:
- if ( me2.button() == RightButton )
- return TRUE;
- break;
- case TQEvent::MouseMove:
- if ( me2.state() & RightButton ) {
- viewportMouseMoveEvent( &me2 );
- return TRUE;
- }
- break;
- default:
- break;
- }
- } else if ( o == viewport() ) {
- TQFocusEvent * fe = (TQFocusEvent *)e;
-
- switch( e->type() ) {
- case TQEvent::FocusIn:
- focusInEvent( fe );
- return TRUE;
- case TQEvent::FocusOut:
- focusOutEvent( fe );
- return TRUE;
- default:
- // nothing
- break;
- }
- } else if ( ::tqt_cast<TQLineEdit*>(o) ) {
- if ( currentItem() && currentItem()->renameBox ) {
- if ( e->type() == TQEvent::KeyPress ) {
- TQKeyEvent *ke = (TQKeyEvent*)e;
- if ( ke->key() == Key_Return ||
- ke->key() == Key_Enter ) {
- currentItem()->okRename( currentItem()->renameCol );
- return TRUE;
- } else if ( ke->key() == Key_Escape ) {
- currentItem()->cancelRename( currentItem()->renameCol );
- return TRUE;
- }
- } else if ( e->type() == TQEvent::FocusOut ) {
- if ( ( (TQFocusEvent*)e )->reason() != TQFocusEvent::Popup ) {
- TQCustomEvent *e = new TQCustomEvent( 9999 );
- TQApplication::postEvent( o, e );
- return TRUE;
- }
- } else if ( e->type() == 9999 ) {
- if ( d->defRenameAction == Reject )
- currentItem()->cancelRename( currentItem()->renameCol );
- else
- currentItem()->okRename( currentItem()->renameCol );
- return TRUE;
- }
- }
- }
-
- return TQScrollView::eventFilter( o, e );
-}
-
-
-/*!
- Returns a pointer to the list view containing this item.
-
- Note that this function traverses the items to the root to find the
- listview. This function will return 0 for taken items - see
- TQListViewItem::takeItem()
-*/
-
-TQListView * TQListViewItem::listView() const
-{
- const TQListViewItem* c = this;
- while ( c && !c->is_root )
- c = c->parentItem;
- if ( !c )
- return 0;
- return ((TQListViewPrivate::Root*)c)->theListView();
-}
-
-
-/*!
- Returns the depth of this item.
-*/
-int TQListViewItem::depth() const
-{
- return parentItem ? parentItem->depth()+1 : -1; // -1 == the hidden root
-}
-
-
-/*!
- Returns a pointer to the item immediately above this item on the
- screen. This is usually the item's closest older sibling, but it
- may also be its parent or its next older sibling's youngest child,
- or something else if anyoftheabove->height() returns 0. Returns 0
- if there is no item immediately above this item.
-
- This function assumes that all parents of this item are open (i.e.
- that this item is visible, or can be made visible by scrolling).
-
- This function might be relatively slow because of the tree
- traversions needed to find the correct item.
-
- \sa itemBelow() TQListView::itemRect()
-*/
-
-TQListViewItem * TQListViewItem::itemAbove()
-{
- if ( !parentItem )
- return 0;
-
- TQListViewItem * c = parentItem;
- if ( c->childItem != this ) {
- c = c->childItem;
- while( c && c->siblingItem != this )
- c = c->siblingItem;
- if ( !c )
- return 0;
- while( c->isOpen() && c->childItem ) {
- c = c->childItem;
- while( c->siblingItem )
- c = c->siblingItem; // assign c's sibling to c
- }
- }
- if ( c && ( !c->height() || !c->isEnabled() ) )
- return c->itemAbove();
- return c;
-}
-
-
-/*!
- Returns a pointer to the item immediately below this item on the
- screen. This is usually the item's eldest child, but it may also
- be its next younger sibling, its parent's next younger sibling,
- grandparent's, etc., or something else if anyoftheabove->height()
- returns 0. Returns 0 if there is no item immediately below this
- item.
-
- This function assumes that all parents of this item are open (i.e.
- that this item is visible or can be made visible by scrolling).
-
- \sa itemAbove() TQListView::itemRect()
-*/
-
-TQListViewItem * TQListViewItem::itemBelow()
-{
- TQListViewItem * c = 0;
- if ( isOpen() && childItem ) {
- c = childItem;
- } else if ( siblingItem ) {
- c = siblingItem;
- } else if ( parentItem ) {
- c = this;
- do {
- c = c->parentItem;
- } while( c->parentItem && !c->siblingItem );
- if ( c )
- c = c->siblingItem;
- }
- if ( c && ( !c->height() || !c->isEnabled() ) )
- return c->itemBelow();
- return c;
-}
-
-
-/*!
- \fn bool TQListViewItem::isOpen () const
-
- Returns TRUE if this list view item has children \e and they are
- not explicitly hidden; otherwise returns FALSE.
-
- \sa setOpen()
-*/
-
-/*!
- Returns the first (top) child of this item, or 0 if this item has
- no children.
-
- Note that the children are not guaranteed to be sorted properly.
- TQListView and TQListViewItem try to postpone or avoid sorting to
- the greatest degree possible, in order to keep the user interface
- snappy.
-
- \sa nextSibling() sortChildItems()
-*/
-
-TQListViewItem* TQListViewItem::firstChild() const
-{
- enforceSortOrder();
- return childItem;
-}
-
-
-/*!
- Returns the parent of this item, or 0 if this item has no parent.
-
- \sa firstChild(), nextSibling()
-*/
-
-TQListViewItem* TQListViewItem::parent() const
-{
- if ( !parentItem || parentItem->is_root ) return 0;
- return parentItem;
-}
-
-
-/*!
- \fn TQListViewItem* TQListViewItem::nextSibling() const
-
- Returns the sibling item below this item, or 0 if there is no
- sibling item after this item.
-
- Note that the siblings are not guaranteed to be sorted properly.
- TQListView and TQListViewItem try to postpone or avoid sorting to
- the greatest degree possible, in order to keep the user interface
- snappy.
-
- \sa firstChild() sortChildItems()
-*/
-
-/*!
- \fn int TQListViewItem::childCount () const
-
- Returns how many children this item has. The count only includes
- the item's immediate children.
-*/
-
-
-/*!
- Returns the height of this item in pixels. This does not include
- the height of any children; totalHeight() returns that.
-*/
-int TQListViewItem::height() const
-{
- TQListViewItem * that = (TQListViewItem *)this;
- if ( !that->configured ) {
- that->configured = TRUE;
- that->setup(); // ### virtual non-const function called in const
- }
-
- return visible ? ownHeight : 0;
-}
-
-/*!
- Call this function when the value of width() may have changed for
- column \a c. Normally, you should call this if text(c) changes.
- Passing -1 for \a c indicates that all columns may have changed.
- It is more efficient to pass -1 if two or more columns have
- changed than to call widthChanged() separately for each one.
-
- \sa width()
-*/
-void TQListViewItem::widthChanged( int c ) const
-{
- TQListView *lv = listView();
- if ( lv )
- lv->widthChanged( this, c );
-}
-
-/*!
- \fn void TQListView::dropped ( TQDropEvent * e )
-
- This signal is emitted, when a drop event occurred on the
- viewport (not onto an item).
-
- \a e provides all the information about the drop.
-*/
-
-/*!
- \fn void TQListView::selectionChanged()
-
- This signal is emitted whenever the set of selected items has
- changed (normally before the screen update). It is available in
- \c Single, \c Multi, and \c Extended selection modes, but is most
- useful in \c Multi selection mode.
-
- \warning Do not delete any TQListViewItem objects in slots
- connected to this signal.
-
- \sa setSelected() TQListViewItem::setSelected()
-*/
-
-
-/*!
- \fn void TQListView::pressed( TQListViewItem *item )
-
- This signal is emitted whenever the user presses the mouse button
- in a list view. \a item is the list view item on which the user
- pressed the mouse button, or 0 if the user didn't press the mouse
- on an item.
-
- \warning Do not delete any TQListViewItem objects in slots
- connected to this signal.
-*/
-
-/*!
- \fn void TQListView::pressed( TQListViewItem *item, const TQPoint &pnt, int c )
-
- \overload
-
- This signal is emitted whenever the user presses the mouse button
- in a list view. \a item is the list view item on which the user
- pressed the mouse button, or 0 if the user didn't press the mouse
- on an item. \a pnt is the position of the mouse cursor in global
- coordinates, and \a c is the column where the mouse cursor was
- when the user pressed the mouse button.
-
- \warning Do not delete any TQListViewItem objects in slots
- connected to this signal.
-*/
-
-/*!
- \fn void TQListView::clicked( TQListViewItem *item )
-
- This signal is emitted whenever the user clicks (mouse pressed \e
- and mouse released) in the list view. \a item is the clicked list
- view item, or 0 if the user didn't click on an item.
-
- \warning Do not delete any TQListViewItem objects in slots
- connected to this signal.
-*/
-
-/*!
- \fn void TQListView::mouseButtonClicked(int button, TQListViewItem * item, const TQPoint & pos, int c)
-
- This signal is emitted whenever the user clicks (mouse pressed \e
- and mouse released) in the list view at position \a pos. \a button
- is the mouse button that the user pressed, \a item is the clicked
- list view item or 0 if the user didn't click on an item. If \a
- item is not 0, \a c is the list view column into which the user
- pressed; if \a item is 0 \a{c}'s value is undefined.
-
- \warning Do not delete any TQListViewItem objects in slots
- connected to this signal.
-*/
-
-/*!
- \fn void TQListView::mouseButtonPressed(int button, TQListViewItem * item, const TQPoint & pos, int c)
-
- This signal is emitted whenever the user pressed the mouse button
- in the list view at position \a pos. \a button is the mouse button
- which the user pressed, \a item is the pressed list view item or 0
- if the user didn't press on an item. If \a item is not 0, \a c is
- the list view column into which the user pressed; if \a item is 0
- \a{c}'s value is undefined.
-
- \warning Do not delete any TQListViewItem objects in slots
- connected to this signal.
-*/
-
-/*!
- \fn void TQListView::clicked( TQListViewItem *item, const TQPoint &pnt, int c )
-
- \overload
-
- This signal is emitted whenever the user clicks (mouse pressed \e
- and mouse released) in the list view. \a item is the clicked list
- view item, or 0 if the user didn't click on an item. \a pnt is the
- position where the user has clicked in global coordinates. If \a
- item is not 0, \a c is the list view column into which the user
- pressed; if \a item is 0 \a{c}'s value is undefined.
-
- \warning Do not delete any TQListViewItem objects in slots
- connected to this signal.
-*/
-
-/*!
- \fn void TQListView::selectionChanged( TQListViewItem * )
-
- \overload
-
- This signal is emitted whenever the selected item has changed in
- \c Single selection mode (normally after the screen update). The
- argument is the newly selected item. If the selection is cleared
- (when, for example, the user clicks in the unused area of the list
- view) then this signal will not be emitted.
-
- In \c Multi selection mode, use the no argument overload of this
- signal.
-
- \warning Do not delete any TQListViewItem objects in slots
- connected to this signal.
-
- \sa setSelected() TQListViewItem::setSelected() currentChanged()
-*/
-
-
-/*!
- \fn void TQListView::currentChanged( TQListViewItem * )
-
- This signal is emitted whenever the current item has changed
- (normally after the screen update). The current item is the item
- responsible for indicating keyboard focus.
-
- The argument is the newly current item, or 0 if the change made no
- item current. This can happen, for example, if all items in the
- list view are deleted.
-
- \warning Do not delete any TQListViewItem objects in slots
- connected to this signal.
-
- \sa setCurrentItem() currentItem()
-*/
-
-
-/*!
- \fn void TQListView::expanded( TQListViewItem *item )
-
- This signal is emitted when \a item has been expanded, i.e. when
- the children of \a item are shown.
-
- \sa setOpen() collapsed()
-*/
-
-/*!
- \fn void TQListView::collapsed( TQListViewItem *item )
-
- This signal is emitted when the \a item has been collapsed, i.e.
- when the children of \a item are hidden.
-
- \sa setOpen() expanded()
-*/
-
-/*!
- Processes the mouse press event \a e on behalf of the viewed widget.
-*/
-void TQListView::contentsMousePressEvent( TQMouseEvent * e )
-{
- contentsMousePressEventEx( e );
-}
-
-void TQListView::contentsMousePressEventEx( TQMouseEvent * e )
-{
- if ( !e )
- return;
-
- if ( !d->ignoreEditAfterFocus )
- d->startEdit = TRUE;
- d->ignoreEditAfterFocus = FALSE;
-
- if ( currentItem() && currentItem()->renameBox &&
- !itemRect( currentItem() ).contains( e->pos() ) ) {
- d->startEdit = FALSE;
- if ( d->defRenameAction == Reject )
- currentItem()->cancelRename( currentItem()->renameCol );
- else
- currentItem()->okRename( currentItem()->renameCol );
- }
-
- d->startDragItem = 0;
- d->dragStartPos = e->pos();
- TQPoint vp = contentsToViewport( e->pos() );
-
- d->ignoreDoubleClick = FALSE;
- d->buttonDown = TRUE;
-
- TQListViewItem * i = itemAt( vp );
- d->pressedEmptyArea = e->y() > contentsHeight();
- if ( i && !i->isEnabled() )
- return;
- if ( d->startEdit && ( i != currentItem() || (i && !i->isSelected()) ) )
- d->startEdit = FALSE;
- TQListViewItem *oldCurrent = currentItem();
-
- if ( e->button() == RightButton && (e->state() & ControlButton ) )
- goto emit_signals;
-
- if ( !i ) {
- if ( !( e->state() & ControlButton ) )
- clearSelection();
- goto emit_signals;
- } else {
- // No new anchor when using shift
- if ( !(e->state() & ShiftButton) )
- d->selectAnchor = i;
- }
-
- if ( (i->isExpandable() || i->childCount()) &&
- d->h->mapToLogical( d->h->cellAt( vp.x() ) ) == 0 ) {
- int x1 = vp.x() +
- d->h->offset() -
- d->h->cellPos( d->h->mapToActual( 0 ) );
- TQPtrListIterator<TQListViewPrivate::DrawableItem> it( *(d->drawables) );
- while( it.current() && it.current()->i != i )
- ++it;
-
- if ( it.current() ) {
- x1 -= treeStepSize() * (it.current()->l - 1);
- TQStyle::SubControl ctrl =
- style().querySubControl( TQStyle::CC_ListView,
- this, TQPoint(x1, e->pos().y()),
- TQStyleOption(i) );
- if( ctrl == TQStyle::SC_ListViewExpand &&
- e->type() == style().styleHint(TQStyle::SH_ListViewExpand_SelectMouseType, this)) {
- d->buttonDown = FALSE;
- if ( e->button() == LeftButton ) {
- bool close = i->isOpen();
- setOpen( i, !close );
- // ### Looks dangerous, removed because of reentrance problems
- // tqApp->processEvents();
- if ( !d->focusItem ) {
- d->focusItem = i;
- repaintItem( d->focusItem );
- emit currentChanged( d->focusItem );
- }
- if ( close ) {
- bool newCurrent = FALSE;
- TQListViewItem *ci = d->focusItem;
- while ( ci ) {
- if ( ci->parent() && ci->parent() == i ) {
- newCurrent = TRUE;
- break;
- }
- ci = ci->parent();
- }
- if ( newCurrent ) {
- setCurrentItem( i );
- }
- }
- }
- d->ignoreDoubleClick = TRUE;
- d->buttonDown = FALSE;
- goto emit_signals;
- }
- }
- }
-
- d->select = d->selectionMode == Multi ? !i->isSelected() : TRUE;
-
- {// calculate activatedP
- activatedByClick = TRUE;
- TQPoint topLeft = itemRect( i ).topLeft(); //### inefficient?
- activatedP = vp - topLeft;
- int xdepth = treeStepSize() * (i->depth() + (rootIsDecorated() ? 1 : 0))
- + itemMargin();
-
- // This returns the position of the first visual section?!? Shouldn't that always be 0? Keep it just in case we have missed something.
- xdepth += d->h->sectionPos( d->h->mapToSection( 0 ) );
- activatedP.rx() -= xdepth;
- }
- i->activate();
- activatedByClick = FALSE;
-
- if ( i != d->focusItem )
- setCurrentItem( i );
- else
- repaintItem( i );
-
- d->pressedSelected = i && i->isSelected();
-
- if ( i->isSelectable() && selectionMode() != NoSelection ) {
- if ( selectionMode() == Single )
- setSelected( i, TRUE );
- else if ( selectionMode() == Multi )
- setSelected( i, d->select );
- else if ( selectionMode() == Extended ) {
- bool changed = FALSE;
- if ( !(e->state() & (ControlButton | ShiftButton)) ) {
- if ( !i->isSelected() ) {
- bool blocked = signalsBlocked();
- blockSignals( TRUE );
- clearSelection();
- blockSignals( blocked );
- i->setSelected( TRUE );
- changed = TRUE;
- }
- } else {
- if ( e->state() & ShiftButton )
- d->pressedSelected = FALSE;
- if ( (e->state() & ControlButton) && !(e->state() & ShiftButton) && i ) {
- i->setSelected( !i->isSelected() );
- changed = TRUE;
- d->pressedSelected = FALSE;
- } else if ( !oldCurrent || !i || oldCurrent == i ) {
- if ( (bool)i->selected != d->select ) {
- changed = TRUE;
- i->setSelected( d->select );
- }
- // Shift pressed in Extended mode ---
- } else {
- changed = selectRange( i, oldCurrent, d->selectAnchor );
- }
- }
- if ( changed ) {
- d->useDoubleBuffer = TRUE;
- triggerUpdate();
- emit selectionChanged();
-
-#if defined(QT_ACCESSIBILITY_SUPPORT)
- TQAccessible::updateAccessibility( viewport(), 0, TQAccessible::Selection );
-#endif
- }
- }
- }
-
- emit_signals:
-
- if ( i && !d->buttonDown &&
- vp.x() + contentsX() < itemMargin() + ( i->depth() + ( rootIsDecorated() ? 1 : 0 ) ) * treeStepSize() )
- i = 0;
- d->pressedItem = i;
-
- int c = i ? d->h->mapToLogical( d->h->cellAt( vp.x() ) ) : -1;
- if ( !i || ( i && i->isEnabled() ) ) {
- emit pressed( i );
- emit pressed( i, viewport()->mapToGlobal( vp ), c );
- }
- emit mouseButtonPressed( e->button(), i, viewport()->mapToGlobal( vp ), c );
-
- if ( e->button() == RightButton && i == d->pressedItem ) {
- if ( !i && !(e->state() & ControlButton) )
- clearSelection();
-
- emit rightButtonPressed( i, viewport()->mapToGlobal( vp ), c );
- }
-}
-
-/*!
- \reimp
-*/
-
-void TQListView::contentsContextMenuEvent( TQContextMenuEvent *e )
-{
- if ( !receivers( TQ_SIGNAL(contextMenuRequested(TQListViewItem*,const TQPoint&,int)) ) ) {
- e->ignore();
- return;
- }
- if ( e->reason() == TQContextMenuEvent::Keyboard ) {
- TQListViewItem *item = currentItem();
- if ( item ) {
- TQRect r = itemRect( item );
- TQPoint p = r.topLeft();
- if ( allColumnsShowFocus() )
- p += TQPoint( width() / 2, ( r.height() / 2 ) );
- else
- p += TQPoint( columnWidth( 0 ) / 2, ( r.height() / 2 ) );
- p.rx() = TQMAX( 0, p.x() );
- p.rx() = TQMIN( visibleWidth(), p.x() );
- emit contextMenuRequested( item, viewport()->mapToGlobal( p ), -1 );
- }
- } else {
- TQPoint vp = contentsToViewport( e->pos() );
- TQListViewItem * i = itemAt( vp );
- int c = i ? d->h->mapToLogical( d->h->cellAt( vp.x() ) ) : -1;
- emit contextMenuRequested( i, viewport()->mapToGlobal( vp ), c );
- }
-}
-
-/*!
- Processes the mouse release event \a e on behalf of the viewed widget.
-*/
-void TQListView::contentsMouseReleaseEvent( TQMouseEvent * e )
-{
- contentsMouseReleaseEventEx( e );
-}
-
-void TQListView::contentsMouseReleaseEventEx( TQMouseEvent * e )
-{
- d->startDragItem = 0;
- bool emitClicked = !d->pressedItem || d->buttonDown;
- d->buttonDown = FALSE;
- // delete and disconnect autoscroll timer, if we have one
- if ( d->scrollTimer ) {
- disconnect( d->scrollTimer, TQ_SIGNAL(timeout()),
- this, TQ_SLOT(doAutoScroll()) );
- d->scrollTimer->stop();
- delete d->scrollTimer;
- d->scrollTimer = 0;
- }
-
- if ( !e )
- return;
-
- if ( d->selectionMode == Extended &&
- d->focusItem == d->pressedItem &&
- d->pressedSelected && d->focusItem &&
- e->button() == LeftButton) {
- bool block = signalsBlocked();
- blockSignals( TRUE );
- clearSelection();
- blockSignals( block );
- d->focusItem->setSelected( TRUE );
- emit selectionChanged();
-#if defined(QT_ACCESSIBILITY_SUPPORT)
- TQAccessible::updateAccessibility( viewport(), 0, TQAccessible::Selection );
-#endif
- }
-
- TQPoint vp = contentsToViewport(e->pos());
- TQListViewItem *i = itemAt( vp );
- if ( i && !i->isEnabled() )
- return;
-
- if ( i && i == d->pressedItem && (i->isExpandable() || i->childCount()) &&
- !d->h->mapToLogical( d->h->cellAt( vp.x() ) ) && e->button() == LeftButton &&
- e->type() == style().styleHint(TQStyle::SH_ListViewExpand_SelectMouseType, this)) {
- TQPtrListIterator<TQListViewPrivate::DrawableItem> it( *(d->drawables) );
- while( it.current() && it.current()->i != i )
- ++it;
- if ( it.current() ) {
- int x1 = vp.x() + d->h->offset() - d->h->cellPos( d->h->mapToActual( 0 ) ) -
- (treeStepSize() * (it.current()->l - 1));
- TQStyle::SubControl ctrl = style().querySubControl( TQStyle::CC_ListView,
- this, TQPoint(x1, e->pos().y()),
- TQStyleOption(i) );
- if( ctrl == TQStyle::SC_ListViewExpand ) {
- bool close = i->isOpen();
- setOpen( i, !close );
- // ### Looks dangerous, removed because of reentrance problems
- // tqApp->processEvents();
- if ( !d->focusItem ) {
- d->focusItem = i;
- repaintItem( d->focusItem );
- emit currentChanged( d->focusItem );
- }
- if ( close ) {
- bool newCurrent = FALSE;
- TQListViewItem *ci = d->focusItem;
- while ( ci ) {
- if ( ci->parent() && ci->parent() == i ) {
- newCurrent = TRUE;
- break;
- }
- ci = ci->parent();
- }
- if ( newCurrent )
- setCurrentItem( i );
- d->ignoreDoubleClick = TRUE;
- }
- }
- }
- }
-
- if ( i == d->pressedItem && i && i->isSelected() && e->button() == LeftButton && d->startEdit ) {
- TQRect r = itemRect( currentItem() );
- r = TQRect( viewportToContents( r.topLeft() ), r.size() );
- d->pressedColumn = header()->sectionAt( e->pos().x() );
- r.setLeft( header()->sectionPos( d->pressedColumn ) );
- r.setWidth( header()->sectionSize( d->pressedColumn ) - 1 );
- if ( d->pressedColumn == 0 )
- r.setLeft( r.left() + itemMargin() + ( currentItem()->depth() +
- ( rootIsDecorated() ? 1 : 0 ) ) * treeStepSize() - 1 );
- if ( r.contains( e->pos() ) &&
- !( e->state() & ( ShiftButton | ControlButton ) ) )
- d->renameTimer->start( TQApplication::doubleClickInterval(), TRUE );
- }
- // Check if we are clicking at the root decoration.
- int rootColumnPos = d->h->sectionPos( 0 );
- if ( i && vp.x() + contentsX() < rootColumnPos + itemMargin() + ( i->depth() + ( rootIsDecorated() ? 1 : 0 ) ) * treeStepSize()
- && vp.x() + contentsX() > rootColumnPos ) {
- i = 0;
- }
- emitClicked = emitClicked && d->pressedItem == i;
- d->pressedItem = 0;
- d->highlighted = 0;
-
- if ( emitClicked ) {
- if ( !i || ( i && i->isEnabled() ) ) {
- emit clicked( i );
- emit clicked( i, viewport()->mapToGlobal( vp ), d->h->mapToLogical( d->h->cellAt( vp.x() ) ) );
- }
- emit mouseButtonClicked( e->button(), i, viewport()->mapToGlobal( vp ),
- i ? d->h->mapToLogical( d->h->cellAt( vp.x() ) ) : -1 );
-
- if ( e->button() == RightButton ) {
- if ( !i ) {
- if ( !(e->state() & ControlButton) )
- clearSelection();
- emit rightButtonClicked( 0, viewport()->mapToGlobal( vp ), -1 );
- return;
- }
-
- int c = d->h->mapToLogical( d->h->cellAt( vp.x() ) );
- emit rightButtonClicked( i, viewport()->mapToGlobal( vp ), c );
- }
- }
-}
-
-
-/*!
- Processes the mouse double-click event \a e on behalf of the viewed widget.
-*/
-void TQListView::contentsMouseDoubleClickEvent( TQMouseEvent * e )
-{
- d->renameTimer->stop();
- d->startEdit = FALSE;
- if ( !e || e->button() != LeftButton )
- return;
-
- // ensure that the following mouse moves and eventual release is
- // ignored.
- d->buttonDown = FALSE;
-
- if ( d->ignoreDoubleClick ) {
- d->ignoreDoubleClick = FALSE;
- return;
- }
-
- TQPoint vp = contentsToViewport(e->pos());
-
- TQListViewItem * i = itemAt( vp );
-
- // we emit doubleClicked when the item is null (or enabled) to be consistent with
- // rightButtonClicked etc.
- if ( !i || i->isEnabled() ) {
- int c = d->h->mapToLogical( d->h->cellAt( vp.x() ) );
- emit doubleClicked( i, viewport()->mapToGlobal( vp ), c );
- }
-
- if ( !i || !i->isEnabled() )
- return;
-
- if ( !i->isOpen() ) {
- if ( i->isExpandable() || i->childCount() )
- setOpen( i, TRUE );
- } else {
- setOpen( i, FALSE );
- }
-
- // we emit the 'old' obsolete doubleClicked only if the item is not null and enabled
- emit doubleClicked( i );
-}
-
-
-/*!
- Processes the mouse move event \a e on behalf of the viewed widget.
-*/
-void TQListView::contentsMouseMoveEvent( TQMouseEvent * e )
-{
- if ( !e )
- return;
-
- bool needAutoScroll = FALSE;
-
- TQPoint vp = contentsToViewport(e->pos());
-
- TQListViewItem * i = itemAt( vp );
- if ( i && !i->isEnabled() )
- return;
- if ( i != d->highlighted &&
- !(d->pressedItem &&
- ( d->pressedItem->isSelected() || d->selectionMode == NoSelection ) &&
- d->pressedItem->dragEnabled() )) {
-
- if ( i ) {
- emit onItem( i );
- } else {
- emit onViewport();
- }
- d->highlighted = i;
- }
-
- if ( d->startDragItem )
- i = d->startDragItem;
-
- if ( !d->buttonDown ||
- ( ( e->state() & LeftButton ) != LeftButton &&
- ( e->state() & MidButton ) != MidButton &&
- ( e->state() & RightButton ) != RightButton ) )
- return;
-
- if ( d->pressedItem &&
- ( d->pressedItem->isSelected() || d->selectionMode == NoSelection ) &&
- d->pressedItem->dragEnabled() ) {
-
- if ( !d->startDragItem ) {
- setSelected( d->pressedItem, TRUE );
- d->startDragItem = d->pressedItem;
- }
- if ( ( d->dragStartPos - e->pos() ).manhattanLength() > TQApplication::startDragDistance() ) {
- d->buttonDown = FALSE;
-#ifndef TQT_NO_DRAGANDDROP
- startDrag();
-#endif
- }
- return;
- }
-
- // check, if we need to scroll
- if ( vp.y() > visibleHeight() || vp.y() < 0 )
- needAutoScroll = TRUE;
-
- // if we need to scroll and no autoscroll timer is started,
- // connect the timer
- if ( needAutoScroll && !d->scrollTimer ) {
- d->scrollTimer = new TQTimer( this );
- connect( d->scrollTimer, TQ_SIGNAL(timeout()),
- this, TQ_SLOT(doAutoScroll()) );
- d->scrollTimer->start( 100, FALSE );
- // call it once manually
- doAutoScroll( vp );
- }
-
- // if we don't need to autoscroll
- if ( !needAutoScroll ) {
- // if there is a autoscroll timer, delete it
- if ( d->scrollTimer ) {
- disconnect( d->scrollTimer, TQ_SIGNAL(timeout()),
- this, TQ_SLOT(doAutoScroll()) );
- d->scrollTimer->stop();
- delete d->scrollTimer;
- d->scrollTimer = 0;
- }
- // call this to select an item ( using the pos from the event )
- doAutoScroll( vp );
- }
-}
-
-
-/*!
- This slot handles auto-scrolling when the mouse button is pressed
- and the mouse is outside the widget.
-*/
-void TQListView::doAutoScroll()
-{
- doAutoScroll( TQPoint() );
-}
-
-/*
- Handles auto-scrolling when the mouse button is pressed
- and the mouse is outside the widget.
-
- If cursorPos is (0,0) (isNull == TRUE) it uses the current TQCursor::pos, otherwise it uses cursorPos
-*/
-void TQListView::doAutoScroll( const TQPoint &cursorPos )
-{
- TQPoint pos = cursorPos.isNull() ? viewport()->mapFromGlobal( TQCursor::pos() ) : cursorPos;
- if ( !d->focusItem || ( d->pressedEmptyArea && pos.y() > contentsHeight() ) )
- return;
-
- bool down = pos.y() > itemRect( d->focusItem ).y();
-
- int g = pos.y() + contentsY();
-
- if ( down && pos.y() > height() )
- g = height() + contentsY();
- else if ( pos.y() < 0 )
- g = contentsY();
-
- TQListViewItem *c = d->focusItem, *old = 0;
- TQListViewItem *oldCurrent = c;
- if ( down ) {
- int y = itemRect( d->focusItem ).y() + contentsY();
- while( c && y + c->height() <= g ) {
- y += c->height();
- old = c;
- c = c->itemBelow();
- }
- if ( !c && old )
- c = old;
- } else {
- int y = itemRect( d->focusItem ).y() + contentsY();
- while( c && y >= g ) {
- old = c;
- c = c->itemAbove();
- if ( c )
- y -= c->height();
- }
- if ( !c && old )
- c = old;
- }
-
- if ( !c || c == d->focusItem )
- return;
-
- if ( d->focusItem ) {
- if ( d->selectionMode == Multi ) {
- // also (de)select the ones in between
- TQListViewItem * b = d->focusItem;
- bool down = ( itemPos( c ) > itemPos( b ) );
- while( b && b != c ) {
- if ( b->isSelectable() )
- setSelected( b, d->select );
- b = down ? b->itemBelow() : b->itemAbove();
- }
- if ( c->isSelectable() )
- setSelected( c, d->select );
- } else if ( d->selectionMode == Extended ) {
- if ( selectRange( c, oldCurrent, d->selectAnchor ) ) {
- d->useDoubleBuffer = TRUE;
- triggerUpdate();
- emit selectionChanged();
- }
- }
- }
-
- setCurrentItem( c );
- d->visibleTimer->start( 1, TRUE );
-}
-
-/*!
- \reimp
-*/
-
-void TQListView::focusInEvent( TQFocusEvent* )
-{
- d->inMenuMode = FALSE;
- if ( d->focusItem ) {
- repaintItem( d->focusItem );
- } else if ( firstChild() && TQFocusEvent::reason() != TQFocusEvent::Mouse ) {
- d->focusItem = firstChild();
- emit currentChanged( d->focusItem );
- repaintItem( d->focusItem );
- }
- if ( TQFocusEvent::reason() == TQFocusEvent::Mouse ) {
- d->ignoreEditAfterFocus = TRUE;
- d->startEdit = FALSE;
- }
- if ( style().styleHint( TQStyle::SH_ItemView_ChangeHighlightOnFocus, this ) ) {
- bool db = d->useDoubleBuffer;
- d->useDoubleBuffer = TRUE;
- viewport()->repaint( FALSE );
- d->useDoubleBuffer = db;
- }
-
- TQRect mfrect = itemRect( d->focusItem );
- if ( mfrect.isValid() ) {
- if ( header() && header()->isVisible() )
- setMicroFocusHint( mfrect.x(), mfrect.y()+header()->height(), mfrect.width(), mfrect.height(), FALSE );
- else
- setMicroFocusHint( mfrect.x(), mfrect.y(), mfrect.width(), mfrect.height(), FALSE );
- }
-}
-
-
-/*!
- \reimp
-*/
-
-void TQListView::focusOutEvent( TQFocusEvent* )
-{
- if ( TQFocusEvent::reason() == TQFocusEvent::Popup && d->buttonDown )
- d->buttonDown = FALSE;
- if ( style().styleHint( TQStyle::SH_ItemView_ChangeHighlightOnFocus, this ) ) {
- d->inMenuMode =
- TQFocusEvent::reason() == TQFocusEvent::Popup
- || (tqApp->focusWidget() && tqApp->focusWidget()->inherits("TQMenuBar"));
- if ( !d->inMenuMode ) {
- bool db = d->useDoubleBuffer;
- d->useDoubleBuffer = TRUE;
- viewport()->repaint( FALSE );
- d->useDoubleBuffer = db;
- }
- }
-
- if ( d->focusItem )
- repaintItem( d->focusItem );
-}
-
-
-/*!
- \reimp
-*/
-
-void TQListView::keyPressEvent( TQKeyEvent * e )
-{
- if (currentItem() && currentItem()->renameBox)
- return;
- if (!firstChild()) {
- e->ignore();
- return; // subclass bug
- }
-
- TQListViewItem* oldCurrent = currentItem();
- if ( !oldCurrent ) {
- setCurrentItem( firstChild() );
- if ( d->selectionMode == Single )
- setSelected( firstChild(), TRUE );
- return;
- }
-
- TQListViewItem * i = currentItem();
- TQListViewItem *old = i;
-
- TQRect r( itemRect( i ) );
- TQListViewItem * i2;
-
- bool singleStep = FALSE;
- bool selectCurrent = TRUE;
- bool wasNavigation = TRUE;
-
- switch( e->key() ) {
- case Key_Backspace:
- case Key_Delete:
- d->currentPrefix.truncate( 0 );
- break;
- case Key_Enter:
- case Key_Return:
- d->currentPrefix.truncate( 0 );
- if ( i && !i->isSelectable() && i->isEnabled() &&
- ( i->childCount() || i->isExpandable() || i->isOpen() ) ) {
- i->setOpen( !i->isOpen() );
- return;
- }
- e->ignore();
- if ( currentItem() && !currentItem()->isEnabled() )
- break;
- emit returnPressed( currentItem() );
- // do NOT accept. TQDialog.
- return;
- case Key_Down:
- selectCurrent = FALSE;
- i = i->itemBelow();
- d->currentPrefix.truncate( 0 );
- singleStep = TRUE;
- break;
- case Key_Up:
- selectCurrent = FALSE;
- i = i->itemAbove();
- d->currentPrefix.truncate( 0 );
- singleStep = TRUE;
- break;
- case Key_Home:
- selectCurrent = FALSE;
- i = firstChild();
- if (!i->height() || !i->isEnabled())
- i = i->itemBelow();
- d->currentPrefix.truncate( 0 );
- break;
- case Key_End:
- selectCurrent = FALSE;
- i = firstChild();
- while (i->nextSibling() && i->nextSibling()->height() && i->nextSibling()->isEnabled())
- i = i->nextSibling();
- while ( i->itemBelow() )
- i = i->itemBelow();
- d->currentPrefix.truncate( 0 );
- break;
- case Key_Next:
- selectCurrent = FALSE;
- i2 = itemAt( TQPoint( 0, visibleHeight()-1 ) );
- if ( i2 == i || !r.isValid() ||
- visibleHeight() <= itemRect( i ).bottom() ) {
- if ( i2 )
- i = i2;
- int left = visibleHeight();
- while( (i2 = i->itemBelow()) != 0 && left > i2->height() ) {
- left -= i2->height();
- i = i2;
- }
- } else {
- if ( !i2 ) {
- // list is shorter than the view, goto last item
- while( (i2 = i->itemBelow()) != 0 )
- i = i2;
- } else {
- i = i2;
- }
- }
- d->currentPrefix.truncate( 0 );
- break;
- case Key_Prior:
- selectCurrent = FALSE;
- i2 = itemAt( TQPoint( 0, 0 ) );
- if ( i == i2 || !r.isValid() || r.top() <= 0 ) {
- if ( i2 )
- i = i2;
- int left = visibleHeight();
- while( (i2 = i->itemAbove()) != 0 && left > i2->height() ) {
- left -= i2->height();
- i = i2;
- }
- } else {
- i = i2;
- }
- d->currentPrefix.truncate( 0 );
- break;
- case Key_Plus:
- d->currentPrefix.truncate( 0 );
- if ( !i->isOpen() && (i->isExpandable() || i->childCount()) )
- setOpen( i, TRUE );
- else
- return;
- break;
- case Key_Right:
- d->currentPrefix.truncate( 0 );
- if ( i->isOpen() && i->childItem) {
- TQListViewItem *childItem = i->childItem;
- while (childItem && !childItem->isVisible())
- childItem = childItem->nextSibling();
- if (childItem)
- i = childItem;
- } else if ( !i->isOpen() && (i->isExpandable() || i->childCount()) ) {
- setOpen( i, TRUE );
- } else if ( contentsX() + visibleWidth() < contentsWidth() ) {
- horizontalScrollBar()->addLine();
- return;
- } else {
- return;
- }
- break;
- case Key_Minus:
- d->currentPrefix.truncate( 0 );
- if ( i->isOpen() )
- setOpen( i, FALSE );
- else
- return;
- break;
- case Key_Left:
- d->currentPrefix.truncate( 0 );
- if ( i->isOpen() ) {
- setOpen( i, FALSE );
- } else if ( i->parentItem && i->parentItem != d->r ) {
- i = i->parentItem;
- } else if ( contentsX() ) {
- horizontalScrollBar()->subtractLine();
- return;
- } else {
- return;
- }
- break;
- case Key_Space:
- activatedByClick = FALSE;
- d->currentPrefix.truncate( 0 );
- if ( currentItem() && !currentItem()->isEnabled() )
- break;
- i->activate();
- if ( i->isSelectable() && ( d->selectionMode == Multi || d->selectionMode == Extended ) ) {
- setSelected( i, !i->isSelected() );
- d->currentPrefix.truncate( 0 );
- }
- emit spacePressed( currentItem() );
- break;
- case Key_Escape:
- e->ignore(); // For TQDialog
- return;
- case Key_F2:
- if ( currentItem() && currentItem()->renameEnabled( 0 ) )
- currentItem()->startRename( 0 );
- default:
- if ( e->text().length() > 0 && e->text()[ 0 ].isPrint() ) {
- selectCurrent = FALSE;
- wasNavigation = FALSE;
- TQString input( d->currentPrefix );
- TQListViewItem * keyItem = i;
- TQTime now( TQTime::currentTime() );
- bool tryFirst = TRUE;
- while( keyItem ) {
- // try twice, first with the previous string and this char
- if ( d->currentPrefixTime.msecsTo( now ) <= 400 )
- input = input + e->text().lower();
- else
- input = e->text().lower();
- if ( input.length() == e->text().length() ) {
- if ( keyItem->itemBelow() ) {
- keyItem = keyItem->itemBelow();
- tryFirst = TRUE;
- } else {
- keyItem = firstChild();
- tryFirst = FALSE;
- }
- }
- TQString keyItemKey;
- TQString prefix;
- while( keyItem ) {
- keyItemKey = TQString::null;
- // Look first in the sort column, then left to right
- if (d->sortcolumn != Unsorted)
- keyItemKey = keyItem->text(d->sortcolumn);
- for ( int col = 0; col < d->h->count() && keyItemKey.isNull(); ++col )
- keyItemKey = keyItem->text( d->h->mapToSection(col) );
- if ( !keyItemKey.isEmpty() ) {
- prefix = keyItemKey;
- prefix.truncate( input.length() );
- prefix = prefix.lower();
- if ( prefix == input ) {
- d->currentPrefix = input;
- d->currentPrefixTime = now;
- i = keyItem;
- // nonoptimal double-break...
- keyItem = 0;
- input.truncate( 0 );
- tryFirst = FALSE;
- }
- }
- if ( keyItem )
- keyItem = keyItem->itemBelow();
- if ( !keyItem && tryFirst ) {
- keyItem = firstChild();
- tryFirst = FALSE;
- }
- }
- // then, if appropriate, with just this character
- if ( input.length() > e->text().length() ) {
- input.truncate(0);
- keyItem = i;
- }
- }
- } else {
- d->currentPrefix.truncate( 0 );
- if ( e->state() & ControlButton ) {
- d->currentPrefix = TQString::null;
- switch ( e->key() ) {
- case Key_A:
- selectAll( TRUE );
- break;
- }
- }
- e->ignore();
- return;
- }
- }
-
- if ( !i )
- return;
-
- if ( !( e->state() & ShiftButton ) || !d->selectAnchor )
- d->selectAnchor = i;
-
- setCurrentItem( i );
- if ( i->isSelectable() )
- handleItemChange( old, wasNavigation && (e->state() & ShiftButton),
- wasNavigation && (e->state() & ControlButton) );
-
- if ( d->focusItem && !d->focusItem->isSelected() && d->selectionMode == Single && selectCurrent )
- setSelected( d->focusItem, TRUE );
-
- if ( singleStep )
- d->visibleTimer->start( 1, TRUE );
- else
- ensureItemVisible( i );
-}
-
-
-/*!
- Returns the list view item at \a viewPos. Note that \a viewPos is
- in the viewport()'s coordinate system, not in the list view's own,
- much larger, coordinate system.
-
- itemAt() returns 0 if there is no such item.
-
- Note that you also get the pointer to the item if \a viewPos
- points to the root decoration (see setRootIsDecorated()) of the
- item. To check whether or not \a viewPos is on the root decoration
- of the item, you can do something like this:
-
- \code
- TQListViewItem *i = itemAt( p );
- if ( i ) {
- if ( p.x() > header()->sectionPos( header()->mapToIndex( 0 ) ) +
- treeStepSize() * ( i->depth() + ( rootIsDecorated() ? 1 : 0) ) + itemMargin() ||
- p.x() < header()->sectionPos( header()->mapToIndex( 0 ) ) ) {
- ; // p is not on root decoration
- else
- ; // p is on the root decoration
- }
- \endcode
-
- This might be interesting if you use this function to find out
- where the user clicked and if you want to start a drag (which you
- do not want to do if the user clicked onto the root decoration of
- an item).
-
- \sa itemPos() itemRect() viewportToContents()
-*/
-
-TQListViewItem * TQListView::itemAt( const TQPoint & viewPos ) const
-{
- if ( viewPos.x() > contentsWidth() - contentsX() ) {
- return 0;
- }
-
- if ( !d->drawables || d->drawables->isEmpty() ) {
- buildDrawableList();
- }
-
- TQListViewPrivate::DrawableItem * c = d->drawables->first();
- int g = viewPos.y() + contentsY();
-
- while( c && c->i && ( c->y + c->i->height() <= g ||
- !c->i->isVisible() ||
- ( c->i->parent() && !c->i->parent()->isVisible() ) ) )
- c = d->drawables->next();
-
- TQListViewItem *i = (c && c->y <= g) ? c->i : 0;
- return i;
-}
-
-
-/*!
- Returns the y-coordinate of \a item in the list view's coordinate
- system. This function is normally much slower than itemAt() but it
- works for all items, whereas itemAt() normally works only for
- items on the screen.
-
- This is a thin wrapper around TQListViewItem::itemPos().
-
- \sa itemAt() itemRect()
-*/
-
-int TQListView::itemPos( const TQListViewItem * item )
-{
- return item ? item->itemPos() : 0;
-}
-
-
-/*! \obsolete
- \property TQListView::multiSelection
- \brief whether the list view is in multi-selection or extended-selection mode
-
- If you enable multi-selection, \c Multi, mode, it is possible to
- specify whether or not this mode should be extended. \c Extended
- means that the user can select multiple items only when pressing
- the Shift or Ctrl key at the same time.
-
- The default selection mode is \c Single.
-
- \sa selectionMode()
-*/
-
-void TQListView::setMultiSelection( bool enable )
-{
- if ( !enable )
- d->selectionMode = TQListView::Single;
- else if ( d->selectionMode != Multi && d->selectionMode != Extended )
- d->selectionMode = TQListView::Multi;
-}
-
-bool TQListView::isMultiSelection() const
-{
- return d->selectionMode == TQListView::Extended || d->selectionMode == TQListView::Multi;
-}
-
-/*!
- \property TQListView::selectionMode
- \brief the list view's selection mode
-
- The mode can be \c Single (the default), \c Extended, \c Multi or
- \c NoSelection.
-
- \sa multiSelection
-*/
-
-void TQListView::setSelectionMode( SelectionMode mode )
-{
- if ( d->selectionMode == mode )
- return;
-
- if ( ( d->selectionMode == Multi || d->selectionMode == Extended ) &&
- ( mode == TQListView::Single || mode == TQListView::NoSelection ) ){
- clearSelection();
- if ( ( mode == TQListView::Single ) && currentItem() )
- currentItem()->selected = TRUE;
- }
-
- d->selectionMode = mode;
-}
-
-TQListView::SelectionMode TQListView::selectionMode() const
-{
- return d->selectionMode;
-}
-
-
-/*!
- If \a selected is TRUE the \a item is selected; otherwise it is
- unselected.
-
- If the list view is in \c Single selection mode and \a selected is
- TRUE, the currently selected item is unselected and \a item is
- made current. Unlike TQListViewItem::setSelected(), this function
- updates the list view as necessary and emits the
- selectionChanged() signals.
-
- \sa isSelected() setMultiSelection() isMultiSelection()
- setCurrentItem(), setSelectionAnchor()
-*/
-
-void TQListView::setSelected( TQListViewItem * item, bool selected )
-{
- if ( !item || item->isSelected() == selected ||
- !item->isSelectable() || selectionMode() == NoSelection )
- return;
-
- bool emitHighlighted = FALSE;
- if ( selectionMode() == Single && d->focusItem != item ) {
- TQListViewItem *o = d->focusItem;
- if ( d->focusItem && d->focusItem->selected )
- d->focusItem->setSelected( FALSE );
- d->focusItem = item;
- if ( o )
- repaintItem( o );
- emitHighlighted = TRUE;
- }
-
- item->setSelected( selected );
-
- repaintItem( item );
-
- if ( d->selectionMode == Single && selected )
- emit selectionChanged( item );
- emit selectionChanged();
-
- if ( emitHighlighted )
- emit currentChanged( d->focusItem );
-}
-
-/*!
- Sets the selection anchor to \a item, if \a item is selectable.
-
- The selection anchor is the item that remains selected when
- Shift-selecting with either mouse or keyboard in \c Extended
- selection mode.
-
- \sa setSelected()
-*/
-
-void TQListView::setSelectionAnchor( TQListViewItem *item )
-{
- if ( item && item->isSelectable() )
- d->selectAnchor = item;
-}
-
-/*!
- Sets all the items to be not selected, updates the list view as
- necessary, and emits the selectionChanged() signals. Note that for
- \c Multi selection list views this function needs to iterate over
- \e all items.
-
- \sa setSelected(), setMultiSelection()
-*/
-
-void TQListView::clearSelection()
-{
- selectAll( FALSE );
-}
-
-/*!
- If \a select is TRUE, all the items get selected; otherwise all
- the items get unselected. This only works in the selection modes \c
- Multi and \c Extended. In \c Single and \c NoSelection mode the
- selection of the current item is just set to \a select.
-*/
-
-void TQListView::selectAll( bool select )
-{
- if ( d->selectionMode == Multi || d->selectionMode == Extended ) {
- bool b = signalsBlocked();
- blockSignals( TRUE );
- bool anything = FALSE;
- TQListViewItemIterator it( this );
- while ( it.current() ) {
- TQListViewItem *i = it.current();
- 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;
- }
- blockSignals( b );
- if ( anything ) {
- emit selectionChanged();
- d->useDoubleBuffer = TRUE;
- triggerUpdate();
- }
- } else if ( d->focusItem ) {
- TQListViewItem * i = d->focusItem;
- setSelected( i, select );
- }
-}
-
-/*!
- Inverts the selection. Only works in \c Multi and \c Extended
- selection modes.
-*/
-
-void TQListView::invertSelection()
-{
- if ( d->selectionMode == Single ||
- d->selectionMode == NoSelection )
- return;
-
- bool b = signalsBlocked();
- blockSignals( TRUE );
- TQListViewItemIterator it( this );
- 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();
-}
-
-
-/*!
- Returns TRUE if the list view item \a i is selected; otherwise
- returns FALSE.
-
- \sa TQListViewItem::isSelected()
-*/
-
-bool TQListView::isSelected( const TQListViewItem * i ) const
-{
- return i ? i->isSelected() : FALSE;
-}
-
-
-/*!
- Returns the selected item if the list view is in \c Single
- selection mode and an item is selected.
-
- If no items are selected or the list view is not in \c Single
- selection mode this function returns 0.
-
- \sa setSelected() setMultiSelection()
-*/
-
-TQListViewItem * TQListView::selectedItem() const
-{
- if ( d->selectionMode != Single )
- return 0;
- if ( d->focusItem && d->focusItem->isSelected() )
- return d->focusItem;
- return 0;
-}
-
-
-/*!
- Sets item \a i to be the current item and repaints appropriately
- (i.e. highlights the item). The current item is used for keyboard
- navigation and focus indication; it is independent of any selected
- items, although a selected item can also be the current item.
-
- This function does not set the selection anchor. Use
- setSelectionAnchor() instead.
-
- \sa currentItem() setSelected()
-*/
-
-void TQListView::setCurrentItem( TQListViewItem * i )
-{
- if ( !i || d->focusItem == i || !i->isEnabled() )
- return;
-
- if ( currentItem() && currentItem()->renameBox ) {
- if ( d->defRenameAction == Reject )
- currentItem()->cancelRename( currentItem()->renameCol );
- else
- currentItem()->okRename( currentItem()->renameCol );
- }
-
- TQListViewItem * prev = d->focusItem;
- d->focusItem = i;
-
- TQRect mfrect = itemRect( i );
- if ( mfrect.isValid() ) {
- if ( header() && header()->isVisible() )
- setMicroFocusHint( mfrect.x(), mfrect.y()+header()->height(), mfrect.width(), mfrect.height(), FALSE );
- else
- setMicroFocusHint( mfrect.x(), mfrect.y(), mfrect.width(), mfrect.height(), FALSE );
- }
-
- if ( i != prev ) {
- if ( i && d->selectionMode == Single ) {
- bool changed = FALSE;
- if ( prev && prev->selected ) {
- changed = TRUE;
- prev->setSelected( FALSE );
- }
- if ( i && !i->selected && d->selectionMode != NoSelection && i->isSelectable() ) {
- i->setSelected( TRUE );
- changed = TRUE;
- emit selectionChanged( i );
- }
- if ( changed )
- emit selectionChanged();
- }
-
- if ( i )
- repaintItem( i );
- if ( prev )
- repaintItem( prev );
- emit currentChanged( i );
-
-#if defined(QT_ACCESSIBILITY_SUPPORT)
- TQAccessible::updateAccessibility( viewport(), indexOfItem( i ), TQAccessible::Focus );
-#endif
- }
-}
-
-
-/*!
- Returns the current item, or 0 if there isn't one.
-
- \sa setCurrentItem()
-*/
-
-TQListViewItem * TQListView::currentItem() const
-{
- return d->focusItem;
-}
-
-
-/*!
- Returns the rectangle on the screen that item \a i occupies in
- viewport()'s coordinates, or an invalid rectangle if \a i is 0 or
- is not currently visible.
-
- The rectangle returned does not include any children of the
- rectangle (i.e. it uses TQListViewItem::height(), rather than
- TQListViewItem::totalHeight()). If you want the rectangle to
- include children you can use something like this:
-
- \code
- TQRect r( listView->itemRect( item ) );
- r.setHeight( (TQCOORD)(TQMIN( item->totalHeight(),
- listView->viewport->height() - r.y() ) ) )
- \endcode
-
- Note the way it avoids too-high rectangles. totalHeight() can be
- much larger than the window system's coordinate system allows.
-
- itemRect() is comparatively slow. It's best to call it only for
- items that are probably on-screen.
-*/
-
-TQRect TQListView::itemRect( const TQListViewItem * i ) const
-{
- if ( !d->drawables || d->drawables->isEmpty() )
- buildDrawableList();
-
- TQListViewPrivate::DrawableItem * c = d->drawables->first();
-
- while( c && c->i && c->i != i )
- c = d->drawables->next();
-
- if ( c && c->i == i ) {
- int y = c->y - contentsY();
- if ( y + c->i->height() >= 0 &&
- y < ((TQListView *)this)->visibleHeight() ) {
- TQRect r( -contentsX(), y, d->h->width(), i->height() );
- return r;
- }
- }
-
- return TQRect( 0, 0, -1, -1 );
-}
-
-
-/*!
- \fn void TQListView::doubleClicked( TQListViewItem *item )
-
- \obsolete (use doubleClicked( TQListViewItem *, const TQPoint&, int ))
-
- This signal is emitted whenever an item is double-clicked. It's
- emitted on the second button press, not the second button release.
- \a item is the list view item on which the user did the
- double-click.
-*/
-
-/*!
- \fn void TQListView::doubleClicked( TQListViewItem *, const TQPoint&, int )
-
- This signal is emitted whenever an item is double-clicked. It's
- emitted on the second button press, not the second button release.
- The arguments are the relevant TQListViewItem (may be 0), the point
- in global coordinates and the relevant column (or -1 if the click
- was outside the list).
-
- \warning Do not delete any TQListViewItem objects in slots
- connected to this signal.
-*/
-
-
-/*!
- \fn void TQListView::returnPressed( TQListViewItem * )
-
- This signal is emitted when Enter or Return is pressed. The
- argument is the currentItem().
-*/
-
-/*!
- \fn void TQListView::spacePressed( TQListViewItem * )
-
- This signal is emitted when Space is pressed. The argument is
- the currentItem().
-*/
-
-
-/*!
- Sets the list view to be sorted by column \a column in ascending
- order if \a ascending is TRUE or descending order if it is FALSE.
-
- If \a column is -1, sorting is disabled and the user cannot sort
- columns by clicking on the column headers. If \a column is larger
- than the number of columns the user must click on a column
- header to sort the list view.
-*/
-
-void TQListView::setSorting( int column, bool ascending )
-{
- if ( column == -1 )
- column = Unsorted;
-
- if ( d->sortcolumn == column && d->ascending == ascending )
- return;
-
- d->ascending = ascending;
- d->sortcolumn = column;
- if ( d->sortcolumn != Unsorted && d->sortIndicator )
- d->h->setSortIndicator( d->sortcolumn, d->ascending );
- else
- d->h->setSortIndicator( -1 );
-
- triggerUpdate();
-
-#if defined(QT_ACCESSIBILITY_SUPPORT)
- TQAccessible::updateAccessibility( viewport(), 0, TQAccessible::ObjectReorder );
-#endif
-}
-
-/*!
- \enum TQt::SortOrder
-
- This enum describes how the items in a widget are sorted.
-
- \value Ascending The items are sorted ascending e.g. starts with
- 'AAA' ends with 'ZZZ' in Latin-1 locales
-
- \value Descending The items are sorted descending e.g. starts with
- 'ZZZ' ends with 'AAA' in Latin-1 locales
-*/
-
-/*!
- Sets the \a column the list view is sorted by.
-
- Sorting is triggered by choosing a header section.
-*/
-
-void TQListView::changeSortColumn( int column )
-{
- if ( isRenaming() ) {
- if ( d->defRenameAction == TQListView::Reject ) {
- currentItem()->cancelRename( currentItem()->renameCol );
- } else {
- currentItem()->okRename( currentItem()->renameCol );
- }
- }
- if ( d->sortcolumn != Unsorted ) {
- int lcol = d->h->mapToLogical( column );
- setSorting( lcol, d->sortcolumn == lcol ? !d->ascending : TRUE);
- }
-}
-
-/*!
- \internal
- Handles renaming when sections are being swapped by the user.
-*/
-
-void TQListView::handleIndexChange()
-{
- if ( isRenaming() ) {
- if ( d->defRenameAction == TQListView::Reject ) {
- currentItem()->cancelRename( currentItem()->renameCol );
- } else {
- currentItem()->okRename( currentItem()->renameCol );
- }
- }
- triggerUpdate();
-}
-
-/*!
- Returns the column by which the list view is sorted, or -1 if
- sorting is disabled.
-
- \sa sortOrder()
-*/
-
-int TQListView::sortColumn() const
-{
- return d->sortcolumn == Unsorted ? -1 : d->sortcolumn;
-}
-
-/*!
- Sets the sorting column for the list view.
-
- If \a column is -1, sorting is disabled and the user cannot sort
- columns by clicking on the column headers. If \a column is larger
- than the number of columns the user must click on a column header
- to sort the list view.
-
- \sa setSorting()
-*/
-void TQListView::setSortColumn( int column )
-{
- setSorting( column, d->ascending );
-}
-
-/*!
- Returns the sorting order of the list view items.
-
- \sa sortColumn()
-*/
-TQt::SortOrder TQListView::sortOrder() const
-{
- if ( d->ascending )
- return Ascending;
- return Descending;
-}
-
-/*!
- Sets the sort order for the items in the list view to \a order.
-
- \sa setSorting()
-*/
-void TQListView::setSortOrder( SortOrder order )
-{
- setSorting( d->sortcolumn, order == Ascending ? TRUE : FALSE );
-}
-
-/*!
- Sorts the list view using the last sorting configuration (sort
- column and ascending/descending).
-*/
-
-void TQListView::sort()
-{
- if ( d->r )
- d->r->sort();
-}
-
-/*!
- \property TQListView::itemMargin
- \brief the advisory item margin that list items may use
-
- The item margin defaults to one pixel and is the margin between
- the item's edges and the area where it draws its contents.
- TQListViewItem::paintFocus() draws in the margin.
-
- \sa TQListViewItem::paintCell()
-*/
-
-void TQListView::setItemMargin( int m )
-{
- if ( d->margin == m )
- return;
- d->margin = m;
- if ( isVisible() ) {
- if ( d->drawables )
- d->drawables->clear();
- triggerUpdate();
- }
-}
-
-int TQListView::itemMargin() const
-{
- return d->margin;
-}
-
-
-/*!
- \fn void TQListView::rightButtonClicked( TQListViewItem *, const TQPoint&, int )
-
- This signal is emitted when the right button is clicked (i.e. when
- it's released). The arguments are the relevant TQListViewItem (may
- be 0), the point in global coordinates and the relevant column (or
- -1 if the click was outside the list).
-*/
-
-
-/*!
- \fn void TQListView::rightButtonPressed (TQListViewItem *, const TQPoint &, int)
-
- This signal is emitted when the right button is pressed. The
- arguments are the relevant TQListViewItem (may be 0), the point in
- global coordinates and the relevant column (or -1 if the click was
- outside the list).
-*/
-
-/*!
- \fn void TQListView::contextMenuRequested( TQListViewItem *item, const TQPoint & pos, int col )
-
- This signal is emitted when the user invokes a context menu with
- the right mouse button or with special system keys. If the
- keyboard was used \a item is the current item; if the mouse was
- used, \a item is the item under the mouse pointer or 0 if there is
- no item under the mouse pointer. If no item is clicked, the column
- index emitted is -1.
-
- \a pos is the position for the context menu in the global
- coordinate system.
-
- \a col is the column on which the user pressed, or -1 if the
- signal was triggered by a key event.
-*/
-
-/*!
- \reimp
-*/
-void TQListView::styleChange( TQStyle& old )
-{
- TQScrollView::styleChange( old );
- reconfigureItems();
-}
-
-
-/*!
- \reimp
-*/
-void TQListView::setFont( const TQFont & f )
-{
- TQScrollView::setFont( f );
- reconfigureItems();
-}
-
-
-/*!
- \reimp
-*/
-void TQListView::setPalette( const TQPalette & p )
-{
- TQScrollView::setPalette( p );
- reconfigureItems();
-}
-
-
-/*!
- Ensures that setup() is called for all currently visible items,
- and that it will be called for currently invisible items as soon
- as their parents are opened.
-
- (A visible item, here, is an item whose parents are all open. The
- item may happen to be off-screen.)
-
- \sa TQListViewItem::setup()
-*/
-
-void TQListView::reconfigureItems()
-{
- d->fontMetricsHeight = fontMetrics().height();
- d->minLeftBearing = fontMetrics().minLeftBearing();
- d->minRightBearing = fontMetrics().minRightBearing();
- d->ellipsisWidth = fontMetrics().width( "..." ) * 2;
- d->r->setOpen( FALSE );
- d->r->configured = FALSE;
- d->r->setOpen( TRUE );
-}
-
-/*!
- Ensures that the width mode of column \a c is updated according to
- the width of \a item.
-*/
-
-void TQListView::widthChanged( const TQListViewItem* item, int c )
-{
- if ( c >= d->h->count() )
- return;
-
-
- TQFontMetrics fm = fontMetrics();
- int col = c < 0 ? 0 : c;
- while ( col == c || ( c < 0 && col < d->h->count() ) ) {
- if ( d->column[col]->wmode == Maximum ) {
- int w = item->width( fm, this, col );
- if ( showSortIndicator() ) {
- int tw = d->h->sectionSizeHint( col, fm ).width();
- tw += 40; //add space for the sort indicator
- w = TQMAX( w, tw );
- }
- if ( col == 0 ) {
- int indent = treeStepSize() * item->depth();
- if ( rootIsDecorated() )
- indent += treeStepSize();
- w += indent;
- }
- if ( w > columnWidth( col ) && !d->h->isStretchEnabled() && !d->h->isStretchEnabled( col ) ) {
- d->updateHeader = TRUE;
- setColumnWidth( col, w );
- }
- }
- col++;
- }
-}
-
-/*!
- \property TQListView::allColumnsShowFocus
- \brief whether items should show keyboard focus using all columns
-
- If this property is TRUE all columns will show focus and selection
- states, otherwise only column 0 will show focus.
-
- The default is FALSE.
-
- Setting this to TRUE if it's not necessary may cause noticeable
- flicker.
-*/
-
-void TQListView::setAllColumnsShowFocus( bool enable )
-{
- d->allColumnsShowFocus = enable;
-}
-
-bool TQListView::allColumnsShowFocus() const
-{
- return d->allColumnsShowFocus;
-}
-
-
-/*!
- Returns the first item in this TQListView. Returns 0 if there is no
- first item.
-
- A list view's items can be traversed using firstChild()
- and nextSibling() or using a TQListViewItemIterator.
-
- \sa itemAt() TQListViewItem::itemBelow() TQListViewItem::itemAbove()
-*/
-
-TQListViewItem * TQListView::firstChild() const
-{
- if ( !d->r )
- return 0;
-
- d->r->enforceSortOrder();
- return d->r->childItem;
-}
-
-/*!
- Returns the last item in the list view tree. Returns 0 if there
- are no items in the TQListView.
-
- This function is slow because it traverses the entire tree to find
- the last item.
-*/
-
-TQListViewItem* TQListView::lastItem() const
-{
- TQListViewItem* item = firstChild();
- if ( item ) {
- while ( item->nextSibling() || item->firstChild() ) {
- if ( item->nextSibling() )
- item = item->nextSibling();
- else
- item = item->firstChild();
- }
- }
- return item;
-}
-
-/*!
- Repaints this item on the screen if it is currently visible.
-*/
-
-void TQListViewItem::repaint() const
-{
- TQListView *lv = listView();
- if ( lv )
- lv->repaintItem( this );
-}
-
-
-/*!
- Repaints \a item on the screen if \a item is currently visible.
- Takes care to avoid multiple repaints.
-*/
-
-void TQListView::repaintItem( const TQListViewItem * item ) const
-{
- if ( !item )
- return;
- d->dirtyItemTimer->start( 0, TRUE );
- if ( !d->dirtyItems )
- d->dirtyItems = new TQPtrDict<void>();
- d->dirtyItems->replace( (void *)item, (void *)item );
-}
-
-
-struct TQCheckListItemPrivate
-{
- TQCheckListItemPrivate():
- exclusive( 0 ),
- currentState( TQCheckListItem::Off ),
- statesDict( 0 ),
- tristate( FALSE ) {}
-
- TQCheckListItem *exclusive;
- TQCheckListItem::ToggleState currentState;
- TQPtrDict<TQCheckListItem::ToggleState> *statesDict;
- bool tristate;
-};
-
-
-/*!
- \class TQCheckListItem
- \brief The TQCheckListItem class provides checkable list view items.
-
- \ingroup advanced
-
- TQCheckListItems are used in \l{TQListView}s to provide
- \l{TQListViewItem}s that are checkboxes, radio buttons or
- controllers.
-
- Checkbox and controller check list items may be inserted at any
- level in a list view. Radio button check list items must be
- children of a controller check list item.
-
- The item can be checked or unchecked with setOn(). Its type can be
- retrieved with type() and its text retrieved with text().
-
- \img qlistviewitems.png List View Items
-
- \sa TQListViewItem TQListView
-*/
-
-// ### obscenity is warranted.
-
-/*!
- \enum TQCheckListItem::Type
-
- This enum type specifies a TQCheckListItem's type:
-
- \value RadioButton
- \value CheckBox
- \value Controller \e obsolete (use \c RadioButtonController instead)
- \value RadioButtonController
- \value CheckBoxController
-*/
-
-/*!
- \enum TQCheckListItem::ToggleState
-
- This enum specifies a TQCheckListItem's toggle state.
-
- \value Off
- \value NoChange
- \value On
-*/
-
-
-/*!
- Constructs a checkable item with parent \a parent, text \a text
- and of type \a tt. Note that a \c RadioButton must be the child of a
- \c RadioButtonController, otherwise it will not toggle.
-*/
-TQCheckListItem::TQCheckListItem( TQCheckListItem *parent, const TQString &text,
- Type tt )
- : TQListViewItem( parent, text, TQString::null )
-{
- myType = tt;
- init();
- if ( myType == RadioButton ) {
- if ( parent->type() != RadioButtonController )
- tqWarning( "TQCheckListItem::TQCheckListItem(), radio button must be "
- "child of a controller" );
- else
- d->exclusive = parent;
- }
-}
-
-/*!
- Constructs a checkable item with parent \a parent, which is after
- \a after in the parent's list of children, and with text \a text
- and of type \a tt. Note that a \c RadioButton must be the child of
- a \c RadioButtonController, otherwise it will not toggle.
-*/
-TQCheckListItem::TQCheckListItem( TQCheckListItem *parent, TQListViewItem *after,
- const TQString &text, Type tt )
- : TQListViewItem( parent, after, text )
-{
- myType = tt;
- init();
- if ( myType == RadioButton ) {
- if ( parent->type() != RadioButtonController )
- tqWarning( "TQCheckListItem::TQCheckListItem(), radio button must be "
- "child of a controller" );
- else
- d->exclusive = parent;
- }
-}
-
-/*!
- Constructs a checkable item with parent \a parent, text \a text
- and of type \a tt. Note that this item must \e not be a \c
- RadioButton. Radio buttons must be children of a \c
- RadioButtonController.
-*/
-TQCheckListItem::TQCheckListItem( TQListViewItem *parent, const TQString &text,
- Type tt )
- : TQListViewItem( parent, text, TQString::null )
-{
- myType = tt;
- if ( myType == RadioButton ) {
- tqWarning( "TQCheckListItem::TQCheckListItem(), radio button must be "
- "child of a TQCheckListItem" );
- }
- init();
-}
-
-/*!
- Constructs a checkable item with parent \a parent, which is after
- \a after in the parent's list of children, with text \a text and
- of type \a tt. Note that this item must \e not be a \c
- RadioButton. Radio buttons must be children of a \c
- RadioButtonController.
-*/
-TQCheckListItem::TQCheckListItem( TQListViewItem *parent, TQListViewItem *after,
- const TQString &text, Type tt )
- : TQListViewItem( parent, after, text )
-{
- myType = tt;
- if ( myType == RadioButton ) {
- tqWarning( "TQCheckListItem::TQCheckListItem(), radio button must be "
- "child of a TQCheckListItem" );
- }
- init();
-}
-
-
-/*!
- Constructs a checkable item with parent \a parent, text \a text
- and of type \a tt. Note that \a tt must \e not be \c RadioButton.
- Radio buttons must be children of a \c RadioButtonController.
-*/
-TQCheckListItem::TQCheckListItem( TQListView *parent, const TQString &text,
- Type tt )
- : TQListViewItem( parent, text )
-{
- myType = tt;
- if ( tt == RadioButton )
- tqWarning( "TQCheckListItem::TQCheckListItem(), radio button must be "
- "child of a TQCheckListItem" );
- init();
-}
-
-/*!
- Constructs a checkable item with parent \a parent, which is after
- \a after in the parent's list of children, with text \a text and
- of type \a tt. Note that \a tt must \e not be \c RadioButton.
- Radio buttons must be children of a \c RadioButtonController.
-*/
-TQCheckListItem::TQCheckListItem( TQListView *parent, TQListViewItem *after,
- const TQString &text, Type tt )
- : TQListViewItem( parent, after, text )
-{
- myType = tt;
- if ( tt == RadioButton )
- tqWarning( "TQCheckListItem::TQCheckListItem(), radio button must be "
- "child of a TQCheckListItem" );
- init();
-}
-
-
-int TQCheckListItem::RTTI = 1;
-
-/* \reimp */
-
-int TQCheckListItem::rtti() const
-{
- return RTTI;
-}
-
-/*!
- Constructs a \c RadioButtonController item with parent \a parent,
- text \a text and pixmap \a p.
-*/
-TQCheckListItem::TQCheckListItem( TQListView *parent, const TQString &text,
- const TQPixmap & p )
- : TQListViewItem( parent, text )
-{
- myType = RadioButtonController;
- setPixmap( 0, p );
- init();
-}
-
-/*!
- Constructs a \c RadioButtonController item with parent \a parent,
- text \a text and pixmap \a p.
-*/
-TQCheckListItem::TQCheckListItem( TQListViewItem *parent, const TQString &text,
- const TQPixmap & p )
- : TQListViewItem( parent, text )
-{
- myType = RadioButtonController;
- setPixmap( 0, p );
- init();
-}
-
-void TQCheckListItem::init()
-{
- d = new TQCheckListItemPrivate();
- on = FALSE; // ### remove on ver 4
- if ( myType == CheckBoxController || myType == CheckBox ) {
- d->statesDict = new TQPtrDict<ToggleState>(101);
- d->statesDict->setAutoDelete( TRUE );
- }
- // CheckBoxControllers by default have tristate set to TRUE
- if ( myType == CheckBoxController )
- setTristate( TRUE );
-}
-
-/*!
- Destroys the item, and all its children to any depth, freeing up
- all allocated resources.
-*/
-TQCheckListItem::~TQCheckListItem()
-{
- if ( myType == RadioButton
- && d->exclusive && d->exclusive->d
- && d->exclusive->d->exclusive == this )
- d->exclusive->turnOffChild();
- d->exclusive = 0; // so the children won't try to access us.
- if ( d->statesDict )
- delete d->statesDict;
- delete d;
- d = 0;
-}
-
-/*!
- \fn TQCheckListItem::Type TQCheckListItem::type() const
-
- Returns the type of this item.
-*/
-
-/*!
- \fn bool TQCheckListItem::isOn() const
-
- Returns TRUE if the item is toggled on; otherwise returns FALSE.
-*/
-
-/*!
- Sets tristate to \a b if the \c Type is either a \c CheckBoxController or
- a \c CheckBox.
-
- \c CheckBoxControllers are tristate by default.
-
- \sa state() isTristate()
-*/
-void TQCheckListItem::setTristate( bool b )
-{
- if ( ( myType != CheckBoxController ) && ( myType != CheckBox ) ) {
- tqWarning( "TQCheckListItem::setTristate(), has no effect on RadioButton "
- "or RadioButtonController." );
- return;
- }
- d->tristate = b;
-}
-
-/*!
- Returns TRUE if the item is tristate; otherwise returns FALSE.
-
- \sa setTristate()
-*/
-bool TQCheckListItem::isTristate() const
-{
- return d->tristate;
-}
-
-/*!
- Returns the state of the item.
-
- \sa TQCheckListItem::ToggleState
-*/
-TQCheckListItem::ToggleState TQCheckListItem::state() const
-{
- if ( !isTristate() && internalState() == NoChange )
- return Off;
- else
- return d->currentState;
-}
-
-/*
- Same as the public state() except this one does not mask NoChange into Off
- when tristate is disabled.
-*/
-TQCheckListItem::ToggleState TQCheckListItem::internalState() const
-{
- return d->currentState;
-}
-
-
-
-
-/*!
- Sets the toggle state of the checklistitem to \a s. \a s can be
- \c Off, \c NoChange or \c On.
-
- Tristate can only be enabled for \c CheckBox or \c CheckBoxController,
- therefore the \c NoChange only applies to them.
-
- Setting the state to \c On or \c Off on a \c CheckBoxController
- will recursivly set the states of its children to the same state.
-
- Setting the state to \c NoChange on a \c CheckBoxController will
- make it recursivly recall the previous stored state of its
- children. If there was no previous stored state the children are
- all set to \c On.
-*/
-void TQCheckListItem::setState( ToggleState s )
-{
- if ( myType == CheckBoxController && state() == NoChange )
- updateStoredState( (void*) this );
- setState( s, TRUE, TRUE );
-}
-
-/*
- Sets the toggle state of the checklistitems. \a update tells if the
- controller / parent controller should be aware of these changes, \a store
- tells if the parent should store its children if certain conditions arise
-*/
-void TQCheckListItem::setState( ToggleState s, bool update, bool store)
-{
-
- if ( s == internalState() )
- return;
-
- if ( myType == CheckBox ) {
- setCurrentState( s );
- stateChange( state() );
- if ( update && parent() && parent()->rtti() == 1
- && ((TQCheckListItem*)parent())->type() == CheckBoxController )
- ((TQCheckListItem*)parent())->updateController( update, store );
- } else if ( myType == CheckBoxController ) {
- if ( s == NoChange && childCount()) {
- restoreState( (void*) this );
- } else {
- TQListViewItem *item = firstChild();
- int childCount = 0;
- while( item ) {
- if ( item->rtti() == 1 &&
- ( ((TQCheckListItem*)item)->type() == CheckBox ||
- ((TQCheckListItem*)item)->type() == CheckBoxController ) ) {
- TQCheckListItem *checkItem = (TQCheckListItem*)item;
- checkItem->setState( s, FALSE, FALSE );
- childCount++;
- }
- item = item->nextSibling();
- }
- if ( update ) {
- if ( childCount > 0 ) {
- ToggleState oldState = internalState();
- updateController( FALSE, FALSE );
- if ( oldState != internalState() &&
- parent() && parent()->rtti() == 1 &&
- ((TQCheckListItem*)parent())->type() == CheckBoxController )
- ((TQCheckListItem*)parent())->updateController( update, store );
-
- updateController( update, store );
- } else {
- // if there are no children we simply set the CheckBoxController and update its parent
- setCurrentState( s );
- stateChange( state() );
- if ( parent() && parent()->rtti() == 1
- && ((TQCheckListItem*)parent())->type() == CheckBoxController )
- ((TQCheckListItem*)parent())->updateController( update, store );
- }
- } else {
- setCurrentState( s );
- stateChange( state() );
- }
-
- }
- } else if ( myType == RadioButton ) {
- if ( s == On ) {
- if ( d->exclusive && d->exclusive->d->exclusive != this )
- d->exclusive->turnOffChild();
- setCurrentState( s );
- if ( d->exclusive )
- d->exclusive->d->exclusive = this;
- } else {
- if ( d->exclusive && d->exclusive->d->exclusive == this )
- d->exclusive->d->exclusive = 0;
- setCurrentState( Off );
- }
- stateChange( state() );
- }
- repaint();
-}
-
-/*
- this function is needed becase we need to update "on" everytime
- we update d->currentState. In order to retain binary compatibility
- the inline function isOn() needs the "on" bool
- ### should be changed in ver 4
-*/
-void TQCheckListItem::setCurrentState( ToggleState s )
-{
- ToggleState old = d->currentState;
- d->currentState = s;
- if (d->currentState == On)
- on = TRUE;
- else
- on = FALSE;
-
-#if defined(QT_ACCESSIBILITY_SUPPORT)
- if ( old != d->currentState && listView() )
- TQAccessible::updateAccessibility( listView()->viewport(), indexOfItem( this ), TQAccessible::StateChanged );
-#else
- Q_UNUSED( old );
-#endif
-}
-
-
-
-/*
- updates the internally stored state of this item for the parent (key)
-*/
-void TQCheckListItem::setStoredState( ToggleState newState, void *key )
-{
- if ( myType == CheckBox || myType == CheckBoxController )
- d->statesDict->replace( key, new ToggleState(newState) );
-}
-
-/*
- Returns the stored state for this item for the given key.
- If the key is not found it returns Off.
-*/
-TQCheckListItem::ToggleState TQCheckListItem::storedState( void *key ) const
-{
- if ( !d->statesDict )
- return Off;
-
- ToggleState *foundState = d->statesDict->find( key );
- if ( foundState )
- return ToggleState( *foundState );
- else
- return Off;
-}
-
-
-/*!
- \fn TQString TQCheckListItem::text() const
-
- Returns the item's text.
-*/
-
-
-/*!
- If this is a \c RadioButtonController that has \c RadioButton
- children, turn off the child that is on.
-*/
-void TQCheckListItem::turnOffChild()
-{
- if ( myType == RadioButtonController && d->exclusive )
- d->exclusive->setOn( FALSE );
-}
-
-/*!
- Toggle check box or set radio button to on.
-*/
-void TQCheckListItem::activate()
-{
- TQListView * lv = listView();
-
- if ( ( lv && !lv->isEnabled() ) || !isEnabled() )
- return;
-
- TQPoint pos;
- int boxsize = lv->style().pixelMetric(TQStyle::PM_CheckListButtonSize, lv);
- if ( activatedPos( pos ) ) {
- bool parentControl = FALSE;
- if ( parent() && parent()->rtti() == 1 &&
- ((TQCheckListItem*) parent())->type() == RadioButtonController )
- parentControl = TRUE;
-
- int x = parentControl ? 0 : 3;
- int align = lv->columnAlignment( 0 );
- int marg = lv->itemMargin();
- int y = 0;
-
- if ( align & AlignVCenter )
- y = ( ( height() - boxsize ) / 2 ) + marg;
- else
- y = (lv->fontMetrics().height() + 2 + marg - boxsize) / 2;
-
- TQRect r( x, y, boxsize-3, boxsize-3 );
- // columns might have been swapped
- r.moveBy( lv->header()->sectionPos( 0 ), 0 );
- if ( !r.contains( pos ) )
- return;
- }
- if ( ( myType == CheckBox ) || ( myType == CheckBoxController) ) {
- switch ( internalState() ) {
- case On:
- setState( Off );
- break;
- case Off:
- if ( (!isTristate() && myType == CheckBox) ||
- (myType == CheckBoxController && !childCount()) ) {
- setState( On );
- } else {
- setState( NoChange );
- if ( myType == CheckBoxController && internalState() != NoChange )
- setState( On );
- }
- break;
- case NoChange:
- setState( On );
- break;
- }
- ignoreDoubleClick();
- } else if ( myType == RadioButton ) {
- setOn( TRUE );
- ignoreDoubleClick();
- }
-}
-
-/*!
- Sets the button on if \a b is TRUE, otherwise sets it off.
- Maintains radio button exclusivity.
-*/
-void TQCheckListItem::setOn( bool b )
-{
- if ( b )
- setState( On , TRUE, TRUE );
- else
- setState( Off , TRUE, TRUE );
-}
-
-
-/*!
- This virtual function is called when the item changes its state.
- \c NoChange (if tristate is enabled and the type is either \c
- CheckBox or \c CheckBoxController) reports the same as \c Off, so
- use state() to determine if the state is actually \c Off or \c
- NoChange.
-*/
-void TQCheckListItem::stateChange( bool )
-{
-}
-
-/*
- Calls the public virtual function if the state is changed to either On, NoChange or Off.
- NoChange reports the same as Off - ### should be fixed in ver4
-*/
-void TQCheckListItem::stateChange( ToggleState s )
-{
- stateChange( s == On );
-}
-
-/*
- sets the state of the CheckBox and CheckBoxController back to
- previous stored state
-*/
-void TQCheckListItem::restoreState( void *key, int depth )
-{
- switch ( type() ) {
- case CheckBox:
- setCurrentState( storedState( key ) );
- stateChange( state() );
- repaint();
- break;
- case CheckBoxController: {
- TQListViewItem *item = firstChild();
- int childCount = 0;
- while ( item ) {
- // recursively calling restoreState for children of type CheckBox and CheckBoxController
- if ( item->rtti() == 1 &&
- ( ((TQCheckListItem*)item)->type() == CheckBox ||
- ((TQCheckListItem*)item)->type() == CheckBoxController ) ) {
- ((TQCheckListItem*)item)->restoreState( key , depth+1 );
- childCount++;
- }
- item = item->nextSibling();
- }
- if ( childCount > 0 ) {
- if ( depth == 0 )
- updateController( TRUE );
- else
- updateController( FALSE );
- } else {
- // if there are no children we retrieve the CheckBoxController state directly.
- setState( storedState( key ), TRUE, FALSE );
- }
- }
- break;
- default:
- break;
- }
-}
-
-
-/*
- Checks the childrens state and updates the controllers state
- if necessary. If the controllers state change, then his parent again is
- called to update itself.
-*/
-void TQCheckListItem::updateController( bool update , bool store )
-{
- if ( myType != CheckBoxController )
- return;
-
- TQCheckListItem *controller = 0;
- // checks if this CheckBoxController has another CheckBoxController as parent
- if ( parent() && parent()->rtti() == 1
- && ((TQCheckListItem*)parent())->type() == CheckBoxController )
- controller = (TQCheckListItem*)parent();
-
- ToggleState theState = Off;
- bool first = TRUE;
- TQListViewItem *item = firstChild();
- while( item && theState != NoChange ) {
- if ( item->rtti() == 1 &&
- ( ((TQCheckListItem*)item)->type() == CheckBox ||
- ((TQCheckListItem*)item)->type() == CheckBoxController ) ) {
- TQCheckListItem *checkItem = (TQCheckListItem*)item;
- if ( first ) {
- theState = checkItem->internalState();
- first = FALSE;
- } else {
- if ( checkItem->internalState() == NoChange ||
- theState != checkItem->internalState() )
- theState = NoChange;
- else
- theState = checkItem->internalState();
- }
- }
- item = item->nextSibling();
- }
- if ( internalState() != theState ) {
- setCurrentState( theState );
- if ( store && ( internalState() == On || internalState() == Off ) )
- updateStoredState( (void*) this );
- stateChange( state() );
- if ( update && controller ) {
- controller->updateController( update, store );
- }
- repaint();
- }
-}
-
-
-/*
- Makes all the children CheckBoxes update their storedState
-*/
-void TQCheckListItem::updateStoredState( void *key )
-{
- if ( myType != CheckBoxController )
- return;
-
- TQListViewItem *item = firstChild();
- while( item ) {
- if ( item->rtti() == 1 ) {
- TQCheckListItem *checkItem = (TQCheckListItem*)item;
- if ( checkItem->type() == CheckBox )
- checkItem->setStoredState( checkItem->internalState(), key );
- else if (checkItem->type() == CheckBoxController )
- checkItem->updateStoredState( key );
- }
- item = item->nextSibling();
- }
- // this state is only needed if the CheckBoxController has no CheckBox / CheckBoxController children.
- setStoredState( internalState() , key );
-}
-
-
-/*!
- \reimp
-*/
-void TQCheckListItem::setup()
-{
- TQListViewItem::setup();
- int h = height();
- TQListView *lv = listView();
- if ( lv )
- h = TQMAX( lv->style().pixelMetric(TQStyle::PM_CheckListButtonSize, lv),
- h );
- h = TQMAX( h, TQApplication::globalStrut().height() );
- setHeight( h );
-}
-
-/*!
- \reimp
-*/
-
-int TQCheckListItem::width( const TQFontMetrics& fm, const TQListView* lv, int column) const
-{
- int r = TQListViewItem::width( fm, lv, column );
- if ( column == 0 ) {
- r += lv->itemMargin();
- if ( myType == RadioButtonController && pixmap( 0 ) ) {
- // r += 0;
- } else {
- r += lv->style().pixelMetric(TQStyle::PM_CheckListButtonSize, lv) + 4;
- }
- }
- return TQMAX( r, TQApplication::globalStrut().width() );
-}
-
-/*!
- Paints the item using the painter \a p and the color group \a cg.
- The item is in column \a column, has width \a width and has
- alignment \a align. (See TQt::AlignmentFlags for valid alignments.)
-*/
-void TQCheckListItem::paintCell( TQPainter * p, const TQColorGroup & cg,
- int column, int width, int align )
-{
- if ( !p )
- return;
-
- TQListView *lv = listView();
- if ( !lv )
- return;
-
- const BackgroundMode bgmode = lv->viewport()->backgroundMode();
- const TQColorGroup::ColorRole crole = TQPalette::backgroundRoleFromMode( bgmode );
- if ( cg.brush( crole ) != lv->colorGroup().brush( crole ) )
- p->fillRect( 0, 0, width, height(), cg.brush( crole ) );
- else
- lv->paintEmptyArea( p, TQRect( 0, 0, width, height() ) );
-
- if ( column != 0 ) {
- // The rest is text, or for subclasses to change.
- TQListViewItem::paintCell( p, cg, column, width, align );
- return;
- }
-
- bool parentControl = FALSE;
- if ( parent() && parent()->rtti() == 1 &&
- ((TQCheckListItem*) parent())->type() == RadioButtonController )
- parentControl = TRUE;
-
- TQFontMetrics fm( lv->fontMetrics() );
- int boxsize = lv->style().pixelMetric( myType == RadioButtonController ? TQStyle::PM_CheckListControllerSize :
- TQStyle::PM_CheckListButtonSize, lv);
- int marg = lv->itemMargin();
- int r = marg;
-
- // Draw controller / checkbox / radiobutton ---------------------
- int styleflags = TQStyle::Style_Default;
- if ( internalState() == On ) {
- styleflags |= TQStyle::Style_On;
- } else if ( internalState() == NoChange ) {
- if ( myType == CheckBoxController && !isTristate() )
- styleflags |= TQStyle::Style_Off;
- else
- styleflags |= TQStyle::Style_NoChange;
- } else {
- styleflags |= TQStyle::Style_Off;
- }
- if ( isSelected() )
- styleflags |= TQStyle::Style_Selected;
- if ( isEnabled() && lv->isEnabled() )
- styleflags |= TQStyle::Style_Enabled;
-
- if ( myType == RadioButtonController ) {
- int x = 0;
- if(!parentControl)
- x += 3;
- if ( !pixmap( 0 ) ) {
- lv->style().drawPrimitive(TQStyle::PE_CheckListController, p,
- TQRect(x, 0, boxsize,
- fm.height() + 2 + marg),
- cg, styleflags, TQStyleOption(this));
- r += boxsize + 4;
- }
- } else {
- Q_ASSERT( lv ); //###
- int x = 0;
- int y = 0;
- if ( !parentControl )
- x += 3;
- if ( align & AlignVCenter )
- y = ( ( height() - boxsize ) / 2 ) + marg;
- else
- y = (fm.height() + 2 + marg - boxsize) / 2;
-
- if ( ( myType == CheckBox ) || ( myType == CheckBoxController ) ) {
- lv->style().drawPrimitive(TQStyle::PE_CheckListIndicator, p,
- TQRect(x, y, boxsize,
- fm.height() + 2 + marg),
- cg, styleflags, TQStyleOption(this));
- } else { //radio button look
- lv->style().drawPrimitive(TQStyle::PE_CheckListExclusiveIndicator,
- p, TQRect(x, y, boxsize,
- fm.height() + 2 + marg),
- cg, styleflags, TQStyleOption(this));
- }
- r += boxsize + 4;
- }
-
- // Draw text ----------------------------------------------------
- p->translate( r, 0 );
- p->setPen( TQPen( cg.text() ) );
- TQListViewItem::paintCell( p, cg, column, width - r, align );
-}
-
-/*!
- Draws the focus rectangle \a r using the color group \a cg on the
- painter \a p.
-*/
-void TQCheckListItem::paintFocus( TQPainter *p, const TQColorGroup & cg,
- const TQRect & r )
-{
- bool intersect = TRUE;
- TQListView *lv = listView();
- if ( lv && lv->header()->mapToActual( 0 ) != 0 ) {
- int xdepth = lv->treeStepSize() * ( depth() + ( lv->rootIsDecorated() ? 1 : 0) ) + lv->itemMargin();
- int p = lv->header()->cellPos( lv->header()->mapToActual( 0 ) );
- xdepth += p;
- intersect = r.intersects( TQRect( p, r.y(), xdepth - p + 1, r.height() ) );
- }
- bool parentControl = FALSE;
- if ( parent() && parent()->rtti() == 1 &&
- ((TQCheckListItem*) parent())->type() == RadioButtonController )
- parentControl = TRUE;
- if ( myType != RadioButtonController && intersect &&
- (lv->rootIsDecorated() || myType == RadioButton ||
- (myType == CheckBox && parentControl) ) ) {
- TQRect rect;
- int boxsize = lv->style().pixelMetric(TQStyle::PM_CheckListButtonSize, lv);
- if ( lv->columnAlignment(0) == AlignCenter ) {
- TQFontMetrics fm( lv->font() );
- int bx = (lv->columnWidth(0) - (boxsize + fm.width(text())))/2 + boxsize;
- if ( bx < 0 ) bx = 0;
- rect.setRect( r.x() + bx + 5, r.y(), r.width() - bx - 5,
- r.height() );
- } else
- rect.setRect( r.x() + boxsize + 5, r.y(), r.width() - boxsize - 5,
- r.height() );
- TQListViewItem::paintFocus(p, cg, rect);
- } else {
- TQListViewItem::paintFocus(p, cg, r);
- }
-}
-
-/*!
- \reimp
-*/
-TQSize TQListView::sizeHint() const
-{
- if ( cachedSizeHint().isValid() )
- return cachedSizeHint();
-
- constPolish();
-
- if ( !isVisible() && (!d->drawables || d->drawables->isEmpty()) )
- // force the column widths to sanity, if possible
- buildDrawableList();
-
- TQSize s( d->h->sizeHint() );
- if ( verticalScrollBar()->isVisible() )
- s.setWidth( s.width() + style().pixelMetric(TQStyle::PM_ScrollBarExtent) );
- s += TQSize(frameWidth()*2,frameWidth()*2);
- TQListViewItem * l = d->r;
- while( l && !l->height() )
- l = l->childItem ? l->childItem : l->siblingItem;
-
- if ( l && l->height() )
- s.setHeight( s.height() + 10 * l->height() );
- else
- s.setHeight( s.height() + 140 );
-
- if ( s.width() > s.height() * 3 )
- s.setHeight( s.width() / 3 );
- else if ( s.width() *3 < s.height() )
- s.setHeight( s.width() * 3 );
-
- setCachedSizeHint( s );
-
- return s;
-}
-
-
-/*!
- \reimp
-*/
-
-TQSize TQListView::minimumSizeHint() const
-{
- return TQScrollView::minimumSizeHint();
-}
-
-
-/*!
- Sets \a item to be open if \a open is TRUE and \a item is
- expandable, and to be closed if \a open is FALSE. Repaints
- accordingly.
-
- \sa TQListViewItem::setOpen() TQListViewItem::setExpandable()
-*/
-
-void TQListView::setOpen( TQListViewItem * item, bool open )
-{
- if ( !item ||
- item->isOpen() == open ||
- (open && !item->childCount() && !item->isExpandable()) )
- return;
-
- TQListViewItem* nextParent = 0;
- if ( open )
- nextParent = item->itemBelow();
-
- item->setOpen( open );
-
- if ( open ) {
- TQListViewItem* lastChild = item;
- TQListViewItem* tmp;
- while ( TRUE ) {
- tmp = lastChild->itemBelow();
- if ( !tmp || tmp == nextParent )
- break;
- lastChild = tmp;
- }
- ensureItemVisible( lastChild );
- ensureItemVisible( item );
- }
- if ( d->drawables )
- d->drawables->clear();
- buildDrawableList();
-
- TQListViewPrivate::DrawableItem * c = d->drawables->first();
-
- while( c && c->i && c->i != item )
- c = d->drawables->next();
-
- if ( c && c->i == item ) {
- d->dirtyItemTimer->start( 0, TRUE );
- if ( !d->dirtyItems )
- d->dirtyItems = new TQPtrDict<void>();
- while( c && c->i ) {
- d->dirtyItems->insert( (void *)(c->i), (void *)(c->i) );
- c = d->drawables->next();
- }
- }
-}
-
-
-/*!
- Identical to \a{item}->isOpen(). Provided for completeness.
-
- \sa setOpen()
-*/
-
-bool TQListView::isOpen( const TQListViewItem * item ) const
-{
- return item->isOpen();
-}
-
-
-/*!
- \property TQListView::rootIsDecorated
- \brief whether the list view shows open/close signs on root items
-
- Open/close signs are small <b>+</b> or <b>-</b> symbols in windows
- style, or arrows in Motif style. The default is FALSE.
-*/
-
-void TQListView::setRootIsDecorated( bool enable )
-{
- if ( enable != (bool)d->rootIsExpandable ) {
- d->rootIsExpandable = enable;
- if ( isVisible() )
- triggerUpdate();
- }
-}
-
-bool TQListView::rootIsDecorated() const
-{
- return d->rootIsExpandable;
-}
-
-
-/*!
- Ensures that item \a i is visible, scrolling the list view
- vertically if necessary and opening (expanding) any parent items
- if this is required to show the item.
-
- \sa itemRect() TQScrollView::ensureVisible()
-*/
-
-void TQListView::ensureItemVisible( const TQListViewItem * i )
-{
- if ( !i || !i->isVisible() )
- return;
-
- TQListViewItem *parent = i->parent();
- while ( parent ) {
- if ( !parent->isOpen() )
- parent->setOpen( TRUE );
- parent = parent->parent();
- }
-
- if ( d->r->maybeTotalHeight < 0 )
- updateGeometries();
- int y = itemPos( i );
- int h = i->height();
- if ( isVisible() && y + h > contentsY() + visibleHeight() )
- setContentsPos( contentsX(), y - visibleHeight() + h );
- else if ( !isVisible() || y < contentsY() )
- setContentsPos( contentsX(), y );
-}
-
-
-/*!
- \fn TQString TQCheckListItem::text( int n ) const
-
- \reimp
-*/
-
-/*!
- Returns the TQHeader object that manages this list view's columns.
- Please don't modify the header behind the list view's back.
-
- You may safely call TQHeader::setClickEnabled(),
- TQHeader::setResizeEnabled(), TQHeader::setMovingEnabled(),
- TQHeader::hide() and all the const TQHeader functions.
-*/
-
-TQHeader * TQListView::header() const
-{
- return d->h;
-}
-
-
-/*!
- \property TQListView::childCount
- \brief the number of parentless (top-level) TQListViewItem objects in this TQListView
-
- Holds the current number of parentless (top-level) TQListViewItem
- objects in this TQListView.
-
- \sa TQListViewItem::childCount()
-*/
-
-int TQListView::childCount() const
-{
- if ( d->r )
- return d->r->childCount();
- return 0;
-}
-
-
-/*
- Moves this item to just after \a olderSibling. \a olderSibling and
- this object must have the same parent.
-
- If you need to move an item in the hierarchy use takeItem() and
- insertItem().
-*/
-
-void TQListViewItem::moveToJustAfter( TQListViewItem * olderSibling )
-{
- if ( parentItem && olderSibling &&
- olderSibling->parentItem == parentItem && olderSibling != this ) {
- if ( parentItem->childItem == this ) {
- parentItem->childItem = siblingItem;
- } else {
- TQListViewItem * i = parentItem->childItem;
- while( i && i->siblingItem != this )
- i = i->siblingItem;
- if ( i )
- i->siblingItem = siblingItem;
- }
- siblingItem = olderSibling->siblingItem;
- olderSibling->siblingItem = this;
- parentItem->lsc = Unsorted;
- }
-}
-
-/*!
- Move the item to be after item \a after, which must be one of the
- item's siblings. To move an item in the hierarchy, use takeItem()
- and insertItem().
-
- Note that this function will have no effect if sorting is enabled
- in the list view.
-*/
-
-void TQListViewItem::moveItem( TQListViewItem *after )
-{
- if ( !after || after == this )
- return;
- if ( parent() != after->parent() ) {
- if ( parentItem )
- parentItem->takeItem( this );
- if ( after->parentItem ) {
- int tmpLsc = after->parentItem->lsc;
- after->parentItem->insertItem( this );
- after->parentItem->lsc = tmpLsc;
- }
- }
- moveToJustAfter( after );
- TQListView *lv = listView();
- if ( lv )
- lv->triggerUpdate();
-}
-
-/*
- Recursively sorts items, from the root to this item.
- (enforceSortOrder() won't work the other way around, as
- documented.)
-*/
-void TQListViewItem::enforceSortOrderBackToRoot()
-{
- if ( parentItem ) {
- parentItem->enforceSortOrderBackToRoot();
- parentItem->enforceSortOrder();
- }
-}
-
-/*!
- \reimp
-*/
-void TQListView::showEvent( TQShowEvent * )
-{
- if ( d->drawables )
- d->drawables->clear();
- delete d->dirtyItems;
- d->dirtyItems = 0;
- d->dirtyItemTimer->stop();
- d->fullRepaintOnComlumnChange = TRUE;
-
- updateGeometries();
-}
-
-
-/*!
- Returns the y coordinate of this item in the list view's
- coordinate system. This function is normally much slower than
- TQListView::itemAt(), but it works for all items whereas
- TQListView::itemAt() normally only works for items on the screen.
-
- \sa TQListView::itemAt() TQListView::itemRect() TQListView::itemPos()
-*/
-
-int TQListViewItem::itemPos() const
-{
- TQPtrStack<TQListViewItem> s;
- TQListViewItem * i = (TQListViewItem *)this;
- while( i ) {
- s.push( i );
- i = i->parentItem;
- }
-
- int a = 0;
- TQListViewItem * p = 0;
- while( s.count() ) {
- i = s.pop();
- if ( p ) {
- if ( !p->configured ) {
- p->configured = TRUE;
- p->setup(); // ### virtual non-const function called in const
- }
- a += p->height();
- TQListViewItem * s = p->firstChild();
- while( s && s != i ) {
- a += s->totalHeight();
- s = s->nextSibling();
- }
- }
- p = i;
- }
- return a;
-}
-
-
-/*!
- \fn void TQListView::removeItem( TQListViewItem * )
- \obsolete
-
- This function has been renamed takeItem().
-*/
-
-/*!
- Removes item \a i from the list view; \a i must be a top-level
- item. The warnings regarding TQListViewItem::takeItem() apply to
- this function, too.
-
- \sa insertItem()
-*/
-void TQListView::takeItem( TQListViewItem * i )
-{
- if ( d->r )
- d->r->takeItem( i );
-}
-
-
-void TQListView::openFocusItem()
-{
- d->autoopenTimer->stop();
- if ( d->focusItem && !d->focusItem->isOpen() ) {
- d->focusItem->setOpen( TRUE );
- d->focusItem->repaint();
- }
-}
-
-static const int autoopenTime = 750;
-
-#ifndef TQT_NO_DRAGANDDROP
-
-/*! \reimp */
-
-void TQListView::contentsDragEnterEvent( TQDragEnterEvent *e )
-{
- d->oldFocusItem = d->focusItem;
- TQListViewItem *i = d->focusItem;
- d->focusItem = itemAt( contentsToViewport( e->pos() ) );
- if ( i )
- i->repaint();
- if ( d->focusItem ) {
- d->autoopenTimer->start( autoopenTime );
- d->focusItem->dragEntered();
- d->focusItem->repaint();
- }
- if ( ( i && i->dropEnabled() && i->acceptDrop( e ) ) || acceptDrops() )
- e->accept();
- else
- e->ignore();
-}
-
-/*! \reimp */
-
-void TQListView::contentsDragMoveEvent( TQDragMoveEvent *e )
-{
- TQListViewItem *i = d->focusItem;
- d->focusItem = itemAt( contentsToViewport( e->pos() ) );
- if ( i ) {
- if ( i != d->focusItem )
- i->dragLeft();
- i->repaint();
- }
- if ( d->focusItem ) {
- if ( i != d->focusItem ) {
- d->focusItem->dragEntered();
- d->autoopenTimer->stop();
- d->autoopenTimer->start( autoopenTime );
- }
- d->focusItem->repaint();
- } else {
- d->autoopenTimer->stop();
- }
- if ( ( i && i->dropEnabled() && i->acceptDrop( e ) ) || acceptDrops() )
- e->accept();
- else
- e->ignore();
-}
-
-/*! \reimp */
-
-void TQListView::contentsDragLeaveEvent( TQDragLeaveEvent * )
-{
- d->autoopenTimer->stop();
-
- if ( d->focusItem )
- d->focusItem->dragLeft();
-
- setCurrentItem( d->oldFocusItem );
- d->oldFocusItem = 0;
-}
-
-/*! \reimp */
-
-void TQListView::contentsDropEvent( TQDropEvent *e )
-{
- d->autoopenTimer->stop();
-
- setCurrentItem( d->oldFocusItem );
- TQListViewItem *i = itemAt( contentsToViewport( e->pos() ) );
- if ( i && i->dropEnabled() && i->acceptDrop( e ) ) {
- i->dropped( e );
- e->accept();
- } else if ( acceptDrops() ) {
- emit dropped( e );
- e->accept();
- }
-}
-
-/*!
- If the user presses the mouse on an item and starts moving the
- mouse, and the item allow dragging (see
- TQListViewItem::setDragEnabled()), this function is called to get a
- drag object and a drag is started unless dragObject() returns 0.
-
- By default this function returns 0. You should reimplement it and
- create a TQDragObject depending on the selected items.
-*/
-
-TQDragObject *TQListView::dragObject()
-{
- return 0;
-}
-
-/*!
- Starts a drag.
-*/
-
-void TQListView::startDrag()
-{
- if ( !d->startDragItem )
- return;
-
- d->startDragItem = 0;
- d->buttonDown = FALSE;
-
- TQDragObject *drag = dragObject();
- if ( !drag )
- return;
-
- drag->drag();
-}
-
-#endif // TQT_NO_DRAGANDDROP
-
-/*!
- \property TQListView::defaultRenameAction
- \brief What action to perform when the editor loses focus during renaming
-
- If this property is \c Accept, and the user renames an item and
- the editor loses focus (without the user pressing Enter), the
- item will still be renamed. If the property's value is \c Reject,
- the item will not be renamed unless the user presses Enter. The
- default is \c Reject.
-*/
-
-void TQListView::setDefaultRenameAction( RenameAction a )
-{
- d->defRenameAction = a;
-}
-
-TQListView::RenameAction TQListView::defaultRenameAction() const
-{
- return d->defRenameAction;
-}
-
-/*!
- Returns TRUE if an item is being renamed; otherwise returns FALSE.
-*/
-
-bool TQListView::isRenaming() const
-{
- return currentItem() && currentItem()->renameBox;
-}
-
-/**********************************************************************
- *
- * Class TQListViewItemIterator
- *
- **********************************************************************/
-
-
-/*!
- \class TQListViewItemIterator
- \brief The TQListViewItemIterator class provides an iterator for collections of TQListViewItems.
-
- \ingroup advanced
-
- Construct an instance of a TQListViewItemIterator, with either a
- TQListView* or a TQListViewItem* as argument, to operate on the tree
- of TQListViewItems, starting from the argument.
-
- A TQListViewItemIterator iterates over all the items from its
- starting point. This means that it always makes the first child of
- the current item the new current item. If there is no child, the
- next sibling becomes the new current item; and if there is no next
- sibling, the next sibling of the parent becomes current.
-
- The following example creates a list of all the items that have
- been selected by the user, storing pointers to the items in a
- TQPtrList:
- \code
- TQPtrList<TQListViewItem> lst;
- TQListViewItemIterator it( myListView );
- while ( it.current() ) {
- if ( it.current()->isSelected() )
- lst.append( it.current() );
- ++it;
- }
- \endcode
-
- An alternative approach is to use an \c IteratorFlag:
- \code
- TQPtrList<TQListViewItem> lst;
- TQListViewItemIterator it( myListView, TQListViewItemIterator::Selected );
- while ( it.current() ) {
- lst.append( it.current() );
- ++it;
- }
- \endcode
-
- A TQListViewItemIterator provides a convenient and easy way to
- traverse a hierarchical TQListView.
-
- Multiple TQListViewItemIterators can operate on the tree of
- TQListViewItems. A TQListView knows about all iterators operating on
- its TQListViewItems. So when a TQListViewItem gets removed all
- iterators that point to this item are updated and point to the
- following item if possible, otherwise to a valid item before the
- current one or to 0. Note however that deleting the parent item of
- an item that an iterator points to is not safe.
-
- \sa TQListView, TQListViewItem
-*/
-
-/*!
- \enum TQListViewItemIterator::IteratorFlag
-
- These flags can be passed to a TQListViewItemIterator constructor
- (OR-ed together if more than one is used), so that the iterator
- will only iterate over items that match the given flags.
-
- \value Visible
- \value Invisible
- \value Selected
- \value Unselected
- \value Selectable
- \value NotSelectable
- \value DragEnabled
- \value DragDisabled
- \value DropEnabled
- \value DropDisabled
- \value Expandable
- \value NotExpandable
- \value Checked
- \value NotChecked
-*/
-
-/*!
- Constructs an empty iterator.
-*/
-
-TQListViewItemIterator::TQListViewItemIterator()
- : curr( 0 ), listView( 0 )
-{
- init( 0 );
-}
-
-/*!
- Constructs an iterator for the TQListView that contains the \a
- item. The current iterator item is set to point to the \a item.
-*/
-
-TQListViewItemIterator::TQListViewItemIterator( TQListViewItem *item )
- : curr( item ), listView( 0 )
-{
- init( 0 );
-
- if ( item ) {
- item->enforceSortOrderBackToRoot();
- listView = item->listView();
- }
- addToListView();
-}
-
-/*!
- Constructs an iterator for the TQListView that contains the \a item
- using the flags \a iteratorFlags. The current iterator item is set
- to point to \a item or the next matching item if \a item doesn't
- match the flags.
-
- \sa TQListViewItemIterator::IteratorFlag
-*/
-
-TQListViewItemIterator::TQListViewItemIterator( TQListViewItem *item, int iteratorFlags )
- : curr( item ), listView( 0 )
-{
- init( iteratorFlags );
-
- // go to next matching item if the current don't match
- if ( curr && !matchesFlags( curr ) )
- ++( *this );
-
- if ( curr ) {
- curr->enforceSortOrderBackToRoot();
- listView = curr->listView();
- }
- addToListView();
-}
-
-
-/*!
- Constructs an iterator for the same TQListView as \a it. The
- current iterator item is set to point on the current item of \a
- it.
-*/
-
-TQListViewItemIterator::TQListViewItemIterator( const TQListViewItemIterator& it )
- : curr( it.curr ), listView( it.listView )
-{
- init(it.d() ? it.d()->flags : 0);
-
- addToListView();
-}
-
-/*!
- Constructs an iterator for the TQListView \a lv. The current
- iterator item is set to point on the first child (TQListViewItem)
- of \a lv.
-*/
-
-TQListViewItemIterator::TQListViewItemIterator( TQListView *lv )
- : curr( lv->firstChild() ), listView( lv )
-{
- init( 0 );
-
- addToListView();
-}
-
-/*!
- Constructs an iterator for the TQListView \a lv with the flags \a
- iteratorFlags. The current iterator item is set to point on the
- first child (TQListViewItem) of \a lv that matches the flags.
-
- \sa TQListViewItemIterator::IteratorFlag
-*/
-
-TQListViewItemIterator::TQListViewItemIterator( TQListView *lv, int iteratorFlags )
- : curr ( lv->firstChild() ), listView( lv )
-{
- init( iteratorFlags );
-
- addToListView();
- if ( !matchesFlags( curr ) )
- ++( *this );
-}
-
-
-
-/*!
- Assignment. Makes a copy of \a it and returns a reference to its
- iterator.
-*/
-
-TQListViewItemIterator &TQListViewItemIterator::operator=( const TQListViewItemIterator &it )
-{
- if ( listView ) {
- if ( listView->d->iterators->removeRef( this ) ) {
- if ( listView->d->iterators->count() == 0 ) {
- delete listView->d->iterators;
- listView->d->iterators = 0;
- }
- }
- }
-
- listView = it.listView;
- addToListView();
- curr = it.curr;
-
- // sets flags to be the same as the input iterators flags
- if ( d() && it.d() )
- d()->flags = it.d()->flags;
-
- // go to next matching item if the current don't match
- if ( curr && !matchesFlags( curr ) )
- ++( *this );
-
- return *this;
-}
-
-/*!
- Destroys the iterator.
-*/
-
-TQListViewItemIterator::~TQListViewItemIterator()
-{
- if ( listView ) {
- if ( listView->d->iterators->removeRef( this ) ) {
- if ( listView->d->iterators->count() == 0 ) {
- delete listView->d->iterators;
- listView->d->iterators = 0;
- }
- }
- }
- // removs the d-ptr from the dict ( autodelete on), and deletes the
- // ptrdict if it becomes empty
- if ( qt_iteratorprivate_dict ) {
- qt_iteratorprivate_dict->remove( this );
- if ( qt_iteratorprivate_dict->isEmpty() ) {
- delete qt_iteratorprivate_dict;
- qt_iteratorprivate_dict = 0;
- }
- }
-}
-
-/*!
- Prefix ++. Makes the next item the new current item and returns
- it. Returns 0 if the current item is the last item or the
- TQListView is 0.
-*/
-
-TQListViewItemIterator &TQListViewItemIterator::operator++()
-{
- do {
- if ( !curr )
- return *this;
-
- TQListViewItem *item = curr->firstChild();
- if ( !item ) {
- while ( (item = curr->nextSibling()) == 0 ) {
- curr = curr->parent();
- if ( curr == 0 )
- break;
- }
- }
- curr = item;
- // if the next one doesn't match the flags we try one more ahead
- } while ( curr && !matchesFlags( curr ) );
- return *this;
-}
-
-/*!
- \overload
-
- Postfix ++. Makes the next item the new current item and returns
- the item that \e was the current item.
-*/
-
-const TQListViewItemIterator TQListViewItemIterator::operator++( int )
-{
- TQListViewItemIterator oldValue = *this;
- ++( *this );
- return oldValue;
-}
-
-/*!
- Sets the current item to the item \a j positions after the current
- item. If that item is beyond the last item, the current item is
- set to 0. Returns the current item.
-*/
-
-TQListViewItemIterator &TQListViewItemIterator::operator+=( int j )
-{
- while ( curr && j-- )
- ++( *this );
-
- return *this;
-}
-
-/*!
- Prefix --. Makes the previous item the new current item and
- returns it. Returns 0 if the current item is the first item or the
- TQListView is 0.
-*/
-
-TQListViewItemIterator &TQListViewItemIterator::operator--()
-{
- if ( !curr )
- return *this;
-
- if ( !curr->parent() ) {
- // we are in the first depth
- if ( curr->listView() ) {
- if ( curr->listView()->firstChild() != curr ) {
- // go the previous sibling
- TQListViewItem *i = curr->listView()->firstChild();
- while ( i && i->siblingItem != curr )
- i = i->siblingItem;
-
- curr = i;
-
- if ( i && i->firstChild() ) {
- // go to the last child of this item
- TQListViewItemIterator it( curr->firstChild() );
- for ( ; it.current() && it.current()->parent(); ++it )
- curr = it.current();
- }
-
- if ( curr && !matchesFlags( curr ) )
- --( *this );
-
- return *this;
- } else {
- //we are already the first child of the list view, so it's over
- curr = 0;
- return *this;
- }
- } else
- return *this;
- } else {
- TQListViewItem *parent = curr->parent();
-
- if ( curr != parent->firstChild() ) {
- // go to the previous sibling
- TQListViewItem *i = parent->firstChild();
- while ( i && i->siblingItem != curr )
- i = i->siblingItem;
-
- curr = i;
-
- if ( i && i->firstChild() ) {
- // go to the last child of this item
- TQListViewItemIterator it( curr->firstChild() );
- for ( ; it.current() && it.current()->parent() != parent; ++it )
- curr = it.current();
- }
-
- if ( curr && !matchesFlags( curr ) )
- --( *this );
-
- return *this;
- } else {
- // make our parent the current item
- curr = parent;
-
- if ( curr && !matchesFlags( curr ) )
- --( *this );
-
- return *this;
- }
- }
-}
-
-/*!
- \overload
-
- Postfix --. Makes the previous item the new current item and
- returns the item that \e was the current item.
-*/
-
-const TQListViewItemIterator TQListViewItemIterator::operator--( int )
-{
- TQListViewItemIterator oldValue = *this;
- --( *this );
- return oldValue;
-}
-
-/*!
- Sets the current item to the item \a j positions before the
- current item. If that item is before the first item, the current
- item is set to 0. Returns the current item.
-*/
-
-TQListViewItemIterator &TQListViewItemIterator::operator-=( int j )
-{
- while ( curr && j-- )
- --( *this );
-
- return *this;
-}
-
-/*!
- Dereference operator. Returns a reference to the current item. The
- same as current().
-*/
-
-TQListViewItem* TQListViewItemIterator::operator*()
-{
- if ( curr != 0 && !matchesFlags( curr ) )
- tqWarning( "TQListViewItemIterator::operator*() curr out of sync" );
- return curr;
-}
-
-/*!
- Returns iterator's current item.
-*/
-
-TQListViewItem *TQListViewItemIterator::current() const
-{
- if ( curr != 0 && !matchesFlags( curr ) )
- tqWarning( "TQListViewItemIterator::current() curr out of sync" );
- return curr;
-}
-
-TQListViewItemIteratorPrivate* TQListViewItemIterator::d() const
-{
- return qt_iteratorprivate_dict ?
- qt_iteratorprivate_dict->find( (void *)this ) : 0;
-}
-
-void TQListViewItemIterator::init( int iteratorFlags )
-{
- // makes new global ptrdict if it doesn't exist
- if ( !qt_iteratorprivate_dict ) {
- qt_iteratorprivate_dict = new TQPtrDict<TQListViewItemIteratorPrivate>;
- qt_iteratorprivate_dict->setAutoDelete( TRUE );
- }
-
- // sets flag, or inserts new TQListViewItemIteratorPrivate with flag
- if ( d() )
- d()->flags = iteratorFlags;
- else
- qt_iteratorprivate_dict->insert( this, new TQListViewItemIteratorPrivate( iteratorFlags ) );
-}
-
-
-/*
- Adds this iterator to its TQListView's list of iterators.
-*/
-
-void TQListViewItemIterator::addToListView()
-{
- if ( listView ) {
- if ( !listView->d->iterators ) {
- listView->d->iterators = new TQPtrList<TQListViewItemIterator>;
- TQ_CHECK_PTR( listView->d->iterators );
- }
- listView->d->iterators->append( this );
- }
-}
-
-/*
- This function is called to notify the iterator that the current
- item has been deleted, and sets the current item point to another
- (valid) item or 0.
-*/
-
-void TQListViewItemIterator::currentRemoved()
-{
- if ( !curr ) return;
-
- if ( curr->parent() )
- curr = curr->parent();
- else if ( curr->nextSibling() )
- curr = curr->nextSibling();
- else if ( listView && listView->firstChild() &&
- listView->firstChild() != curr )
- curr = listView->firstChild();
- else
- curr = 0;
-}
-
-/*
- returns TRUE if the item \a item matches all of the flags set for the iterator
-*/
-bool TQListViewItemIterator::matchesFlags( const TQListViewItem *item ) const
-{
- if ( !item )
- return FALSE;
-
- int flags = d() ? d()->flags : 0;
-
- if ( flags == 0 )
- return TRUE;
-
- if ( flags & Visible && !item->isVisible() )
- return FALSE;
- if ( flags & Invisible && item->isVisible() )
- return FALSE;
- if ( flags & Selected && !item->isSelected() )
- return FALSE;
- if ( flags & Unselected && item->isSelected() )
- return FALSE;
- if ( flags & Selectable && !item->isSelectable() )
- return FALSE;
- if ( flags & NotSelectable && item->isSelectable() )
- return FALSE;
- if ( flags & DragEnabled && !item->dragEnabled() )
- return FALSE;
- if ( flags & DragDisabled && item->dragEnabled() )
- return FALSE;
- if ( flags & DropEnabled && !item->dropEnabled() )
- return FALSE;
- if ( flags & DropDisabled && item->dropEnabled() )
- return FALSE;
- if ( flags & Expandable && !item->isExpandable() )
- return FALSE;
- if ( flags & NotExpandable && item->isExpandable() )
- return FALSE;
- if ( flags & Checked && !isChecked( item ) )
- return FALSE;
- if ( flags & NotChecked && isChecked( item ) )
- return FALSE;
-
- return TRUE;
-}
-
-/*
- we want the iterator to check TQCheckListItems as well, so we provide this convenience function
- that checks if the rtti() is 1 which means TQCheckListItem and if isOn is TRUE, returns FALSE otherwise.
-*/
-bool TQListViewItemIterator::isChecked( const TQListViewItem *item ) const
-{
- if ( item->rtti() == 1 )
- return ((const TQCheckListItem*)item)->isOn();
- else return FALSE;
-}
-
-void TQListView::handleItemChange( TQListViewItem *old, bool shift, bool control )
-{
- if ( d->selectionMode == Single ) {
- // nothing
- } else if ( d->selectionMode == Extended ) {
- if ( shift ) {
- selectRange( d->selectAnchor ? d->selectAnchor : old,
- d->focusItem, FALSE, TRUE, (d->selectAnchor && !control) ? TRUE : FALSE );
- } else if ( !control ) {
- bool block = signalsBlocked();
- blockSignals( TRUE );
- selectAll( FALSE );
- blockSignals( block );
- setSelected( d->focusItem, TRUE );
- }
- } else if ( d->selectionMode == Multi ) {
- if ( shift )
- selectRange( old, d->focusItem, TRUE, FALSE );
- }
-}
-
-void TQListView::startRename()
-{
- if ( !currentItem() )
- return;
- currentItem()->startRename( d->pressedColumn );
- d->buttonDown = FALSE;
-}
-
-/* unselects items from to, including children, returns TRUE if any items were unselected */
-bool TQListView::clearRange( TQListViewItem *from, TQListViewItem *to, bool includeFirst )
-{
- if ( !from || !to )
- return FALSE;
-
- // Swap
- if ( from->itemPos() > to->itemPos() ) {
- TQListViewItem *temp = from;
- from = to;
- to = temp;
- }
-
- // Start on second?
- if ( !includeFirst ) {
- TQListViewItem *below = (from == to) ? from : from->itemBelow();
- if ( below )
- from = below;
- }
-
- // Clear items <from, to>
- bool changed = FALSE;
-
- TQListViewItemIterator it( from );
- while ( it.current() ) {
- if ( it.current()->isSelected() ) {
- it.current()->setSelected( FALSE );
- changed = TRUE;
- }
- if ( it.current() == to )
- break;
- ++it;
- }
-
- // NOTE! This function does _not_ emit
- // any signals about selection changed
- return changed;
-}
-
-void TQListView::selectRange( TQListViewItem *from, TQListViewItem *to, bool invert, bool includeFirst, bool clearSel )
-{
- if ( !from || !to )
- return;
- if ( from == to && !includeFirst )
- return;
- bool swap = FALSE;
- if ( to == from->itemAbove() )
- swap = TRUE;
- if ( !swap && from != to && from != to->itemAbove() ) {
- TQListViewItemIterator it( from );
- bool found = FALSE;
- for ( ; it.current(); ++it ) {
- if ( it.current() == to ) {
- found = TRUE;
- break;
- }
- }
- if ( !found )
- swap = TRUE;
- }
- if ( swap ) {
- TQListViewItem *i = from;
- from = to;
- to = i;
- if ( !includeFirst )
- to = to->itemAbove();
- } else {
- if ( !includeFirst )
- from = from->itemBelow();
- }
-
- bool changed = FALSE;
- if ( clearSel ) {
- TQListViewItemIterator it( firstChild() );
- for ( ; it.current(); ++it ) {
- if ( it.current()->selected ) {
- it.current()->setSelected( FALSE );
- changed = TRUE;
- }
- }
- it = TQListViewItemIterator( to );
- for ( ; it.current(); ++it ) {
- if ( it.current()->selected ) {
- it.current()->setSelected( FALSE );
- changed = TRUE;
- }
- }
- }
-
- for ( TQListViewItem *i = from; i; i = i->itemBelow() ) {
- if ( !invert ) {
- if ( !i->selected && i->isSelectable() ) {
- i->setSelected( TRUE );
- changed = TRUE;
- }
- } else {
- bool sel = !i->selected;
- if ( ( (bool)i->selected != sel && sel && i->isSelectable() ) || !sel ) {
- i->setSelected( sel );
- changed = TRUE;
- }
- }
- if ( i == to )
- break;
- }
- if ( changed ) {
- d->useDoubleBuffer = TRUE;
- triggerUpdate();
- emit selectionChanged();
- }
-}
-
-/* clears selection from anchor to old, selects from anchor to new, does not emit selectionChanged on change */
-bool TQListView::selectRange( TQListViewItem *newItem, TQListViewItem *oldItem, TQListViewItem *anchorItem )
-{
- if ( !newItem || !oldItem || !anchorItem )
- return FALSE;
-
- int anchorPos = anchorItem ? anchorItem->itemPos() : 0,
- oldPos = oldItem ? oldItem->itemPos() : 0,
- newPos = newItem->itemPos();
- TQListViewItem *top=0, *bottom=0;
- if ( anchorPos > newPos ) {
- top = newItem;
- bottom = anchorItem;
- } else {
- top = anchorItem;
- bottom = newItem;
- }
-
- // removes the parts of the old selection that will no longer be selected
- bool changed = FALSE;
- int topPos = top ? top->itemPos() : 0,
- bottomPos = bottom ? bottom->itemPos() : 0;
- if ( !(oldPos > topPos && oldPos < bottomPos) ) {
- if ( oldPos < topPos )
- changed = clearRange( oldItem, top );
- else
- changed = clearRange( bottom, oldItem );
- }
-
- // selects the new (not already selected) items
- TQListViewItemIterator lit( top );
- for ( ; lit.current(); ++lit ) {
- if ( (bool)lit.current()->selected != d->select ) {
- lit.current()->setSelected( d->select );
- changed = TRUE;
- }
- // Include bottom, then break
- if ( lit.current() == bottom )
- break;
- }
-
- return changed;
-}
-
-
-/*!
- Finds the first list view item in column \a column, that matches
- \a text and returns the item, or returns 0 of no such item could
- be found.
- The search starts from the current item if the current item exists,
- otherwise it starts from the first list view item. After reaching
- the last item the search continues from the first item.
- Pass OR-ed together \l TQt::StringComparisonMode values
- in the \a compare flag, to control how the matching is performed.
- The default comparison mode is case-sensitive, exact match.
-*/
-
-TQListViewItem *TQListView::findItem( const TQString& text, int column,
- ComparisonFlags compare ) const
-{
- if (text.isEmpty() && !(compare & ExactMatch))
- return 0;
-
- if ( compare == CaseSensitive || compare == 0 )
- compare |= ExactMatch;
-
- TQString itmtxt;
- TQString comtxt = text;
- if ( !(compare & CaseSensitive) )
- comtxt = comtxt.lower();
-
- TQListViewItemIterator it( d->focusItem ? d->focusItem : firstChild() );
- TQListViewItem *sentinel = 0;
- TQListViewItem *item;
- TQListViewItem *beginsWithItem = 0;
- TQListViewItem *endsWithItem = 0;
- TQListViewItem *containsItem = 0;
-
- for ( int pass = 0; pass < 2; pass++ ) {
- while ( (item = it.current()) != sentinel ) {
- itmtxt = item->text( column );
- if ( !(compare & CaseSensitive) )
- itmtxt = itmtxt.lower();
-
- if ( compare & ExactMatch && itmtxt == comtxt )
- return item;
- if ( compare & BeginsWith && !beginsWithItem && itmtxt.startsWith( comtxt ) )
- beginsWithItem = containsItem = item;
- if ( compare & EndsWith && !endsWithItem && itmtxt.endsWith( comtxt ) )
- endsWithItem = containsItem = item;
- if ( compare & Contains && !containsItem && itmtxt.contains( comtxt ) )
- containsItem = item;
- ++it;
- }
-
- it = TQListViewItemIterator( firstChild() );
- sentinel = d->focusItem ? d->focusItem : firstChild();
- }
-
- // Obey the priorities
- if ( beginsWithItem )
- return beginsWithItem;
- else if ( endsWithItem )
- return endsWithItem;
- else if ( containsItem )
- return containsItem;
- return 0;
-}
-
-/*! \reimp */
-void TQListView::windowActivationChange( bool oldActive )
-{
- if ( oldActive && d->scrollTimer )
- d->scrollTimer->stop();
- if ( palette().active() != palette().inactive() )
- viewport()->update();
- TQScrollView::windowActivationChange( oldActive );
-}
-
-/*!
- Hides the column specified at \a column. This is a convenience
- function that calls setColumnWidth( \a column, 0 ).
-
- Note: The user may still be able to resize the hidden column using
- the header handles. To prevent this, call setResizeEnabled(FALSE,
- \a column) on the list views header.
-
- \sa setColumnWidth()
-*/
-
-void TQListView::hideColumn( int column )
-{
- setColumnWidth( column, 0 );
-}
-
-/*! Adjusts the column \a col to its preferred width */
-
-void TQListView::adjustColumn( int col )
-{
- if ( col < 0 || col > (int)d->column.count() - 1 || d->h->isStretchEnabled( col ) )
- return;
-
- int oldw = d->h->sectionSize( col );
-
- int w = d->h->sectionSizeHint( col, fontMetrics() ).width();
- if ( d->h->iconSet( col ) )
- w += d->h->iconSet( col )->pixmap().width();
- w = TQMAX( w, 20 );
- TQFontMetrics fm( fontMetrics() );
- TQListViewItem* item = firstChild();
- int rootDepth = rootIsDecorated() ? treeStepSize() : 0;
- while ( item ) {
- int iw = item->width( fm, this, col );
- if ( 0 == col )
- iw += itemMargin() + rootDepth + item->depth()*treeStepSize() - 1;
- w = TQMAX( w, iw );
- item = item->itemBelow();
- }
- w = TQMAX( w, TQApplication::globalStrut().width() );
-
- d->h->adjustHeaderSize( oldw - w );
- if (oldw != w) {
- d->fullRepaintOnComlumnChange = TRUE;
- d->h->resizeSection( col, w );
- emit d->h->sizeChange( col, oldw, w);
- }
-}
-
-#endif // TQT_NO_LISTVIEW