Qt 事件处理 快捷键(重写eventFilter的函数,使用Qt::ControlModifier判断)
CTRL+Enter发送信息的实现
在现在的即时聊天程序中,一般都设置有快捷键来实现一些常用的功能,类似QQ可以用CTRL+Enter来实现信息的发送。
在QT4中,所有的事件都继承与QEvent这个类,以下是用QEvent来实现快捷键的功能。
首先所有QT类的基类QObject有一个成员函数installEventFilter,这个函数是用来将一个事件处理器和该QObject绑定起来,所以就有了我下面的想法。
首先在chat类定义一个eventFilter,该函数是一个虚函数,可以由子类进行更改。所以声明eventFilter如下:
virtual bool eventFilter(QObject *obj, QEvent *e);
看了下QT文档对于这个函数的声明的解释,大概意思就是如果你要过滤某个事件就返回false,如果要使用某个事件就返回true。
我想在这个函数中加入对Enter键和Ctrl+Enter组合键的判断,具体查看QKeyEvent类的文档
QKeyEvent类中有函数key和modifier,key函数返回的是发生时间的按键值,modifier返回的而是修饰键,QT所支持的修饰键如下:
Constant Value Description
Qt::NoModifier 0x00000000 No modifier key is pressed.
Qt::ShiftModifier 0x02000000 A Shift key on the keyboard is pressed.
Qt::ControlModifier 0x04000000 A Ctrl key on the keyboard is pressed.
Qt::AltModifier 0x08000000 An Alt key on the keyboard is pressed.
Qt::MetaModifier 0x10000000 A Meta key on the keyboard is pressed.
Qt::KeypadModifier 0x20000000 A keypad button is pressed.
Qt::GroupSwitchModifier 0x40000000 X11 only. A Mode_switch key on the keyboard is pressed.
所以可以重写eventFilter函数来实现快捷键的功能,可以根据QKeyEvent的key和modifire来分别是Enter还是Ctrl+enter被按下。
重写eventFilter的函数如下:
- bool Window::eventFilter(QObject *obj, QEvent *e)
- {
- Q_ASSERT(obj == ui.inputMsgEdit);
- if (e->type() == QEvent::KeyPress)
- {
- QKeyEvent *event = static_cast(e);
- if (event->key() == Qt::Key_Return && (event->modifiers() & Qt::ControlModifier))
- {
- sendMessage();
- return true;
- }
- }
- return false;
- }
然后把这个过滤器用installEventFilter函数安装在聊天窗口的输入框上(QTextEdit),这样就实现快捷键的功能了。
三键组合Shift + Ctrl + A的实现
只要在窗体中相应keyPressEvent事件函数即可。
- void Window::keyPressEvent(QKeyEvent *e)
- {
- if (e->modifiers() == (Qt::ShiftModifier | Qt::ControlModifier) && e->key() == Qt::Key_A)
- {
- //pressed
- }
- }
键盘按住Ctrl键 + 鼠标左键的实现
在窗体中相应mousePressEvent事件函数在其中检测Ctrl键是否按住即可。
- void Window::mousePressEvent(QMouseEvent *e)
- {
- // 获取鼠标在点击窗体上的坐标
- QPoint pos = e->pos();
- if (e->button() == LeftButton)
- {
- if ( QApplication::keyboardModifiers () == Qt::ControlModifier)
- {
- //pressed
- }
- }
- }
一个例子:
- #include "mainwindow.h"
- #include <QKeyEvent>
- #include <QMessageBox>
- #include <QDebug>
- #include <QShortcut>
- #include <QPushButton>
- #include <QHBoxLayout>
- #include <QAction>
- MainWindow::MainWindow(QWidget *parent) :
- QMainWindow(parent)
- {
- // 设置窗口布局
- QWidget *mainWidget = new QWidget(this);
- QPushButton *button1 = new QPushButton("MessageBoxA", this);
- QPushButton *button2 = new QPushButton("MessageBoxB", this);
- QHBoxLayout *layout = new QHBoxLayout(this);
- layout->addWidget(button1);
- layout->addWidget(button2);
- mainWidget->setLayout(layout);
- this->setCentralWidget(mainWidget);
- this->resize(200, 100);
- this->setWindowTitle("Test");
- // 创建QAction并设置快捷键
- QAction *actionA = new QAction(this);
- actionA->setShortcut(QKeySequence(tr("Ctrl+A")));
- // actionA->setShortcut(QKeySequence(Qt::CTRL + Qt::Key_A));
- QAction *actionB = new QAction(this);
- actionB->setShortcut(QKeySequence(tr("Ctrl+B")));
- // actionA->setShortcut(QKeySequence(Qt::CTRL + Qt::Key_B));
- // 给button添加快捷键
- // this->addAction(actionA);// 没用
- button1->addAction(actionA);// 必须将快捷键添加到按钮上,同时使keyPressEvent失效,无法捕捉到Ctrl+A
- button2->addAction(actionB);
- // 设置快捷键相应
- connect(actionA, &QAction::triggered, this, &MainWindow::button1_click);
- connect(actionB, &QAction::triggered, this, &MainWindow::button2_click);
- // 设置按钮点击事件相应
- connect(button1, &QPushButton::clicked, this, &MainWindow::button1_click);
- connect(button2, &QPushButton::clicked, this, &MainWindow::button2_click);
- // 占用快捷键,使keyPressEvent函数失效
- QShortcut *shortCut1 = new QShortcut(QKeySequence(tr("Delete")), this);
- QShortcut *shortCut2 = new QShortcut(QKeySequence(tr("Return")), this);
- // QShortcut *shortCut2 = new QShortcut(tr("Return"), this);
- }
- MainWindow::~MainWindow()
- {
- }
- // 如果快捷键被设置,keyPressevent就无法处理相应的按钮事件
- void MainWindow::keyPressEvent(QKeyEvent *event)
- {
- switch (event->key())
- {
- case Qt::Key_0:
- {
- qDebug() << Qt::Key_0;
- QMessageBox::about(NULL, "0", "0");
- break;
- }
- case Qt::Key_Return:// 被占用,失效
- {
- qDebug() << Qt::Key_Return;
- QMessageBox::about(NULL, "return", "return");
- break;
- }
- case Qt::Key_Delete:// 被占用,失效
- {
- qDebug() << Qt::Key_Delete;
- QMessageBox::about(NULL, "Delete", "Delete");
- break;
- }
- case QKeySequence::Delete:// 捕获不到,不能有这种方式处理
- {
- qDebug() << QKeySequence::Delete;
- QMessageBox::about(NULL, "QKeySequence::Delete", "QKeySequence::Delete");
- break;
- }
- case Qt::Key_F1:
- {
- qDebug() << Qt::Key_F1;
- QMessageBox::about(NULL, "F1", "F1");
- break;
- }
- case Qt::Key_O:// 处理组合快捷按钮
- {
- if (event->modifiers() & Qt::ControlModifier)
- {
- QMessageBox::about(NULL, "Ctr+O", "Ctr+O");
- }
- break;
- }
- case Qt::Key_A:// 被窗口button占用,失效,不能处理
- {
- if (event->modifiers() & Qt::ControlModifier)
- {
- QMessageBox::about(NULL, "Ctr+A", "Ctr+A");
- }
- break;
- }
- default:
- {
- qDebug() << event->key();
- }
- }
- // if (event->key() == Qt::Key_O)
- // {
- // if (event->modifiers() & Qt::ControlModifier)
- // {
- // QMessageBox::about(NULL, "Ctr+O", "Ctr+O");
- // }
- // }
- }
- void MainWindow::keyReleaseEvent(QKeyEvent *event)
- {
- }
- void MainWindow::button1_click()
- {
- QMessageBox::about(NULL, "MessageBoxA", "MessageBoxA");
- }
- void MainWindow::button2_click()
- {
- QMessageBox::about(NULL, "MessageBoxB", "MessageBoxB");
- }
http://blog.csdn.net/caoshangpa/article/details/77933937
原文链接:http://blog.csdn.net/yang382197207/article/details/45363967
原文链接:http://blog.csdn.net/xj626852095/article/details/12039093
Qt 事件处理 快捷键(重写eventFilter的函数,使用Qt::ControlModifier判断)的更多相关文章
- 【转】Qt 事件处理机制 (下篇)
转自:http://mobile.51cto.com/symbian-272816.htm 在Qt中,事件被封装成一个个对象,所有的事件均继承自抽象类QEvent. 接下来依次谈谈Qt中有谁来产生.分 ...
- Qt 事件处理机制 (下篇)
继续我们上一篇文章继续介绍,Qt 事件处理机制 (上篇) 介绍了Qt框架的事件处理机制:事件的产生.分发.接受和处理,并以视窗系统鼠标点击QWidget为例,对代码进行了剖析,向大家分析了Qt框架如何 ...
- Qt 学习之路 2(19):事件的接受与忽略(当重写事件回调函数时,时刻注意是否需要通过调用父类的同名函数来确保原有实现仍能进行!有好几个例子。为什么要这么做?而不是自己去手动调用这两个函数呢?因为我们无法确认父类中的这个处理函数有没有额外的操作)
版本: 2012-09-29 2013-04-23 更新有关accept()和ignore()函数的相关内容. 2013-12-02 增加有关accept()和ignore()函数的示例. 上一章我们 ...
- QT事件过滤器(QT事件处理的5个层次:自己覆盖或过滤,父窗口过滤,Application过滤与通知)
Qt事件模型一个真正强大的特色是一个QObject 的实例能够管理另一个QObject 实例的事件. 让我们试着设想已经有了一个CustomerInfoDialog的小部件.CustomerInfoD ...
- Qt 事件处理的五个层次
看了这篇文章(见http://devbean.blog.51cto.com/448512/231861),然后经过自己的思考,把Qt事件处理的五个层次.同时也是Qt时间处理的流程画了出来.若有不对请批 ...
- QT开发(十二)——QT事件处理机制
一.QT事件简介 QT程序是事件驱动的, 程序的每个动作都是由内部某个事件所触发.QT事件的发生和处理成为程序运行的主线,存在于程序整个生命周期. 常见的QT事件类型如下: 键盘事件: 按键按下和松开 ...
- Qt事件处理机制
研一的时候开始使用Qt,感觉用Qt开发图形界面比MFC的一套框架来方便的多.后来由于项目的需要,也没有再接触Qt了.现在要重新拾起来,于是要从基础学起. Now,开始学习Qt事件处理机制. 先给出原文 ...
- 9、Qt 事件处理机制
原文地址:http://mobile.51cto.com/symbian-272812.htm 在Qt中,事件被封装成一个个对象,所有的事件均继承自抽象类QEvent. 接下来依次谈谈Qt中有谁来产生 ...
- Qt 事件处理机制
Qt 事件处理机制 因为这篇文章写得特别好,将Qt的事件处理机制能够阐述的清晰有条理,并且便于学习.于是就装载过来了(本文做了排版,并删减了一些冗余的东西,希望原主勿怪),以供学习之用. 简介 在Qt ...
随机推荐
- HDU 5044 Tree(树链剖分)
HDU 5044 Tree field=problem&key=2014+ACM%2FICPC+Asia+Regional+Shanghai+Online&source=1&s ...
- TensorFlow中卷积
CNN中的卷积核及TensorFlow中卷积的各种实现 声明: 1. 我和每一个应该看这篇博文的人一样,都是初学者,都是小菜鸟,我发布博文只是希望加深学习印象并与大家讨论. 2. 我不确定的地方用了“ ...
- 百度UEditor上传图片-再总结一次
晚上,在继续开发BriefCMS,把百度UEditor上传图片的问题,给解决了,终于解决了. 公司极简版CMS.BriefCMS.个人官网,最近2个月,与百度UEditor厮杀了好久.最值得吐槽的,就 ...
- require.js的用法详解
require.js的诞生是为了解决两大问题,第一实现js文件的异步加载,避免网页失去响应,第二管理模块之间的依赖性,便于代码的编写和维护. 一.为什么要用require.js? 最早的时候,所有Ja ...
- [Android]TextView实现分散对齐(两端对齐)
TextView是个特别基础的Android控件,只要有文本基本就少不了它.但是最近在项目开发的过程中我发现TextView存在很多局限性,其中最令我头疼的就是TextView文本排版方面的问题.我们 ...
- window.url.createobjecturl 兼容多种浏览器(IE,google,360,Safari,firefox)
<script type="text/javascript"> function setImagePreview() { var docObj = document.g ...
- 讨论IM软件企业知识—会谈session的概念,附连到IM软件层次图
session通常当今计算机领域,IM软体session.老IM那里有两个:第一个是逻辑层session参与者管理会议.新闻列表,会话类型等:有协议层session.主要代表client随着serve ...
- Light libraries是一组通用的C基础库,目标是为减少重复造轮子而写(全部用POSIX C实现)
Light libraries是一组通用的C基础库,目标是为减少重复造轮子而写实现了日志.原子操作.哈希字典.红黑树.动态库加载.线程.锁操作.配置文件.os适配层.事件驱动.工作队列.RPC.IPC ...
- 浅析JAVA的垃圾回收机制(GC)
1.什么是垃圾回收? 垃圾回收(Garbage Collection)是Java虚拟机(JVM)垃圾回收器提供的一种用于在空闲时间不定时回收无任何对象引用的对象占据的内存空间的一种机制. 注意:垃圾回 ...
- c语言学习笔记(2)——预备知识
c语言预备知识 1.cpu 内存条 硬盘 显卡 主板显示器 之间的关系 硬盘里的<猛龙过江>(双击)--->内存条 cpu---->显卡,声卡--->显示器 2.he ...