19.QT-事件发送函数sendEvent()、postEvent()
时间:2022-05-30
本文章向大家介绍19.QT-事件发送函数sendEvent()、postEvent(),主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
Qt发送事件分为两种
-阻塞型事件发送
- 需要重写接收对象的event()事件处理函数
- 当事件发送后,将会立即进入event()事件处理函数进行事件处理
- 通过sendEvent()静态函数实现阻塞发送:
bool QApplication::sendEvent ( QObject * receiver, QEvent * event ) ;
// receiver:接收对象, event :要发送的event类型(比如:鼠标双击)
//当有事件发送,将会调用receiver对象里的event()成员函数进行事件处理
- sendEvent()函数是阻塞式的,所以支持栈空间/堆空间事件对象的发送(局部对象和new分配的对象)
- new分配的事件对象被处理后,会由Qt内部自动摧毁
-非阻塞型事件发送
- 需要重写接收对象的event()事件处理函数
- 当事件发送后立即返回,事件将会发送到事件队列中等待处理
- 通过postEvent()静态函数实现非阻塞发送:
void QApplication::postEvent ( QObject * receiver, QEvent * event );
- postEvent()函数是非阻塞式的,所以只能支持栈堆空间事件对象的发送(new分配的对象)
- new分配的事件对象被处理后,会由Qt内部自动摧毁
示例-通过sendEvent()发送预定义的键盘Delete按键事件
Wiget.h
#ifndef WIDGET_H
#define WIDGET_H
#include <QWidget>
#include <QtGui>
class Widget : public QWidget
{
Q_OBJECT
private :
QTextEdit edit;
QPushButton bt;
private slots:
void onPushButton();
public:
explicit Widget();
};
#endif // WIDGET_H
Widget.c
#include "widget.h"
Widget::Widget() : edit(this),bt("Delete",this)
{
edit.setGeometry(0,0,300,200);
bt.setGeometry(310,20,48,32);
connect(&bt, SIGNAL(clicked()), this, SLOT(onPushButton()));
}
void Widget::onPushButton()
{
int key = Qt::Key_Delete ;
QKeyEvent EventPress(QEvent::KeyPress,key,Qt::NoModifier);
QApplication::sendEvent(&edit,&EventPress); //发送键盘按下事件
QKeyEvent EventRelease(QEvent::KeyRelease,key,Qt::NoModifier);
QApplication::sendEvent(&edit,&EventRelease); //发送键盘松开事件
}
效果
自定义事件对象
- 自定义的事件类必须继承自QEvent,并且无需指定父类
- 自定义的事件类必须拥有全局唯一的Type值,使用QEvent::User+value即可
- 自定义事件类示例:
class StringEvent : public QEvent
{
public:
static const Type = static_cast<Type>(QEvent::User+0x10);
explicit QStringEvent();
//... ...
}
QStringEvent::QStringEvent() :
QEvent(TYPE) //注册TYPE值
{
//... ...
}
- 由于Qt不认识自定义事件,所以程序里需要提供处理自定义事件对象的方法
常用两种方法来处理
1.通过事件过滤器处理
- 通过installEventFilter()安装到目标对象
- 在eventFilter()函数里处理事件
2.重写目标对象的event()函数
- 在event ()函数里处理事件
示例-通过单击鼠标按钮发送自定义事件QStringEvent
QStringEvent文件:
class QStringEvent : public QEvent
{
private:
QString mstr;
public:
const static Type TYPE = static_cast<Type>(QEvent::User+0x10);
explicit QStringEvent(QString s);
QString str();
};
QStringEvent::QStringEvent(QString s) :
QEvent(TYPE)
{
mstr = s;
}
QString QStringEvent::str()
{
return mstr;
}
widget文件:
class Widget : public QWidget
{
private :
QLabel label;
bool event( QEvent * e);
bool eventFilter(QObject *obj, QEvent *event);
public:
explicit Widget();
};
Widget::Widget() : label(this)
{
label.installEventFilter(this);
}
bool Widget::event( QEvent * e)
{
if(e->type() == QEvent::MouseButtonPress)
{
QMouseEvent *me = dynamic_cast<QMouseEvent* >(e);if(me->button() == Qt::LeftButton)
{
QStringEvent event( QString("X坐标: %1 Y坐标: %2").arg(me->x()).arg(me->y()) );
QApplication::sendEvent(&label,&event); //发送自定义事件
}
}
return QWidget::event(e);
}
bool Widget::eventFilter(QObject *obj, QEvent *event)
{
QLabel *t = dynamic_cast<QLabel* >(obj);
if(t && event->type()== QStringEvent::TYPE )
{
QStringEvent *str = dynamic_cast<QStringEvent* >(event);
t->setText(str->str());
t->adjustSize();
return true;
}
return QWidget::eventFilter(obj,event);
}
效果:
- docker学习(3) 容器的启动过程
- 基础野:细说原码、反码和补码
- JavaScript循环读书笔记
- docker学习(2) mac中docker-machine使用vmware fusion以及配置国内镜像加速
- HttpClient(一)HttpClient抓取网页基本信息
- Httpd运维日志:通过apxs添加模块
- 探索客户端JavaScript
- docker学习(8) 在mac机上搭建私有仓库
- Jsoup(一)Jsoup详解(官方)
- Ajax几种常用模式
- dubbox升级spring到4.x及添加log4j2支持
- CSS魔法堂:Absolute Positioning就这个样
- MongoDB(一)环境搭建与初始配置
- AI进了直播间,这画风666
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 使用SAP Analysis Path Framework (APF)展示CDS view数据
- 基于docker封装prometheus解决时区问题
- Node.js 如何处理 ES6 模块
- 关于Hive使用的一些实例
- 134. 加油站 Krains 2020-08-20 14:03:21 前缀和贪心
- 53. 最大子序和 Krains 2020-08-20 10:46:24 动态规划前缀和
- 如何用Unity导出H5与小游戏的3D场景
- 设计模式 之 模板模式
- java基础:注解的定义与使用
- 使用 vagrant 从搭建 gitlab server 开始体验整个 gitlab CI/CD 过程
- 纲手推荐程序笔记1-p5.js创意游戏编程
- 由浅入深彻底了解 Python 闭包和装饰器
- leetcode1078 Occurrences After Bigram
- 负二进制加法实现
- 如何在O(1)时间复杂度下实现LRU