QT6 源(111):阅读与注释菜单栏 QMenuBar,进行属性与成员函数测试,信号与槽函数测试,并给出源码

(1)

在这里插入图片描述

(2)

在这里插入图片描述

(3)

在这里插入图片描述

++

在这里插入图片描述

(4)

在这里插入图片描述

(5)

在这里插入图片描述

(6)

在这里插入图片描述

(7)以下源代码来自于头文件 qmenubar . h

#ifndef QMENUBAR_H
#define QMENUBAR_H#include <QtWidgets/qtwidgetsglobal.h>
#include <QtWidgets/qmenu.h>QT_REQUIRE_CONFIG(menubar);QT_BEGIN_NAMESPACE //说明本菜单栏定义于 Qt的全局命名空间class QMenuBarPrivate;
class QStyleOptionMenuItem;
class QWindowsStyle;
class QPlatformMenuBar;/*
The QMenuBar class provides a horizontal menu bar.不需要设置菜单栏。它会自动将其几何形状设置为父控件的顶部,并在父控件重新调整大小时适当地进行更改。Usage:
在大多数主要窗口样式应用程序中,
您将使用QMainWindow中提供的menuBar()函数,将QMenus添加到菜单栏中,并将QActions添加到弹出菜单中。可以通过使用QWidgetAction类的实例来将小部件添加到菜单中。
然后,可以使用通常的方式将这些动作插入菜单中;请参阅QMenu文档以获取详细信息。Platform Dependent Look and Feel:
不同的平台对菜单栏的外观以及用户与菜单栏交互时的行为有不同的要求。
例如,Windows 系统通常配置为仅在按下 AIt 键时显示带下划线的字符助记符,
这些助记符指示菜单栏中项目的键盘快捷方式。QMenuBar as a Global Menu Bar :
在macOs和某些Linux桌面环境中,如Ubuntu Unity,
QMenuBar是用于使用系统级菜单栏的包装器.
如果在同一个对话框中有多个菜单栏,
则最外面的菜单栏(通常位于具有widget标志Qt::Window的widget中)将用于系统级菜单栏。
...........*/class Q_WIDGETS_EXPORT QMenuBar : public QWidget
{Q_OBJECT//此属性包含弹出窗口的方向. 默认弹出窗口的方向。默认情况下,菜单会“向下”弹出屏幕。//通过将属性设置为true,菜单将“向上”弹出。您可以将此调用用于位于它们所指向的文档下方的菜单。//如果菜单无法在屏幕上显示,则自动使用其他方向。Q_PROPERTY(bool      defaultUp       //决定下拉菜单的弹出方向,默认向下弹出。READ   isDefaultUp       WRITE   setDefaultUp)Q_PROPERTY(bool      nativeMenuBar   //本属性在 windows系统上无用READ   isNativeMenuBar   WRITE   setNativeMenuBar)//这个属性表示在支持它的平台上是否将使用菜单栏作为原生菜单栏。//此属性指定是否应在支持的平台上将菜单栏用作原生菜单栏。目前支持的平台是macOS和Linux桌面,//它们使用com,canonical.dbusmeny D-Bus接口(例如Ubuntu Unity)。//如果此属性为真,则菜单栏在原生菜单栏中使用,不在其父窗口中;如果为假,则菜单栏保留在窗口中。//在其他平台上,设置此属性没有影响,读取此属性将始终返回假。//默认情况下,会遵循是否为该应用程序设置了 Qt:AA_DontUseNativeMenuBar属性。//显式设置此属性会覆盖属性的存在(或不存在)。private:Q_DECLARE_PRIVATE(QMenuBar)Q_DISABLE_COPY(QMenuBar)Q_PRIVATE_SLOT(d_func(), void _q_actionTriggered())Q_PRIVATE_SLOT(d_func(), void _q_actionHovered())Q_PRIVATE_SLOT(d_func(), void _q_internalShortcutActivated(int))Q_PRIVATE_SLOT(d_func(), void _q_updateLayout())friend class QMenu        ; //本菜单栏类的友元类是菜单 QMenufriend class QMenuPrivate ;friend class QWindowsStyle;public:explicit QMenuBar(QWidget * parent = nullptr);~QMenuBar();//   Q_PROPERTY(bool      defaultUp       //决定下拉菜单的弹出方向,默认向下弹出。
//              READ    isDefaultUp       WRITE   setDefaultUp)bool    isDefaultUp() const;void   setDefaultUp(bool);//   Q_PROPERTY(bool      nativeMenuBar   //本属性在 windows系统上无用
//              READ    isNativeMenuBar   WRITE   setNativeMenuBar)bool    isNativeMenuBar() const;void   setNativeMenuBar(bool nativeMenuBar);QPlatformMenuBar *  platformMenuBar(); //无注释//菜单栏里的按钮是由 QMenu::menuAction()得到的。//总结:以为菜单栏里插入的是菜单,其实插入的是对应代表菜单的按钮QAction。//Returns the QAction that is currently highlighted, if any, else nullptr.QAction  *     activeAction() const;   //显示菜单栏上被高亮显示的按钮void        setActiveAction(QAction * action);//Sets the currently highlighted action to action.//这俩函数的意思是不必为每个按钮单独设置触发与高亮函数,只为按钮的容器,菜单栏或菜单设计槽函数即可。//Returns the widget on the left of the first or on the right of the last menu item,//  depending on corner.//Note: Using a corner other than Qt::TopRightCorner or//                                Qt::TopLeftCorner will result in a warning.//enum Qt::Corner { TopLeftCorner    = 0, TopRightCorner    = 1,//                  BottomLeftCorner = 2, BottomRightCorner = 3  };QWidget  *     cornerWidget(Qt::Corner corner = Qt::TopRightCorner) const;void        setCornerWidget(QWidget * w,Qt::Corner corner = Qt::TopRightCorner);//This sets the given w to be shown directly on the left of the first menu item,//or on the right of the last menu item, depending on corner.//The menu bar takes ownership of widget, reparenting it into the menu bar.//However, if the corner already contains a widget,//this previous widget will no longer be managed and will still be a//  visible child of the menu bar.QSize           sizeHint() const override;QSize    minimumSizeHint() const override;int                  heightForWidth(int) const override;QRect               actionGeometry(QAction *) const;   //因为本菜单栏也可以直接管理按钮QAction          *  actionAt(const QPoint  &) const;   //略,这俩函数在 QMenu里也出现过void clear(); //Removes all the actions from the menu bar.//This convenience function inserts menu before action before and returns the//  menus menuAction(). //把菜单 menu 放到 before的前面,并返回 menu对应的 QActionQAction *  insertMenu(QAction * before, QMenu * menu); //在菜单里也可以插入子菜单QAction *     addMenu(QMenu   * menu); //在菜单栏的末尾追加菜单,返回菜单对应的按钮。//Appends menu to the menu bar. Returns the menu's menuAction().//The menu bar does not take ownership of the menu.QMenu   *     addMenu(const QString & title);//生成一个菜单,其对应的按钮项叫 title//Appends a new QMenu with title to the menu bar.//The menu bar takes ownership of the menu. Returns the new menu.QMenu   *     addMenu(const QIcon   & icon, const QString & title);//Appends a new QMenu with icon and title to the menu bar.//The menu bar takes ownership of the menu. Returns the new menu.//This convenience function creates a new separator action,//i.e. an action with QAction::isSeparator() returning true.//The function inserts the newly created action into this menu bar's list of//  actions before action before and returns it.QAction *  insertSeparator(QAction * before); //在菜单栏里 before按钮的前面插入分隔符QAction *     addSeparator();                 //Appends a separator to the menu.//经测试,新添加的分隔符的容器父类,就是菜单栏。但经测试,菜单栏里似乎不允许或不显示添加的分隔符。//该 addAction() 函数的正确用法如下:可见 QMenu::menuAction()这个函数很重要!!//    menubar->addAction(menu_F->menuAction());        //为菜单栏添加"文件(&F)"菜单//    menu_F ->setTitle(//          QCoreApplication::translate("MainWindow",  //设置菜单的名字,以及快捷键//             "\346\226\207\344\273\266(&F)", nullptr));using QWidget::addAction;//void  QWidget::addAction(QAction * action);QAction * addAction(const QString & text);  //说明菜单栏里可以添加普通按钮//This convenience function creates a new action with text.//The function adds the newly created action to the menu's list of actions,//  and returns it.QAction * addAction(const QString & text,   //为菜单栏创建按钮,并为其指定槽函数。const QObject * receiver, const char * member);// addAction(QString)://Connect to a QObject slot / functor or function pointer (with context)template<typename Obj, typename Func1>inline typename std::enable_if<!std::is_same<const char *, Func1>::value&&   QtPrivate::IsPointerToTypeDerivedFromQObject<Obj *>::Value,QAction *>::typeaddAction(const QString & text, const Obj * object, Func1 slot){   //把创建的文本为 text的按钮的 triggered()信号连接到形参 object的 slot槽函数上QAction * result = addAction(text);connect(result, & QAction::triggered, object, std::move(slot));return result;}// addAction(QString)://Connect to a functor or function pointer (without context)template <typename Func1>inline QAction * addAction(const QString & text, Func1 slot){   //把创建的 text按钮的信号连接到全局槽函数 slot上。QAction * result = addAction(text);connect(result, & QAction::triggered, std::move(slot));return result;}public Q_SLOTS:void setVisible(bool visible) override; //菜单栏消失,窗体整体上移,工具栏占据了菜单栏的位置。//Reimplements an access function for property: QWidget::visible.Q_SIGNALS://This signal is emitted when an action in a menu belonging to this menubar//is triggered as a result of a mouse click;    //注意上面的话:an action in a menu//action is the action that caused the signal to be emitted.//Note: QMenuBar has to have ownership of the QMenu in order this signal to work.//Normally, you connect each menu action to a single slot using QAction::triggered(),//but sometimes you will want to connect several items to a single slot//(most often if the user selects from an array). This signal is useful in such cases.//即使菜单栏里的按钮被敲击,也不会触发 triggered()信号。void triggered(QAction * action); //菜单栏里的菜单里的按钮被鼠标敲击,才触发本信号。void   hovered(QAction * action); //菜单栏里的按钮高亮时触发本信号。注意这俩信号对按钮的区别。//This signal is emitted when a menu action is highlighted;//action is the action that caused the event to be sent.//Often this is used to update status information.protected:virtual void initStyleOption(QStyleOptionMenuItem * option,const        QAction * action) const;bool             eventFilter(QObject *, QEvent *) override;bool             event(QEvent       *) override;void       changeEvent(QEvent       *) override;void     keyPressEvent(QKeyEvent    *) override;void mouseReleaseEvent(QMouseEvent  *) override;void   mousePressEvent(QMouseEvent  *) override;void    mouseMoveEvent(QMouseEvent  *) override;void        leaveEvent(QEvent       *) override;void        paintEvent(QPaintEvent  *) override;void       resizeEvent(QResizeEvent *) override;void       actionEvent(QActionEvent *) override;void     focusOutEvent(QFocusEvent  *) override;void      focusInEvent(QFocusEvent  *) override;void        timerEvent(QTimerEvent  *) override;}; //完结 class QMenuBar : public QWidgetQT_END_NAMESPACE#endif // QMENUBAR_H

(8)

谢谢

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/81696.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Leetcode 3552. Grid Teleportation Traversal

Leetcode 3552. Grid Teleportation Traversal 1. 解题思路2. 代码实现 题目链接&#xff1a;3552. Grid Teleportation Traversal 1. 解题思路 这一题的话核心就是一个广度优先遍历&#xff0c;我们只需要从原点开始&#xff0c;一点点考察其所能到达的位置&#xff0c;直至…

2023CCPC河南省赛暨河南邀请赛个人补题ABEFGHK

Dashboard - 2023 CCPC Henan Provincial Collegiate Programming Contest - Codeforces 过题难度&#xff1a;A H F G B K E 铜奖&#xff1a; 2 339 银奖&#xff1a; 3 318 金奖&#xff1a; 5 523 A: 直接模拟 // Code Start Here int t;cin >> t;while(t-…

如何用Python批量解压ZIP文件?快速解决方案

如何用Python批量解压ZIP文件&#xff1f;快速解决方案 文章目录 **如何用Python批量解压ZIP文件&#xff1f;快速解决方案**代码结果详细解释 话不多说&#xff0c;先上干货&#xff01;&#xff01;&#xff01; 代码 import os import zipfiledef unzip_file(dir_path: str…

Spring Boot 的高级特性与经典的设计模式应用

目录 1. 设计模式在 Spring Boot 中的应用 1.1 单例模式&#xff1a;Bean 管理与全局实例 1.1.1 Spring 中的单例 Bean 1.1.2 自定义单例实现 1.1.3 单例模式的优势 1.2 工厂模式&#xff1a;动态创建 Bean 1.2.1 Spring 的工厂方法 1.2.2 自定义工厂类 1.2.3 工厂模式…

在Excel中使用函数公式时,常见错误对应不同的典型问题

在Excel中使用函数公式时&#xff0c;常见错误对应不同的典型问题 1. #DIV/0!&#xff08;除以零错误&#xff09;2. #N/A&#xff08;值不可用&#xff09;3. #NAME?&#xff08;名称错误&#xff09;4. #NULL!&#xff08;空交集错误&#xff09;5. #NUM!&#xff08;数值错…

【cursor疑惑】cursor续杯后使用agent对话时,提示“需要pro或商业订阅的用户才能使用“

背景 cursor的pro会员体验过期了&#xff0c;想再次体验deepseek、Claude等agent对话提示:“免费版本不可以使用agent对话功能(英文忘记截图了&#xff0c;大意是这样)”。 处理方法 Step-1&#xff1a;再次续杯cursor的pro会员14天体验 详情&#xff0c;见&#xff1a;【c…

解决qt.network.ssl: QSslSocket::connectToHostEncrypted: TLS initialization failed

可以参考&#xff1a;解决qt.network.ssl: QSslSocket::connectToHostEncrypted: TLS initialization failed-CSDN博客 讲的是程序执行目录下可能缺少了&#xff1a; libssl-1_1-x64.dll 和 libcrypto-1_1-x64.dll 库文件&#xff0c;将其复制到可执行文件exe的同级目录下即可…

白杨SEO:不到7天,白杨SEO博客网站百度搜索显示和排名恢复正常!顺带说说上海线下GEO聚会分享和播客红利

大家好&#xff0c;我是白杨SEO&#xff0c;专注SEO十年以上&#xff0c;全网SEO流量实战派&#xff0c;AI搜索优化研究者。 5月开始&#xff0c;明显就忙起来了&#xff0c;不管是个人陪跑还是企业顾问&#xff0c;不管是需要传统SEO还是新媒体流量&#xff0c;还是当下这个A…

FART 自动化脱壳框架简介与脱壳点的选择

版权归作者所有&#xff0c;如有转发&#xff0c;请注明文章出处&#xff1a;https://cyrus-studio.github.io/blog/ FART简介 ART 环境下基于主动调用的自动化脱壳方案&#xff0c;可以解决函数抽取壳。 关于函数抽取壳的实现原理可以参考&#xff1a;基于 art 下的类加载机…

卷积神经网络进阶:转置卷积与棋盘效应详解

【内容摘要】 本文深入解析卷积神经网络中的转置卷积&#xff08;反卷积&#xff09;技术&#xff0c;重点阐述标准卷积与转置卷积的计算过程、转置卷积的上采样作用&#xff0c;以及其常见问题——棋盘效应的产生原因与解决方法&#xff0c;为图像分割、超分辨率等任务提供理论…

Redis进阶知识

Redis 1.事务2. 主从复制2.1 如何启动多个Redis服务器2.2 监控主从节点的状态2.3 断开主从复制关系2.4 额外注意2.5拓扑结构2.6 复制过程2.6.1 数据同步 3.哨兵选举原理注意事项 4.集群4.1 数据分片算法4.2 故障检测 5. 缓存5.1 缓存问题 6. 分布式锁 1.事务 Redis的事务只能保…

SDC命令详解:使用get_libs命令进行查询

相关阅读 SDC命令详解https://blog.csdn.net/weixin_45791458/category_12931432.html?spm1001.2014.3001.5482 get_libs命令用于创建一个库对象集合&#xff0c;关于设计对象和集合的更详细介绍&#xff0c;可以参考下面的博客。需要注意的是&#xff0c;在有些工具中还存在…

idea2024 不知道安装了什么插件,界面都是中文的了,不习惯,怎么修改各个选项改回英文

如果你的 IntelliJ IDEA 2024 突然变成中文界面&#xff0c;很可能是安装了中文语言包插件&#xff08;如 “Chinese (Simplified) Language Pack”&#xff09;。以下是 彻底恢复英文界面 的方法&#xff1a; 方法 1&#xff1a;直接卸载中文插件&#xff08;推荐&#xff09;…

物流项目第二期(用户端登录与双token三验证)

第一期内容&#xff1a; 物流项目第一期&#xff08;登录业务&#xff09;-CSDN博客 用户端登录 实现分析 登录功能 Data public class UserLoginRequestVO {ApiModelProperty("登录临时凭证")private String code;ApiModelProperty("手机号临时凭证"…

精准掌控张力动态,重构卷对卷工艺设计

一、MapleSim Web Handling Library仿真和虚拟调试解决方案 在柔性材料加工领域&#xff0c;卷对卷&#xff08;Roll-to-Roll&#xff09;工艺的效率与质量直接决定了产品竞争力。如何在高动态生产场景中实现张力稳定、减少断裂风险、优化加工速度&#xff0c;是行业长期面临的…

Voxblox算法

文章目录 1. 算法简介2. 由 TSDF 构建 ESDF 的方法2.1. 论文解读2.2. 伪代码实现 1. 算法简介 Voxblox 算法出现于文献《Voxblox: Incremental 3D Euclidean Signed Distance Fields for On-Board MAV Planning》&#xff0c;PDF 链接&#xff1a;https://arxiv.org/pdf/1611.…

计算机图形学基础--Games101笔记(一)数学基础与光栅化

文章目录 数学基础向量插值三角形插值双线性插值 平面定义法线-点表示 第一部分&#xff1a;光栅化坐标变换二维变换3D变换视图变换&#xff08;MVP&#xff09;投影变换 光栅化采样抗锯齿&#xff08;反走样&#xff09;可见性&#xff08;遮挡&#xff09; 着色与纹理Blinn-P…

@RequestParam 和 @RequestBody、HttpServletrequest 与HttpServletResponse

在Java Web开发中&#xff0c;RequestParam、RequestBody、HttpServletRequest 和 HttpServletResponse 是常用的组件&#xff0c;它们用于处理HTTP请求和响应。下面分别介绍它们的使用场景和使用方法&#xff1a; 1. RequestParam RequestParam 是Spring MVC框架中的注解&am…

【硬核数学】2. AI如何“学习”?微积分揭秘模型优化的奥秘《从零构建机器学习、深度学习到LLM的数学认知》

在上一篇中&#xff0c;我们探索了线性代数如何帮助AI表示数据&#xff08;向量、矩阵&#xff09;和变换数据&#xff08;矩阵乘法&#xff09;。但AI的魅力远不止于此&#xff0c;它最核心的能力是“学习”——从数据中自动调整自身&#xff0c;以做出越来越准确的预测或决策…

10.15 LangChain v0.3重磅升级:Tool Calling技术颠覆大模型工具调用,效率飙升300%!

LangChain v0.3 技术生态与未来发展:支持 Tool Calling 的大模型 关键词:LangChain Tool Calling, 大模型工具调用, @tool 装饰器, ToolMessage 管理, Few-shot Prompting 1. Tool Calling 的技术革新 LangChain v0.3 的工具调用(Tool Calling)功能标志着大模型应用开发进…