本篇介绍Qt菜单栏相关操作,分为三部分:1.菜单栏相关的类介绍;2.系统菜单的生成和响应;3.弹出菜单的生成和响应;菜单栏通常只有以QMainWindow为基类的程序中才用到,以QWidget为基类的程序通常没有菜单栏。

1. 菜单相关类

  QMenuBar --菜单栏类,即下图中红色区域标记,菜单栏类给窗口提供水平菜单栏,此菜单栏占用窗口上方区域,垂直高度不变,水平宽度为窗口宽度,可随窗口大小变化而变化。如下图中“测试”,“test1”,"test2"所在的栏几位QMenuBar

  QMenu --菜单项,即下图中绿色区域,下图中“测试”,"test1","test2"都是一个独立的菜单,包含各个子菜单。QMenu还可以用来创建弹出菜单

  QAction --子菜单,即下图中蓝色区域标记的内容,一个子菜单对应一个操作。

2.系统菜单的生成和响应

2.1.使用代码添加系统菜单

示例源码:

.h文件

 1 #ifndef MAINWINDOW_H
2 #define MAINWINDOW_H
3
4 #include <QMainWindow>
5 #include <QMenuBar>
6
7 QT_BEGIN_NAMESPACE
8 namespace Ui { class MainWindow; }
9 QT_END_NAMESPACE
10
11 class MainWindow : public QMainWindow
12 {
13 Q_OBJECT
14
15 public:
16 MainWindow(QWidget *parent = nullptr);
17 ~MainWindow();
18
19 //菜单栏
20 QMenuBar *pMenuBar;
21 //菜单项
22 QMenu *pMenuTest;
23 QMenu *pMenuTest1;
24 QMenu *pMenuTest2;
25 //子菜单
26 QAction *pActionTest;
27 QAction *pActionTest1;
28 QAction *pActionTest2;
29 QAction *pActionTest3;
30 QAction *pActionTest4;
31 QAction *pActionTest5;
32 QAction *pActionTest6;
33
34 public slots:
35 //菜单响应函数
36 void OnActionTest();
37 void OnActionTest1();
38
39 private:
40 Ui::MainWindow *ui;
41 };
42 #endif // MAINWINDOW_H

.cpp文件

 1 #include "mainwindow.h"
2 #include "ui_mainwindow.h"
3 #include <QDialog>
4
5 //是否启用QMainWindow自带的菜单栏
6 //#define USE_DEFAULT_MENU_BAR
7
8 MainWindow::MainWindow(QWidget *parent)
9 : QMainWindow(parent)
10 , ui(new Ui::MainWindow)
11 {
12 ui->setupUi(this);
13
14 //指定菜单栏
15 #ifdef USE_DEFAULT_MENU_BAR
16 //添加菜单栏(此处添加为的为QMainWindow自带的菜单)
17 pMenuBar = this->menuBar();
18 #else
19 //添加自定义菜单
20 pMenuBar = new QMenuBar(this);
21 #endif
22
23 //定义菜单项
24 //(&n)代表快捷方式,当窗口获得焦点时按alt+n即可打开“测试”菜单项
25 pMenuTest = new QMenu("测试(&n)",this);
26 pMenuTest1 = new QMenu("test1",this);
27 pMenuTest2 = new QMenu("test2",this);
28
29 //定义子菜单
30 //(&s)为子菜单快捷键,当打开该菜单项后,按下‘s’键即可响应
31 pActionTest = new QAction("测试(&s)",this);
32 //新建一个带图标的菜单项,图标使用资源文件中的资源
33 pActionTest1 = new QAction(QIcon(":/new/prefix1/resource/soccer_ball.ico"),"测试1",this);
34 pActionTest2 = new QAction("测试2",this);
35 pActionTest3 = new QAction("测试3(&Y)",this);
36 pActionTest4 = new QAction("测试4",this);
37 pActionTest5 = new QAction("测试5(&M)",this);
38 pActionTest6 = new QAction("测试6",this);
39
40 //将菜单项添加到子菜单
41 pMenuTest->addAction(pActionTest);
42 pMenuTest->addAction(pActionTest1);
43 //在菜单项之间添加分割线
44 pMenuTest->addSeparator();
45 pMenuTest->addAction(pActionTest2);
46
47 pMenuTest1->addAction(pActionTest3);
48 pMenuTest1->addAction(pActionTest4);
49
50 pMenuTest2->addAction(pActionTest5);
51 pMenuTest2->addAction(pActionTest6);
52
53 //将子菜单添加到菜单栏
54 pMenuBar->addMenu(pMenuTest);
55 pMenuBar->addMenu(pMenuTest1);
56 pMenuBar->addMenu(pMenuTest2);
57
58 #ifndef USE_DEFAULT_MENU_BAR
59 //当不使用QMainWindow自带的菜单栏时,必须要加上此行
60 setMenuBar(pMenuBar);
61 #endif
62
63 //添加菜单响应函数
64 connect(pActionTest,&QAction::triggered,this,&MainWindow::OnActionTest);
65 connect(pActionTest1,&QAction::triggered,this,&MainWindow::OnActionTest);
66 }
67
68
69 //菜单响应函数
70 void MainWindow::OnActionTest()
71 {
72 QDialog dlg;
73 dlg.setWindowTitle("测试菜单响应");
74 dlg.exec();
75 }
76
77 void MainWindow::OnActionTest1()
78 {
79
80 QDialog dlg;
81 dlg.setWindowTitle("测试菜单响应");
82 dlg.exec();
83 }
84
85 MainWindow::~MainWindow()
86 {
87 delete ui;
88 }

  上面的代码中定义了两种创建系统菜单的方式:调用QMainWindow自带的菜单栏和自己新建菜单栏,由第6行定义的宏控制,显示效果相同。

  第25行为“测试”子菜单添加快捷键,当窗口获得焦点时按alt+n可展开“测试”子菜单。

  第31行为“测试”子菜单“测试”菜单项添加快捷键,当“测试”子菜单弹出后按‘s’键,程序即可做出响应。

  第33行为“测试”子菜单的“测试2”菜单项添加了图标。

  第44行为“测试”子菜单的“测试2”和“测试3”之间添加了分割线。

2.2.使用UI设计器设计系统菜单

  进入“设计”页面,进入如下图所示的界面,具体操作方法见如下两张图,注意:输入菜单名称后一定要按“Enter”键才能生效

1

Qt基础之菜单栏的更多相关文章

  1. 基于C/S架构的3D对战网络游戏C++框架 _04客户端详细设计与OpenGL、Qt基础

    本系列博客主要是以对战游戏为背景介绍3D对战网络游戏常用的开发技术以及C++高级编程技巧,有了这些知识,就可以开发出中小型游戏项目或3D工业仿真项目. 笔者将分为以下三个部分向大家介绍(每日更新): ...

  2. QT学习之菜单栏与工具栏

    QT学习之菜单栏与工具栏 目录 简单菜单栏 多级菜单栏 上下菜单栏 工具栏 简单菜单栏 程序示例 from PyQt5.QtWidgets import QApplication, QMainWind ...

  3. qt 工具栏和菜单栏

    在前面的QMainWindow的基础之上,我们开始着手建造我们的应用程序.虽然现在已经有一个框架,但是,确切地说我们还一行代码没有写呢!下面的工作就不那么简单了!在这一节里面,我们要为我们的框架添加菜 ...

  4. QT基础:QMainWindow学习小结

    简述 普通的桌面应用程序有个共同的特性,有菜单栏.工具栏.状态栏.中央窗口等部件.菜单栏其实可以看成是一个窗口,菜单栏中的每一个菜单也可以看成一个窗口,每个部件基本都可以认为是一个窗口.那么这些典型的 ...

  5. C++ Qt基础知识

    时间如流水,只能流去不流回. 学历代表你的过去,能力代表你的现在,学习能力代表你的将来. 学无止境,精益求精. 记录C++ Qt的基础知识学习记录 <C++ Qt设计模式(第二版)>

  6. qt基础知识之类库概述

    qt是用标准c++编写的跨平台开发类库,它对标准c++进行拓展,引入元对象系统.信号&槽.属性等特征 全局定义 容器类及对应迭代器 qt的模块化体系,分为 基本模块和拓展模块,一个模块通常就是 ...

  7. 【Qt开发】菜单栏,工具栏和状态栏

    概述 菜单栏,工具栏,状态栏应用中经常见到,下图解释一目了然,实际开发中 两种方式来实现,一种是使用纯代码QMenuBar,QToolBar,QStatusBar来设计开发,另一种使用Qt Desig ...

  8. C/C++ Qt 基础通用组件应用

    QT 是一个跨平台C++图形界面开发库,利用QT可以快速开发跨平台窗体应用程序,在QT中我们可以通过拖拽的方式将不同组件放到指定的位置,实现图形化开发极大的方便了开发效率. 目前,QT开发中常用的基础 ...

  9. [Qt基础内容-08] Qt中MVC的M(Model)

    Qt中MVC的M(Model)简单介绍 Qt有自己的MVC框架,分别是model(模型).view(视图).delegate(委托),这篇文章,简单的介绍以下Qt中有关model(模型)的类以及一些基 ...

随机推荐

  1. HNOI 2015 【亚瑟王】

    看着洛谷里那一排任务计划,瑟瑟发抖...... 题目大意: 你有n张牌,每一张牌有一个发动的概率和造成的伤害值,游戏一共有r轮.对于每一轮游戏,你只能发动一张牌(在之前回合发动过的牌会被跳过,不予考虑 ...

  2. Python+Appium自动化测试(11)-location与size获取元素坐标

    appium做app自动化测试过程中,有时需要获取控件元素的坐标进行滑动操作.appium中提供了location方法获取控件元素左上角的坐标,再通过size方法获取控件元素的宽高,就可以得到控件元素 ...

  3. 网络IO模型-异步选择模型(Delphi版)

    其实关于这个模型,网络上也有一个案例说明 老陈使用了微软公司的新式信箱.这种信箱非常先进,一旦信箱里有新的信件,盖茨就会给老陈打电话:喂,大爷,你有新的信件了!从此,老陈再也不必频繁上下楼检查信箱了, ...

  4. 测试AAA

    程序计数器(线程私有) 程序计数器(Program Counter Register),也有称作为 PC 寄存器.保存的是程序当 前执行的指令的地址(也可以说保存下一条指令的所在存储单元的地址),当 ...

  5. 多测师讲解自动化 _rf自动化需要总结的问题(2)_高级讲师肖sir

    1.口述整个自动化环境搭建的过程.以及环境搭建需要哪些工具包以及对应的工具包的作用?2.RF框架的原理?常见的功能?3.公司自动化测试的流程?1.自动化需求的评审2.自动化场景的选择3.自动化工具的选 ...

  6. 【Flutter 混合开发】嵌入原生View-iOS

    Flutter 混合开发系列 包含如下: 嵌入原生View-Android 嵌入原生View-iOS 与原生通信-MethodChannel 与原生通信-BasicMessageChannel 与原生 ...

  7. docker的常用操作之三:网络配置

    一, docker安装后容器使用哪些网络类型? 在宿主机执行如下命令: [root@localhost liuhongdi]# docker network ls NETWORK ID NAME DR ...

  8. Ubuntu安装zookeeper问题

    在Ubuntu系统安装zookeeper后,启动报错: root@host8:/usr/solrcould/service1/zookeeper-3.5.0-alpha# sh bin/zkServe ...

  9. C++ Primer第5版 第三章课后练习

    练习3.1 #include <iostream> using namespace std; int main() { int sum = 0, val = 50; while (val ...

  10. js实现无缝连接轮播图(二)实现自定义属性,根据banner图片的数量动态生成小圆点

    <!-- 这个animate.js 必须写到 index.js的上面引入 --><script src="js/animate.js"></scrip ...