【十六】【QT开发应用】Menu菜单,contextMenuEvent,setContextMenuPolicy,addAction

在 Qt 框架中,QMenu 类用于创建和管理菜单。菜单是用户界面的一部分,可以包含多个选项或动作,用户可以选择这些选项来执行特定的功能。菜单通常显示在菜单栏、上下文菜单(右键菜单)或工具栏中。
基本用法

创建菜单对象:

QMenu *menu = new QMenu(this); // 创建一个新的 QMenu 对象,父对象为当前小部件

添加动作:
使用 addAction 方法将 QAction 对象添加到菜单中。QAction 代表菜单中的一个选项或动作。

QAction *action1 = new QAction("Action 1", this);
menu->addAction(action1); // 将动作添加到菜单

显示菜单:
菜单可以在指定的位置显示,例如在鼠标光标位置。

menu->exec(QCursor::pos()); // 在当前光标位置显示菜单

在这里插入图片描述

widget.h

#pragma once

#include <QtWidgets/QWidget>
#include "ui_widget.h"
#include <QMenu>

class widget : public QWidget
{
    Q_OBJECT

public:
    widget(QWidget *parent = nullptr);
    ~widget();

    void contextMenuEvent(QContextMenuEvent* event) override;

    void initMenu();


private:
    Ui::widgetClass ui;

    QMenu* m_pMenu = nullptr;
};

widget.cpp

#include "widget.h"
#include <QAction>
#include <QMessageBox>





widget::widget(QWidget *parent)
    : QWidget(parent)
{
    ui.setupUi(this);


    this->setContextMenuPolicy(Qt::DefaultContextMenu);

    initMenu();
}

widget::~widget()
{}

void widget::contextMenuEvent(QContextMenuEvent* event) {
    m_pMenu->exec(QCursor::pos());
}

void widget::initMenu() {
    m_pMenu = new QMenu(this);

    QAction* pAc1 = new QAction("ac1");
    QAction* pAc2 = new QAction("ac2");
    QAction* pAc3 = new QAction("ac3");
    QAction* pAc4 = new QAction("ac4");
    QAction* pAc5 = new QAction("ac5");
    QAction* pAc6 = new QAction("ac6");
    QAction* pAc7 = new QAction("ac7");


    m_pMenu->addAction(pAc1);
    m_pMenu->addAction(pAc2);
    m_pMenu->addAction(pAc3);
    m_pMenu->addAction(pAc4);
    m_pMenu->addAction(pAc5);
    m_pMenu->addAction(pAc6);
    m_pMenu->addAction(pAc7);

	connect(pAc1, &QAction::triggered, [=] {
		QMessageBox::information(this, "title", "ac1");
		});

	connect(pAc2, &QAction::triggered, [=] {
		QMessageBox::information(this, "title", "ac2");
		});

	connect(pAc3, &QAction::triggered, [=] {
		QMessageBox::information(this, "title", "ac3");
		});

	connect(pAc4, &QAction::triggered, [=] {
		QMessageBox::information(this, "title", "ac4");
		});

	connect(pAc5, &QAction::triggered, [=] {
		QMessageBox::information(this, "title", "ac5");
		});

	connect(pAc6, &QAction::trigger, [=] {
		QMessageBox::information(this, "title", "ac6");
		});

	connect(pAc7, &QAction::trigger, [=] {
		QMessageBox::information(this, "title", "ac7");
		});
}

复盘

#include "widget.h"
#include <QAction>
#include <QMessageBox>

widget::widget(QWidget *parent)
    : QWidget(parent)
{
    ui.setupUi(this);

    // 设置上下文菜单策略为默认
    this->setContextMenuPolicy(Qt::DefaultContextMenu);

    initMenu(); // 初始化菜单
}

widget::~widget()
{}

void widget::contextMenuEvent(QContextMenuEvent* event) {
    m_pMenu->exec(QCursor::pos()); // 在光标位置执行菜单
}

void widget::initMenu() {
    m_pMenu = new QMenu(this); // 创建新的QMenu

    QAction* pAc1 = new QAction("ac1"); // 创建动作ac1
    QAction* pAc2 = new QAction("ac2"); // 创建动作ac2
    QAction* pAc3 = new QAction("ac3"); // 创建动作ac3
    QAction* pAc4 = new QAction("ac4"); // 创建动作ac4
    QAction* pAc5 = new QAction("ac5"); // 创建动作ac5
    QAction* pAc6 = new QAction("ac6"); // 创建动作ac6
    QAction* pAc7 = new QAction("ac7"); // 创建动作ac7

    m_pMenu->addAction(pAc1); // 将动作ac1添加到菜单
    m_pMenu->addAction(pAc2); // 将动作ac2添加到菜单
    m_pMenu->addAction(pAc3); // 将动作ac3添加到菜单
    m_pMenu->addAction(pAc4); // 将动作ac4添加到菜单
    m_pMenu->addAction(pAc5); // 将动作ac5添加到菜单
    m_pMenu->addAction(pAc6); // 将动作ac6添加到菜单
    m_pMenu->addAction(pAc7); // 将动作ac7添加到菜单

    // 连接动作ac1的触发信号到槽函数,显示信息框
    connect(pAc1, &QAction::triggered, [=] {
        QMessageBox::information(this, "title", "ac1");
    });

    // 连接动作ac2的触发信号到槽函数,显示信息框
    connect(pAc2, &QAction::triggered, [=] {
        QMessageBox::information(this, "title", "ac2");
    });

    // 连接动作ac3的触发信号到槽函数,显示信息框
    connect(pAc3, &QAction::triggered, [=] {
        QMessageBox::information(this, "title", "ac3");
    });

    // 连接动作ac4的触发信号到槽函数,显示信息框
    connect(pAc4, &QAction::triggered, [=] {
        QMessageBox::information(this, "title", "ac4");
    });

    // 连接动作ac5的触发信号到槽函数,显示信息框
    connect(pAc5, &QAction::triggered, [=] {
        QMessageBox::information(this, "title", "ac5");
    });

    // 连接动作ac6的触发信号到槽函数,显示信息框
    connect(pAc6, &QAction::trigger, [=] {
        QMessageBox::information(this, "title", "ac6");
    });

    // 连接动作ac7的触发信号到槽函数,显示信息框
    connect(pAc7, &QAction::trigger, [=] {
        QMessageBox::information(this, "title", "ac7");
    });
}

setContextMenuPolicy

setContextMenuPolicy 是 Qt 中 QWidget 类的一个函数,用于设置小部件的上下文菜单策略。上下文菜单(也称为右键菜单)是用户通过右键单击触发的菜单。
Qt::ContextMenuPolicy 枚举定义了以下几种策略:

Qt::NoContextMenu: 禁用上下文菜单。

Qt::PreventContextMenu: 禁用默认上下文菜单,但仍然会触发 contextMenuEvent。

Qt::DefaultContextMenu: 使用 QWidget 的默认上下文菜单处理。

Qt::ActionsContextMenu: 显示与 QWidget 关联的动作(QAction)。

Qt::CustomContextMenu: 触发 customContextMenuRequested 信号,用户可以连接自己的槽函数来处理。

this->setContextMenuPolicy(Qt::DefaultContextMenu);

设置了默认的上下文菜单策略,即当用户右键单击小部件时,会触发 contextMenuEvent 函数。你可以在这个事件处理函数中自定义上下文菜单的行为,如下所示:

void widget::contextMenuEvent(QContextMenuEvent* event) {
    m_pMenu->exec(QCursor::pos()); // 在光标位置显示菜单
}

通过这个设置,你可以为小部件提供自定义的上下文菜单,而不是依赖于系统的默认菜单。

QAction 和 QMenu

QAction 和 QMenu 是 Qt 框架中用于创建和管理菜单项的类。

QAction* pAc1 = new QAction("ac1");

这行代码创建了一个新的 QAction 对象。QAction 表示一个动作,可以被用户在菜单、工具栏或快捷键中触发。构造函数接受一个字符串参数作为动作的文本标签。

QAction 构造函数: QAction(const QString &text, QObject *parent = nullptr)

text: 动作的标签文本。在这个例子中,标签是 “ac1”。

parent: 动作的父对象。这里没有指定父对象,默认值为 nullptr。

QAction* pAc1 = new QAction("ac1"); // 创建一个标签为“ac1”的新动作

m_pMenu->addAction(pAc1);

这行代码将先前创建的 QAction 对象 pAc1 添加到菜单 m_pMenu 中。QMenu 是 Qt 中用于创建菜单的类,addAction 函数用于向菜单中添加一个动作。

QMenu 函数: void addAction(QAction *action)

action: 要添加到菜单中的 QAction 对象。

m_pMenu->exec(QCursor::pos());

m_pMenu->exec(QCursor::pos()); 是在 Qt 中显示上下文菜单的一种常见方式。

m_pMenu->exec(QCursor::pos());

m_pMenu:这是一个 QMenu 对象的指针,表示要显示的菜单。

exec():QMenu 类的成员函数,用于以模态方式显示菜单,并阻塞直到用户选择了菜单项或关闭了菜单。exec() 函数返回用户选择的 QAction 指针,如果用户没有选择任何项而是关闭了菜单,则返回 nullptr。

QCursor::pos():静态函数,返回当前鼠标光标的位置(以全局坐标系表示)。通过这个位置,可以在鼠标光标处显示菜单。

在上下文菜单事件中,我们通常会使用这行代码来显示上下文菜单:

void widget::contextMenuEvent(QContextMenuEvent* event) {
    m_pMenu->exec(QCursor::pos()); // 在光标位置显示菜单
}

显示菜单:exec() 方法会在指定位置显示菜单。在这个例子中,QCursor::pos() 返回当前光标的位置,因此菜单会在鼠标光标处弹出。

阻塞调用:exec() 是一个阻塞调用,这意味着程序执行会暂停在这一行,直到用户在菜单中选择一个动作或关闭菜单。然后,exec() 将返回选择的 QAction 或 nullptr。

结尾

最后,感谢您阅读我的文章,希望这些内容能够对您有所启发和帮助。如果您有任何问题或想要分享您的观点,请随时在评论区留言。
同时,不要忘记订阅我的博客以获取更多有趣的内容。在未来的文章中,我将继续探讨这个话题的不同方面,为您呈现更多深度和见解。
谢谢您的支持,期待与您在下一篇文章中再次相遇!

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

# Kafka_深入探秘者(5):kafka 分区

Kafka_深入探秘者&#xff08;5&#xff09;&#xff1a;kafka 分区 一、kafka 副本机制 1、Kafka 可以将主题划分为多个分区(Partition)&#xff0c;会根据分区规则选择把消息存储到哪个分区中&#xff0c;只要如果分区规则设置的合理&#xff0c;那么所有的消息将会被均匀的…

边缘混合计算智慧矿山视频智能综合管理方案:矿山安全生产智能转型升级之路

一、智慧矿山方案介绍 智慧矿山是以矿山数字化、信息化为前提和基础&#xff0c;通过物联网、人工智能等技术进行主动感知、自动分析、快速处理&#xff0c;实现安全矿山、高效矿山的矿山智能化建设。旭帆科技TSINGSEE青犀基于图像的前端计算、边缘计算技术&#xff0c;结合煤…

u盘插到另一台电脑上数据丢失怎么办?提供实用的解决方案

在现代数字化生活中&#xff0c;U盘作为一种便携式存储设备&#xff0c;承载着我们重要的数据和信息。然而&#xff0c;有时当我们将U盘插入另一台电脑时&#xff0c;可能会遇到数据丢失的棘手问题。这可能是由于多种原因造成的&#xff0c;那么&#xff0c;U盘插到另一台电脑上…

使用隐式事件执行控制图

什么是隐式事件&#xff1f; 隐式事件是图表执行时发生的内置事件&#xff1a; 图表唤醒 进入一个状态 退出状态 分配给内部数据对象的值 这些事件是隐式的&#xff0c;因为您没有显式地定义或触发它们。隐式事件是它们发生的图表的子级&#xff0c;仅在父图表中可见。 隐式事…

png格式快速压缩该怎么做?在电脑压缩png图片的方法

png格式的图片如何快速压缩变小呢&#xff1f;现在网络的不断发展&#xff0c;图片是日常用来分享展示内容的一种常用手段&#xff0c;其中使用最多的一种图片格式就是png&#xff0c;png格式具有无损压缩支持透明底的特性&#xff0c;在很多的场景下都会使用。 现在图片的清晰…

笔记-python reduce 函数

reduce() 函数在 python 2 是内置函数&#xff0c; 从python 3 开始移到了 functools 模块。 官方文档是这样介绍的 reduce(...) reduce(function, sequence[, initial]) -> valueApply a function of two arguments cumulatively to the items of a sequence, from left …

健身房管理系统

摘 要 随着人们健康意识的增强&#xff0c;健身房作为一种提供健身服务的场所&#xff0c;受到越来越多人的关注和喜爱。然而&#xff0c;传统的健身房管理方式存在诸多问题&#xff0c;如信息管理不便捷、会员管理不规范等。为了解决这些问题&#xff0c;本文设计并实现了一款…

分享一套基于SSM的九宫格日志网站(源码+文档+部署)

大家好&#xff0c;今天给大家分享一套基于SSM的九宫格日志网站 开发语言&#xff1a;Java 数据库&#xff1a;MySQL 技术&#xff1a;SpringSpringMvcMyBatis 工具&#xff1a;IDEA/Ecilpse、Navicat、Maven 博主介绍&#xff1a; 一名Java全栈工程师&#xff0c;专注于Java全…

AI大模型日报#0626:首款大模型芯片挑战英伟达、面壁智能李大海专访、大模型测试题爆火LeCun点赞

导读&#xff1a;AI大模型日报&#xff0c;爬虫LLM自动生成&#xff0c;一文览尽每日AI大模型要点资讯&#xff01;目前采用“文心一言”&#xff08;ERNIE-4.0-8K-latest&#xff09;生成了今日要点以及每条资讯的摘要。欢迎阅读&#xff01;《AI大模型日报》今日要点&#xf…

vue elementui简易侧拉栏的使用

如图所示&#xff0c;增加了侧拉栏&#xff0c;目的是可以选择多条数据展示数据 组件&#xff1a; celadon.vue <template><div class"LayoutMain"><el-aside :width"sidebarIsCollapse ? 180px : 0px" class"aside-wrap">…

MD5加密接口

签名算法 app_key和app_secret由对方系统提供 MD5_CALCULATE_HASH_FOR_CHAR&#xff08;中文加密与JAVA不一致&#xff09; 代码&#xff1a; *获取传输字段名的ASCII码&#xff0c;根据ASCII码对字段名进行排序SELECT * FROM zthr0051WHERE functionid iv_functionidINTO …

AI音乐大模型:深度剖析创意与产业的双重变革

随着AI技术的飞速发展&#xff0c;音乐大模型在最近一个月内纷纷上线&#xff0c;这一变革性技术不仅颠覆了传统的音乐创作方式&#xff0c;更是对整个音乐产业及创意产业带来了深远的影响。本文将从多个维度出发&#xff0c;深度剖析AI音乐大模型对创意与产业的双重变革。 一、…

多模态能力评估新篇章:MMStar引领大型视觉语言模型评估新标准

随着大模型&#xff08;LLMs&#xff09;的快速发展&#xff0c;将视觉模态整合进LLMs以提升模型的交互能力已成为研究的热点。这些大型视觉语言模型&#xff08;LVLMs&#xff09;不仅展现出强大的视觉感知和理解能力&#xff0c;还能够通过对话与用户互动&#xff0c;提供更丰…

Matlab|【免费】含氢气氨气综合能源系统优化调度

目录 主要内容 部分代码 结果一览 下载链接 主要内容 该程序参考《_基于氨储能技术的电转氨耦合风–光–火综合能源系统双层优化调度》模型&#xff0c;对制氨工厂、风力发电、电制氢、燃气轮机、火电机组等主体进行建模分析&#xff0c;以火电机组启停成本、煤耗…

尚硅谷vue2的todolist案例解析,基本概括了vue2所有知识点,结尾有具体代码,复制粘贴学习即可

脚手架搭建 1-初始化脚手架&#xff08;全局安装&#xff09; npm install -g vue/cli2-切换到创建项目的空目录下 vue create xxxx整体结构 整体思路 App定义所有回调方法 增删改查 还有统一存放最终数据&#xff0c;所有子组件不拿数据&#xff0c;由App下发数据&#xf…

Spring Boot 集成 H2 数据库

1. 引言 Spring Boot 以其简洁的配置和快速开发能力&#xff0c;成为现代微服务架构的首选框架之一。而H2数据库作为一个轻量级的内存数据库&#xff0c;非常适合开发阶段作为嵌入式数据库进行单元测试和功能验证。本文将手把手教你如何在Spring Boot项目中集成H2数据库&#…

Mybatis 到 MyBatisPlus

Mybatis 到 MyBatisPlus Mybatis MyBatis&#xff08;官网&#xff1a;https://mybatis.org/mybatis-3/zh/index.html &#xff09;是一款优秀的 持久层 &#xff08;ORM&#xff09;框架&#xff0c;用于简化JDBC的开发。是 Apache的一个开源项目iBatis&#xff0c;2010年这…

DC/AC电源模块一种效率与可靠性兼备的能源转换解决方案

DC/AC电源模块都是一种效率与可靠性兼备的能源转换解决方案 DC/AC电源模块是一种能够将直流电源&#xff08;DC&#xff09;转换为交流电源&#xff08;AC&#xff09;的设备。它在现代电子设备中扮演着非常重要的角色&#xff0c;因为许多设备需要交流电源才能正常运行。无论…

VS Code修改菜单栏字体大小

修改方法 打开VS Code&#xff0c;快捷键 CtrlShiftP&#xff0c;在弹出的输入框中输入 setting&#xff0c;找到带有JSON的一项&#xff0c;如图所示&#xff1a; 原文链接 window.zoomLevel 前后变化 终端字体大小 File -> Preferences -> Settings -> Features…

云计算运维工程师的突发状况处理

云计算运维工程师在应对突发的故障和紧急情况时,需要采取一系列迅速而有效的措施来最小化服务中断的时间并恢复系统的稳定性。 以下是一些关键步骤和策略: 快速响应: 立即识别并确认故障的性质和范围。通知团队成员和相关的利益相关者,确保所有人了解当前情况。故障诊断:…