Qt
Internal/Contributor docs for the Qt SDK. <b>Note:</b> These are NOT official API docs; those are found <a href='https://doc.qt.io/'>here</a>.
Loading...
Searching...
No Matches
mainwindow.cpp
Go to the documentation of this file.
1// Copyright (C) 2016 The Qt Company Ltd.
2// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR BSD-3-Clause
3
4#include <QtWidgets>
5
6#include "mainwindow.h"
7
9{
10 QMenu *fileMenu = new QMenu(tr("&File"));
11
12 QAction *quitAction = fileMenu->addAction(tr("E&xit"));
13 quitAction->setShortcut(tr("Ctrl+Q"));
14
15 QMenu *itemsMenu = new QMenu(tr("&Items"));
16
17 insertAction = itemsMenu->addAction(tr("&Insert Item"));
18 removeAction = itemsMenu->addAction(tr("&Remove Item"));
19 removeAction->setEnabled(false);
20 itemsMenu->addSeparator();
21 ascendingAction = itemsMenu->addAction(tr("Sort in &Ascending Order"));
22 descendingAction = itemsMenu->addAction(tr("Sort in &Descending Order"));
23 autoSortAction = itemsMenu->addAction(tr("&Automatically Sort Items"));
24 autoSortAction->setCheckable(true);
25 itemsMenu->addSeparator();
26 QAction *findItemsAction = itemsMenu->addAction(tr("&Find Items"));
27 findItemsAction->setShortcut(tr("Ctrl+F"));
28
29 menuBar()->addMenu(fileMenu);
30 menuBar()->addMenu(itemsMenu);
31
32/* For convenient quoting:
34 QTreeWidget *treeWidget = new QTreeWidget(this);
36*/
37 treeWidget = new QTreeWidget(this);
41 QStringList headers;
42 headers << tr("Subject") << tr("Default");
45
46 connect(quitAction, &QAction::triggered, this, &QWidget::close);
47 connect(ascendingAction, &QAction::triggered, this, &MainWindow::sortAscending);
48 connect(autoSortAction, &QAction::triggered, this, &MainWindow::updateSortItems);
49 connect(descendingAction, &QAction::triggered, this, &MainWindow::sortDescending);
50 connect(findItemsAction, &QAction::triggered, this, &MainWindow::findItems);
51 connect(insertAction, &QAction::triggered, this, &MainWindow::insertItem);
52 connect(removeAction, &QAction::triggered, this, &MainWindow::removeItem);
55
56 setupTreeItems();
58
60 setWindowTitle(tr("Tree Widget"));
61}
62
63void MainWindow::setupTreeItems()
64{
67 cities->setText(0, tr("Cities"));
68 QTreeWidgetItem *osloItem = new QTreeWidgetItem(cities);
69 osloItem->setText(0, tr("Oslo"));
70 osloItem->setText(1, tr("Yes"));
72
73 (new QTreeWidgetItem(cities))->setText(0, tr("Stockholm"));
74 (new QTreeWidgetItem(cities))->setText(0, tr("Helsinki"));
75 (new QTreeWidgetItem(cities))->setText(0, tr("Copenhagen"));
76
78 QTreeWidgetItem *planets = new QTreeWidgetItem(treeWidget, cities);
80 planets->setText(0, tr("Planets"));
82 (new QTreeWidgetItem(planets))->setText(0, tr("Mercury"));
83 (new QTreeWidgetItem(planets))->setText(0, tr("Venus"));
84
85 QTreeWidgetItem *earthItem = new QTreeWidgetItem(planets);
86 earthItem->setText(0, tr("Earth"));
87 earthItem->setText(1, tr("Yes"));
88
89 (new QTreeWidgetItem(planets))->setText(0, tr("Mars"));
90 (new QTreeWidgetItem(planets))->setText(0, tr("Jupiter"));
91 (new QTreeWidgetItem(planets))->setText(0, tr("Saturn"));
92 (new QTreeWidgetItem(planets))->setText(0, tr("Uranus"));
93 (new QTreeWidgetItem(planets))->setText(0, tr("Neptune"));
94 (new QTreeWidgetItem(planets))->setText(0, tr("Pluto"));
95}
96
97void MainWindow::findItems()
98{
99 QString itemText = QInputDialog::getText(this, tr("Find Items"),
100 tr("Text to find (including wildcards):"));
101
102 if (itemText.isEmpty())
103 return;
104
105 const QList<QTreeWidgetItem *> items = treeWidget->selectedItems();
106 for (QTreeWidgetItem *item : items)
107 item->setSelected(false);
108
110 const QList<QTreeWidgetItem *> found = treeWidget->findItems(
111 itemText, Qt::MatchWildcard);
112
113 for (QTreeWidgetItem *item : found) {
114 item->setSelected(true);
115 // Show the item->text(0) for each item.
116 }
118}
119
120void MainWindow::insertItem()
121{
122 QTreeWidgetItem *currentItem = treeWidget->currentItem();
123
124 if (!currentItem)
125 return;
126
127 QString itemText = QInputDialog::getText(this, tr("Insert Item"),
128 tr("Input text for the new item:"));
129
130 if (itemText.isEmpty())
131 return;
132
134 QTreeWidgetItem *parent = currentItem->parent();
135 QTreeWidgetItem *newItem;
136 if (parent)
137 newItem = new QTreeWidgetItem(parent, treeWidget->currentItem());
138 else
142
143 newItem->setText(0, itemText);
144}
145
146void MainWindow::removeItem()
147{
148 QTreeWidgetItem *currentItem = treeWidget->currentItem();
149
150 if (!currentItem)
151 return;
152
154 QTreeWidgetItem *parent = currentItem->parent();
155 int index;
156
157 if (parent) {
158 index = parent->indexOfChild(treeWidget->currentItem());
159 delete parent->takeChild(index);
160 } else {
164 }
166}
167
168void MainWindow::sortAscending()
169{
171}
172
173void MainWindow::sortDescending()
174{
176}
177
179{
180 insertAction->setEnabled(current != 0);
181 removeAction->setEnabled(current != 0);
182}
183
184void MainWindow::updateSortItems()
185{
186 ascendingAction->setEnabled(!autoSortAction->isChecked());
187 descendingAction->setEnabled(!autoSortAction->isChecked());
188
189 treeWidget->setSortingEnabled(autoSortAction->isChecked());
190}
void updateMenus()
The QAction class provides an abstraction for user commands that can be added to different user inter...
Definition qaction.h:30
void triggered(bool checked=false)
This signal is emitted when an action is activated by the user; for example, when the user clicks a m...
void setEnabled(bool)
Definition qaction.cpp:927
void setSelected(bool selected)
If selected is true and this item is selectable, this item is selected; otherwise,...
static QString getText(QWidget *parent, const QString &title, const QString &label, QLineEdit::EchoMode echo=QLineEdit::Normal, const QString &text=QString(), bool *ok=nullptr, Qt::WindowFlags flags=Qt::WindowFlags(), Qt::InputMethodHints inputMethodHints=Qt::ImhNone)
Static convenience function to get a string from the user.
void setCentralWidget(QWidget *widget)
Sets the given widget to be the main window's central widget.
QAction * addMenu(QMenu *menu)
Appends menu to the menu bar.
Definition qmenubar.cpp:768
The QMenu class provides a menu widget for use in menu bars, context menus, and other popup menus.
Definition qmenu.h:26
void addAction(QAction *action)
Appends the action action to this widget's list of actions.
Definition qwidget.cpp:3117
QObject * parent() const
Returns a pointer to the parent object.
Definition qobject.h:346
static QMetaObject::Connection connect(const QObject *sender, const char *signal, const QObject *receiver, const char *member, Qt::ConnectionType=Qt::AutoConnection)
\threadsafe
Definition qobject.cpp:2960
\inmodule QtCore
\macro QT_RESTRICTED_CAST_FROM_ASCII
Definition qstring.h:129
bool isEmpty() const noexcept
Returns true if the string has no characters; otherwise returns false.
Definition qstring.h:192
void setSortingEnabled(bool enable)
The QTreeWidgetItem class provides an item for use with the QTreeWidget convenience class.
Definition qtreewidget.h:23
QTreeWidgetItem * parent() const
Returns the item's parent.
The QTreeWidget class provides a tree view that uses a predefined tree model.
void sortItems(int column, Qt::SortOrder order)
Sorts the items in the widget in the specified order by the values in the given column.
QList< QTreeWidgetItem * > findItems(const QString &text, Qt::MatchFlags flags, int column=0) const
Returns a list of items that match the given text, using the given flags, in the given column.
QTreeWidgetItem * takeTopLevelItem(int index)
Removes the top-level item at the given index in the tree and returns it, otherwise returns \nullptr;...
QList< QTreeWidgetItem * > selectedItems() const
Returns a list of all selected non-hidden items.
void currentItemChanged(QTreeWidgetItem *current, QTreeWidgetItem *previous)
This signal is emitted when the current item changes.
int indexOfTopLevelItem(QTreeWidgetItem *item) const
Returns the index of the given top-level item, or -1 if the item cannot be found.
QTreeWidgetItem * currentItem() const
Returns the current item in the tree widget.
void setColumnCount(int columns)
void setHeaderLabels(const QStringList &labels)
Adds a column in the header for each item in the labels list, and sets the label for each column.
bool close()
Closes this widget.
Definition qwidget.cpp:8562
void insertAction(QAction *before, QAction *action)
Inserts the action action to this widget's list of actions, before the action before.
Definition qwidget.cpp:3142
void setWindowTitle(const QString &)
Definition qwidget.cpp:6105
@ DescendingOrder
Definition qnamespace.h:123
@ AscendingOrder
Definition qnamespace.h:122
@ MatchWildcard
GLuint index
[2]
#define tr(X)
QGraphicsItem * item
QList< QTreeWidgetItem * > items
QTreeWidget * treeWidget
[0]
insertRed setText("insert red text")
QMenuBar * menuBar
[0]