如何用Qt实现右击菜单项,并添加长尾词功能?
- 内容介绍
- 文章标签
- 相关推荐
本文共计1219个文字,预计阅读时间需要5分钟。
本文以Qt为例,分享了实现右键菜单项的整体代码,供大家参考。具体内容如下:
方法一:自定义槽函数接收信号
1. 创建一个自定义槽函数,用于处理右键菜单项的点击事件。
2.在信号与槽连接中,将右键菜单项的信号连接到自定义槽函数。
cpp
// 自定义槽函数void onRightClickMenuClicked() { // 处理右键菜单项点击事件}// 信号与槽连接connect(rightClickMenu, SIGNAL(triggered()), this, SLOT(onRightClickMenuClicked()));
方法二:使用鼠标事件监听
1. 在鼠标事件监听函数中,检查鼠标事件是否为右键点击。
2.如果是右键点击,则弹出右键菜单。
cpp
// 鼠标事件监听函数void onTextEditMousePressEvent(QMouseEvent *event) { if (event->button()==Qt::RightButton) { // 弹出右键菜单 rightClickMenu->exec(event->globalPos()); }}这里我使用的文本编辑控件是QTextEdit,来实现右键功能。
本文实例为大家分享了Qt实现右击菜单项的具体代码,供大家参考,具体内容如下
有两种方法:
- 自定义槽函数接受信号
- 使用鼠标事件监听
一、前言
这里我用的是QTextEdit来实现右键功能,假设我们的预期功能是:复制、粘贴、保存、关闭四个功能。
但是,我们在直接运行Qt后,发现右键已经有默认功能了,如图:
如果有ui项目的话,进入ui的QTextEdit组件,找到contextMenuPolicy发现已经设置为DefaultContextMenu。到此应该知道,Qt默认为我们创好了默认菜单。
查看Qt文档可以证明我们的猜测是正确的。
Qt文档中解释了,默认属性是Qt::DefaultContextMenu,并且还有Qt::NoContextMenu、Qt::PreventContextMenu、Qt::ActionsContextMenu、Qt::CustomContextMenu。并且使用Qt::CustomContextMenu时,会发射一个customContextMenuRequested()信号。
这么一来,就很清晰了。
二、自定义槽函数接受信号
从上文可知,我们要想使用自定义方法。需要将属性值改了,如果我们在QTextEdit中修改属性,则
edit->setContextMenuPolicy(Qt::CustomContextMenu);
这样一来,右键就不会出现默认选项了。
并对QTextEdit连接了自定义槽函数,名称自定
connect(edit,&QTextEdit::customContextMenuRequested,this,&Widget::ShowMenu);
这样准备工作就完成了。
槽函数中我们需要创建一个菜单,并且添加选择,这里使用QAction。
再将QAction的成员连接个自功能,这样就实现了基础的菜单功能。
显示的位置在光标位置处,所以使用QCursor::pos()即可。
具体功能在槽函数里添加就行了。
void Widget::ShowMenu() { QMenu *menu = new QMenu(this); QStringList list; list << "copy" << "paste" << "save" << "close"; QList<QAction *> actList; for(int i = 0; i < list.count(); i ++) actList.append(new QAction(list.at(i))); connect(actList.at(0),&QAction::triggered,this,&Widget::CopyAction); connect(actList.at(1),&QAction::triggered,this,&Widget::PasteAction); connect(actList.at(2),&QAction::triggered,this,&Widget::SaveAction); connect(actList.at(3),&QAction::triggered,this,&Widget::CloseAction); menu->addActions(actList); menu->exec(QCursor::pos()); }
三、使用鼠标监听
重写
void mousePressEvent(QMouseEvent *event) override;
函数
需要判断鼠标点击事件是否是右击,如果不,则直接返回,如果是,执行和方法一一样的思路。
void Widget::mousePressEvent(QMouseEvent *event) { if(event->button() != Qt::RightButton) return; QMenu *menu = new QMenu(this); QStringList list; list << "copy" << "paste" << "save" << "close"; QList<QAction *> actList; for(int i = 0; i < list.count(); i ++) actList.append(new QAction(list.at(i))); connect(actList.at(0),&QAction::triggered,this,&Widget::CopyAction); connect(actList.at(1),&QAction::triggered,this,&Widget::PasteAction); connect(actList.at(2),&QAction::triggered,this,&Widget::SaveAction); connect(actList.at(3),&QAction::triggered,this,&Widget::CloseAction); menu->addActions(actList); menu->exec(QCursor::pos()); }
四、两分法对比
方法一针对的是某个组件实现的菜单功能。比如我对界面中的edit1组件使用了edit->setContextMenuPolicy(Qt::CustomContextMenu);,那么edit1就可以实现自定义功能。而edit2、edit3则没有。
方法二是监听鼠标事件,只要是右击就出现菜单,对程序整个窗口内都有效,包括空白区域。
两个方法实现的思路都是大同小异,在使用时看情况而分配吧。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持自由互联。
本文共计1219个文字,预计阅读时间需要5分钟。
本文以Qt为例,分享了实现右键菜单项的整体代码,供大家参考。具体内容如下:
方法一:自定义槽函数接收信号
1. 创建一个自定义槽函数,用于处理右键菜单项的点击事件。
2.在信号与槽连接中,将右键菜单项的信号连接到自定义槽函数。
cpp
// 自定义槽函数void onRightClickMenuClicked() { // 处理右键菜单项点击事件}// 信号与槽连接connect(rightClickMenu, SIGNAL(triggered()), this, SLOT(onRightClickMenuClicked()));
方法二:使用鼠标事件监听
1. 在鼠标事件监听函数中,检查鼠标事件是否为右键点击。
2.如果是右键点击,则弹出右键菜单。
cpp
// 鼠标事件监听函数void onTextEditMousePressEvent(QMouseEvent *event) { if (event->button()==Qt::RightButton) { // 弹出右键菜单 rightClickMenu->exec(event->globalPos()); }}这里我使用的文本编辑控件是QTextEdit,来实现右键功能。
本文实例为大家分享了Qt实现右击菜单项的具体代码,供大家参考,具体内容如下
有两种方法:
- 自定义槽函数接受信号
- 使用鼠标事件监听
一、前言
这里我用的是QTextEdit来实现右键功能,假设我们的预期功能是:复制、粘贴、保存、关闭四个功能。
但是,我们在直接运行Qt后,发现右键已经有默认功能了,如图:
如果有ui项目的话,进入ui的QTextEdit组件,找到contextMenuPolicy发现已经设置为DefaultContextMenu。到此应该知道,Qt默认为我们创好了默认菜单。
查看Qt文档可以证明我们的猜测是正确的。
Qt文档中解释了,默认属性是Qt::DefaultContextMenu,并且还有Qt::NoContextMenu、Qt::PreventContextMenu、Qt::ActionsContextMenu、Qt::CustomContextMenu。并且使用Qt::CustomContextMenu时,会发射一个customContextMenuRequested()信号。
这么一来,就很清晰了。
二、自定义槽函数接受信号
从上文可知,我们要想使用自定义方法。需要将属性值改了,如果我们在QTextEdit中修改属性,则
edit->setContextMenuPolicy(Qt::CustomContextMenu);
这样一来,右键就不会出现默认选项了。
并对QTextEdit连接了自定义槽函数,名称自定
connect(edit,&QTextEdit::customContextMenuRequested,this,&Widget::ShowMenu);
这样准备工作就完成了。
槽函数中我们需要创建一个菜单,并且添加选择,这里使用QAction。
再将QAction的成员连接个自功能,这样就实现了基础的菜单功能。
显示的位置在光标位置处,所以使用QCursor::pos()即可。
具体功能在槽函数里添加就行了。
void Widget::ShowMenu() { QMenu *menu = new QMenu(this); QStringList list; list << "copy" << "paste" << "save" << "close"; QList<QAction *> actList; for(int i = 0; i < list.count(); i ++) actList.append(new QAction(list.at(i))); connect(actList.at(0),&QAction::triggered,this,&Widget::CopyAction); connect(actList.at(1),&QAction::triggered,this,&Widget::PasteAction); connect(actList.at(2),&QAction::triggered,this,&Widget::SaveAction); connect(actList.at(3),&QAction::triggered,this,&Widget::CloseAction); menu->addActions(actList); menu->exec(QCursor::pos()); }
三、使用鼠标监听
重写
void mousePressEvent(QMouseEvent *event) override;
函数
需要判断鼠标点击事件是否是右击,如果不,则直接返回,如果是,执行和方法一一样的思路。
void Widget::mousePressEvent(QMouseEvent *event) { if(event->button() != Qt::RightButton) return; QMenu *menu = new QMenu(this); QStringList list; list << "copy" << "paste" << "save" << "close"; QList<QAction *> actList; for(int i = 0; i < list.count(); i ++) actList.append(new QAction(list.at(i))); connect(actList.at(0),&QAction::triggered,this,&Widget::CopyAction); connect(actList.at(1),&QAction::triggered,this,&Widget::PasteAction); connect(actList.at(2),&QAction::triggered,this,&Widget::SaveAction); connect(actList.at(3),&QAction::triggered,this,&Widget::CloseAction); menu->addActions(actList); menu->exec(QCursor::pos()); }
四、两分法对比
方法一针对的是某个组件实现的菜单功能。比如我对界面中的edit1组件使用了edit->setContextMenuPolicy(Qt::CustomContextMenu);,那么edit1就可以实现自定义功能。而edit2、edit3则没有。
方法二是监听鼠标事件,只要是右击就出现菜单,对程序整个窗口内都有效,包括空白区域。
两个方法实现的思路都是大同小异,在使用时看情况而分配吧。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持自由互联。

