在Qt5 C++编程教程的这一部分,我们谈谈Qt5应用程序中的菜单和工具条。
菜单栏是GUI应用程序的一个常见部分。它是一组位于不同地方的命令,称为菜单。菜单将我们可以在一个应用程序中使用的命令分组。工具栏提供了对最常用的命令的快速访问。
Qt5简单的菜单
以下是一个简单的菜单的示例代码。
simple_menu.h
#pragma once
#include <QMainWindow>
#include <QApplication>
class SimpleMenu : public QMainWindow {
public:
SimpleMenu(QWidget *parent = nullptr);
};
这是我们代码示例的头文件。
simple_menu.cpp
#include <QMenu>
#include <QMenuBar>
#include "simple_menu.h"
SimpleMenu::SimpleMenu(QWidget *parent)
: QMainWindow(parent) {
auto *quit = new QAction("&Quit", this);
QMenu *file = menuBar()->addMenu("&File");
file->addAction(quit);
connect(quit, &QAction::triggered, qApp, QApplication::quit);
}
我们有一个菜单栏、一个菜单和一个动作。为了使用菜单,我们必须从QMainWindow小部件继承。
auto *quit = new QAction("&Quit", this);
这一行代码创建了一个QAction。每个QMenu都有一个或多个动作对象。
QMenu *file;file = menuBar()->addMenu("&File");
我们创建了一个QMenu对象。
file->addAction(quit);
我们使用addAction方法将一个动作放置在菜单中。
connect(quit, &QAction::triggered, qApp, QApplication::quit);
当我们从菜单中选择这个选项时,应用程序就会退出。
main.cpp
#include "simple_menu.h"
int main(int argc, char *argv[]) {
QApplication app(argc, argv);
SimpleMenu window;
window.resize(350, 250);
window.setWindowTitle("Simple menu");
window.show();
return app.exec();
}
![](https://img-blog.csdnimg.cn/img_convert/bb10521623a70cc2e750d8e5cdc9cfc9.webp?x-oss-process=image/format,png)
Qt5图标,快捷键和分隔符
在下面的例子中,我们进一步增强了之前的应用程序。我们为菜单添加图标,使用快捷键和分隔符。
another_menu.cpp
#include <QMenu>
#include <QMenuBar>
#include "another_menu.h"
AnotherMenu::AnotherMenu(QWidget *parent)
: QMainWindow(parent) {
QPixmap newpix("new.png");
QPixmap openpix("open.png");
QPixmap quitpix("quit.png");
auto *newa = new QAction(newpix, "&New", this);
auto *open = new QAction(openpix, "&Open", this);
auto *quit = new QAction(quitpix, "&Quit", this);
quit->setShortcut(tr("CTRL+Q"));
QMenu *file = menuBar()->addMenu("&File");
file->addAction(newa);
file->addAction(open);
file->addSeparator();
file->addAction(quit);
qApp->setAttribute(Qt::AA_DontShowIconsInMenus, false);
connect(quit, &QAction::triggered, qApp, &QApplication::quit);
}
在我们的例子中,我们有一个菜单和三个动作。只有退出动作在选择时才会实际执行操作。我们还创建了一个分隔符和一个CTRL+Q快捷键,该快捷键终止应用程序。
QPixmap newpix("new.png");
QPixmap openpix("open.png");
QPixmap quitpix("quit.png");
这些是我们在菜单中使用的图像。请注意,一些桌面环境可能不会在菜单中显示图像。
auto *newa = new QAction(newpix, "&New", this);
auto *open = new QAction(openpix, "&Open", this);
auto *quit = new QAction(quitpix, "&Quit", this);
在这段代码中,我们使用带有Pixmap的QAction构造函数作为第一个参数。
quit->setShortcut(tr("CTRL+Q"));
在这里,我们创建了一个键盘快捷键。通过按下此快捷键,我们将运行退出操作,该操作将退出应用程序。
file->addSeparator();
我们创建了一个分隔符。分隔符是一条水平线,使我们能够将菜单动作分组成一些逻辑组。
qApp->setAttribute(Qt::AA_DontShowIconsInMenus, false);
在某些环境中,默认情况下不显示菜单图标。在这种情况下,我们可以禁用Qt :: AA_DontShowIconsInMenus属性。
main.cpp
#include "another_menu.h"
int main(int argc, char *argv[]) {
QApplication app(argc, argv);
AnotherMenu window;
window.resize(350, 250);
window.setWindowTitle("Another menu");
window.show();
return app.exec();
}
这是主文件。
![](https://img-blog.csdnimg.cn/img_convert/11cfb0e0559f9c6c46b1ad5d2c2b8ede.webp?x-oss-process=image/format,png)
Qt5可选菜单
在下面的示例中,我们创建一个可选菜单。这将是一个带有复选框的操作。该选项切换状态栏的可见性。
checkable.h
#pragma once
#include <QMainWindow>
#include <QApplication>
class Checkable : public QMainWindow {
Q_OBJECT
public:
Checkable(QWidget *parent = nullptr);
private slots:
void toggleStatusbar();
private:
QAction *viewst;
checkable.cpp
#include <QMenu>
#include <QMenuBar>
#include <QStatusBar>
#include "checkable.h"
Checkable::Checkable(QWidget *parent)
: QMainWindow(parent) {
viewst = new QAction("&View statusbar", this);
viewst->setCheckable(true);
viewst->setChecked(true);
QMenu *file = menuBar()->addMenu("&File");
file->addAction(viewst);
statusBar();
connect(viewst, &QAction::triggered, this, &Checkable::toggleStatusbar);
}
void Checkable::toggleStatusbar() {
if (viewst->isChecked()) {
statusBar()->show();
} else {
statusBar()->hide();
}
}
一个可选菜单项切换状态栏的可见性。
viewst = new QAction("&View statusbar", this);
viewst->setCheckable(true);
viewst->setChecked(true);
我们创建一个操作并使用setCheckable方法使其可选。setChecked方法使其被选中。
if (viewst->isChecked()) {
statusBar()->show();
} else {
statusBar()->hide();
}
在toggleStatusbar方法中,我们确定菜单项是否被选中,并相应地隐藏或显示状态栏。
#include "checkable.h"
int main(int argc, char *argv[]) {
QApplication app(argc, argv);
Checkable window;
window.resize(350, 250);
window.setWindowTitle("Checkable menu");
window.show();
return app.exec();
}
![](https://img-blog.csdnimg.cn/img_convert/6cfd9e1b06f7a2432ad203b4217cb2d8.webp?x-oss-process=image/format,png)
Qt5 QToolBar
QToolBar 类提供了一个可移动的面板,其中包含一组控件,可快速访问应用程序操作。
toolbar.h
#pragma once
#include <QMainWindow>
#include <QApplication>
class Toolbar : public QMainWindow {
Q_OBJECT
public:
Toolbar(QWidget *parent = nullptr);
};
toolbar.cpp
#include <QToolBar>
#include <QIcon>
#include <QAction>
#include "toolbar.h"
Toolbar::Toolbar(QWidget *parent)
: QMainWindow(parent) {
QPixmap newpix("new.png");
QPixmap openpix("open.png");
QPixmap quitpix("quit.png");
QToolBar *toolbar = addToolBar("main toolbar");
toolbar->addAction(QIcon(newpix), "New File");
toolbar->addAction(QIcon(openpix), "Open File");
toolbar->addSeparator();
QAction *quit = toolbar->addAction(QIcon(quitpix),
"Quit Application");
connect(quit, &QAction::triggered, qApp, &QApplication::quit);
}
为创建工具栏,我们从 QMainWindow 继承小部件。
QToolBar *toolbar = addToolBar("main toolbar");
addToolBar 方法创建工具栏并返回指向它的指针。
toolbar->addAction(QIcon(newpix), "New File");
toolbar->addAction(QIcon(openpix), "Open File");
toolbar->addSeparator();
这里我们向工具栏添加两个操作和一个分隔符。
main.cpp
#include "toolbar.h"
int main(int argc, char *argv[]) {
QApplication app(argc, argv);
Toolbar window;
window.resize(350, 250);
window.setWindowTitle("QToolBar");
window.show();
return app.exec();
}
这是主文件。
![](https://img-blog.csdnimg.cn/img_convert/88002b63295b6145e79a818f41d3af06.webp?x-oss-process=image/format,png)
Qt5应用程序框架
在这个C++ Qt5教程的最后,我们创建了一个应用程序框架。这个例子主要基于QMainWindow窗口小部件。
skeleton.h
#pragma once
#include <QMainWindow>
#include <QApplication>
class Skeleton : public QMainWindow {
Q_OBJECT
public:
Skeleton(QWidget *parent = nullptr);
};
skeleton.cpp
#include <QToolBar>
#include <QIcon>
#include <QAction>
#include <QMenu>
#include <QMenuBar>
#include <QStatusBar>
#include <QTextEdit>
#include "skeleton.h"
Skeleton::Skeleton(QWidget *parent)
: QMainWindow(parent) {
QPixmap newpix("new.png");
QPixmap openpix("open.png");
QPixmap quitpix("quit.png");
auto *quit = new QAction("&Quit", this);
QMenu *file = menuBar()->addMenu("&File");
file->addAction(quit);
connect(quit, &QAction::triggered, qApp, &QApplication::quit);
QToolBar *toolbar = addToolBar("main toolbar");
toolbar->addAction(QIcon(newpix), "New File");
toolbar->addAction(QIcon(openpix), "Open File");
toolbar->addSeparator();
QAction *quit2 = toolbar->addAction(QIcon(quitpix),
"Quit Application");
connect(quit2, &QAction::triggered, qApp, &QApplication::quit);
auto *edit = new QTextEdit(this);
setCentralWidget(edit);
statusBar()->showMessage("Ready");
}
这里我们创建了一个菜单栏、一个工具栏和一个状态栏。
auto *edit = new QTextEdit(this);
setCentralWidget(edit);
我们创建了一个QTextEdit小部件,并将其放置在QMainWindow小部件的中央部分。
main.cpp
#include "skeleton.h"
int main(int argc, char *argv[]) {
QApplication app(argc, argv);
Skeleton window;
window.resize(450, 350);
window.setWindowTitle("Application skeleton");
window.show();
return app.exec();
}
这是主文件。
![](https://img-blog.csdnimg.cn/img_convert/9ccdca125f5132ecc049ca5aefe55367.webp?x-oss-process=image/format,png)