Qt5 C++14教程--菜单和工具条

在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();
}

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();
}

这是主文件。

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();
}

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();
}

这是主文件。

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();
}

这是主文件。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值