QTreeWidgetItemIterator Class

The QTreeWidgetItemIterator class provides a way to iterate over the items in a QTreeWidget instance. More...

Header: #include <QTreeWidgetItemIterator>
qmake: QT += widgets

Public Types

enum IteratorFlag { All, Hidden, NotHidden, Selected, ..., UserFlag }
flags IteratorFlags

Public Functions

QTreeWidgetItemIterator(QTreeWidgetItem *item, QTreeWidgetItemIterator::IteratorFlags flags = All)
QTreeWidgetItemIterator(QTreeWidget *widget, QTreeWidgetItemIterator::IteratorFlags flags = All)
QTreeWidgetItemIterator(const QTreeWidgetItemIterator &it)
QTreeWidgetItemIterator & operator=(const QTreeWidgetItemIterator &it)
~QTreeWidgetItemIterator()
QTreeWidgetItem * operator*() const
QTreeWidgetItemIterator & operator++()
const QTreeWidgetItemIterator operator++(int)
QTreeWidgetItemIterator & operator+=(int n)
QTreeWidgetItemIterator & operator--()
const QTreeWidgetItemIterator operator--(int)
QTreeWidgetItemIterator & operator-=(int n)

Detailed Description

The iterator will walk the items in a pre-order traversal order, thus visiting the parent node before it continues to the child nodes.

For example, the following code examples each item in a tree, checking the text in the first column against a user-specified search string:

    QTreeWidgetItemIterator it(treeWidget);
    while (*it) {
        if ((*it)->text(0) == itemText)
            (*it)->setSelected(true);
        ++it;
    }

It is also possible to filter out certain types of node by passing certain flags to the constructor of QTreeWidgetItemIterator.

See also QTreeWidget, Model/View Programming, and QTreeWidgetItem.

Member Type Documentation

enum QTreeWidgetItemIterator::IteratorFlagflags QTreeWidgetItemIterator::IteratorFlags

These flags can be passed to a QTreeWidgetItemIterator constructor (OR-ed together if more than one is used), so that the iterator will only iterate over items that match the given flags.

Constant Value
QTreeWidgetItemIterator::All 0x00000000
QTreeWidgetItemIterator::Hidden 0x00000001
QTreeWidgetItemIterator::NotHidden 0x00000002
QTreeWidgetItemIterator::Selected 0x00000004
QTreeWidgetItemIterator::Unselected 0x00000008
QTreeWidgetItemIterator::Selectable 0x00000010
QTreeWidgetItemIterator::NotSelectable 0x00000020
QTreeWidgetItemIterator::DragEnabled 0x00000040
QTreeWidgetItemIterator::DragDisabled 0x00000080
QTreeWidgetItemIterator::DropEnabled 0x00000100
QTreeWidgetItemIterator::DropDisabled 0x00000200
QTreeWidgetItemIterator::HasChildren 0x00000400
QTreeWidgetItemIterator::NoChildren 0x00000800
QTreeWidgetItemIterator::Checked 0x00001000
QTreeWidgetItemIterator::NotChecked 0x00002000
QTreeWidgetItemIterator::Enabled 0x00004000
QTreeWidgetItemIterator::Disabled 0x00008000
QTreeWidgetItemIterator::Editable 0x00010000
QTreeWidgetItemIterator::NotEditable 0x00020000
QTreeWidgetItemIterator::UserFlag 0x01000000

The IteratorFlags type is a typedef for QFlags<IteratorFlag>. It stores an OR combination of IteratorFlag values.

Member Function Documentation

QTreeWidgetItemIterator::QTreeWidgetItemIterator(QTreeWidgetItem *item, QTreeWidgetItemIterator::IteratorFlags flags = All)

Constructs an iterator for the given item that uses the specified flags to determine which items are found during iteration. The iterator is set to point to item, or the next matching item if item doesn't match the flags.

See also QTreeWidgetItemIterator::IteratorFlag.

QTreeWidgetItemIterator::QTreeWidgetItemIterator(QTreeWidget *widget, QTreeWidgetItemIterator::IteratorFlags flags = All)

Constructs an iterator for the given widget that uses the specified flags to determine which items are found during iteration. The iterator is set to point to the first top-level item contained in the widget, or the next matching item if the top-level item doesn't match the flags.

See also QTreeWidgetItemIterator::IteratorFlag.

QTreeWidgetItemIterator::QTreeWidgetItemIterator(const QTreeWidgetItemIterator &it)

Constructs an iterator for the same QTreeWidget as it. The current iterator item is set to point on the current item of it.

QTreeWidgetItemIterator &QTreeWidgetItemIterator::operator=(const QTreeWidgetItemIterator &it)

Assignment. Makes a copy of it and returns a reference to its iterator.

QTreeWidgetItemIterator::~QTreeWidgetItemIterator()

Destroys the iterator.

QTreeWidgetItem *QTreeWidgetItemIterator::operator*() const

Dereference operator. Returns a pointer to the current item.

QTreeWidgetItemIterator &QTreeWidgetItemIterator::operator++()

The prefix ++ operator (++it) advances the iterator to the next matching item and returns a reference to the resulting iterator. Sets the current pointer to nullptr if the current item is the last matching item.

const QTreeWidgetItemIterator QTreeWidgetItemIterator::operator++(int)

The postfix ++ operator (it++) advances the iterator to the next matching item and returns an iterator to the previously current item.

QTreeWidgetItemIterator &QTreeWidgetItemIterator::operator+=(int n)

Makes the iterator go forward by n matching items. (If n is negative, the iterator goes backward.)

If the current item is beyond the last item, the current item pointer is set to nullptr. Returns the resulting iterator.

QTreeWidgetItemIterator &QTreeWidgetItemIterator::operator--()

The prefix -- operator (--it) advances the iterator to the previous matching item and returns a reference to the resulting iterator. Sets the current pointer to nullptr if the current item is the first matching item.

const QTreeWidgetItemIterator QTreeWidgetItemIterator::operator--(int)

The postfix -- operator (it--) makes the preceding matching item current and returns an iterator to the previously current item.

QTreeWidgetItemIterator &QTreeWidgetItemIterator::operator-=(int n)

Makes the iterator go backward by n matching items. (If n is negative, the iterator goes forward.)

If the current item is ahead of the last item, the current item pointer is set to nullptr. Returns the resulting iterator.

© The Qt Company Ltd
Licensed under the GNU Free Documentation License, Version 1.3.
https://doc.qt.io/qt-5.13/qtreewidgetitemiterator.html