3.QT事件处理,消息过滤器
1
新建一个项目:06Event
新建cpp文件
|
06Event.pro |
|
HEADERS MyWidget.h SOURCES MyWidget.cpp QT |
|
MyWidget.h |
|
#ifndef #define #include #include #include class { Q_OBJECT public: explicit bool void void void /*不要用,因为它默认调用两次mousePressEvent*/ //void void void void //void //void void QPushButton* QLineEdit* signals: public void }; #endif |
|
MyWidget.cpp |
#include "MyWidget.h" #include <QApplication> #include <QEvent> #include <QDebug> #include <QMouseEvent> #include <QKeyEvent> #include <QVBoxLayout> #include <QPainter> MyWidget::MyWidget(QWidget *parent) : QWidget(parent) {
// QVBoxLayout* lay = new QVBoxLayout(this); #if 0 QPushButton* button2; lay->addWidget(button = new QPushButton("OK", this));
lay->addWidget(button2 = new QPushButton("Button2"));
//设置它为默认的焦点,当点击tab键之后可以切换焦点 button->setDefault(true); // 鼠标不需要按下,mouseMove就能得到调用 this->setMouseTracking(true); connect(button2, SIGNAL(clicked()), this, SLOT(slotButtonClicked())); connect(button, SIGNAL(clicked()), this, SLOT(slotButtonClicked())); #endif // lay->addWidget(edit = new QLineEdit()); // connect(edit, SIGNAL(returnPressed()), this, SLOT(slotButtonClicked())); } //通过这一句实现点击按钮的时候获得按钮上的text()内容 void MyWidget::slotButtonClicked() {
QLineEdit* button = (QLineEdit*)sender(); qDebug() << button->text(); } /* QApplication先得到->具体应该处理的窗口::event()->event()根据消息类型来调用具体的虚函数 */ /* 1)可以重载具体的虚函数,来实现对消息的响应 2)可以重载event函数,用来处理或者截取消息 */ /* 截取消息 */ bool MyWidget::event(QEvent *ev) {
// 鼠标消息被截断 // if(ev->type() == QEvent::MouseButtonPress) // return true; ev->accept(); return QWidget::event(ev); } /** * @brief MyWidget::closeEvent 窗口关闭的事件 */ void MyWidget::closeEvent(QCloseEvent *) {
qDebug() << "closeEvent"; } void MyWidget::paintEvent(QPaintEvent *) {
QPainter p(this); //通过下面的方式实现画线 p.drawLine(QPoint(0, 0), QPoint(100, 100)); } /** * @brief MyWidget::mousePressEvent 鼠标按下的事件 * @param ev */ void MyWidget::mousePressEvent(QMouseEvent *ev) {
#if 0 QPoint pt = ev->pos(); qDebug() << pt; //如果鼠标按下的是左键的处理 if(ev->button() == Qt::LeftButton){}
//如果按下的Shift键了 if(ev->modifiers() == Qt::ShiftModifier) {
qDebug() << "shift press"; } #endif //改进办法:先判断是否有左键,然后如果判断是否还按了Ctrl键 if(ev->button() == Qt::LeftButton) {
if(ev->modifiers() == Qt::ControlModifier) {
// handle with Control; return; } // handle2 without control; } else {}
} /** * @brief MyWidget::mouseReleaseEvent 鼠标释放的按键 */ void MyWidget::mouseReleaseEvent(QMouseEvent *){}
/** * @brief MyWidget::mouseMoveEvent 鼠标移动的事件 */ void MyWidget::mouseMoveEvent(QMouseEvent *) {
static int i=0; qDebug() << "mouse move"<< i++; } /** * @brief MyWidget::keyPressEvent 鼠标按下的事件,通过这个可以获得按下的键 * @param ev */ void MyWidget::keyPressEvent(QKeyEvent *ev) {
ev->modifiers(); int key = ev->key(); qDebug() << key; char a = key; qDebug() << (char)a; } /** * @brief MyWidget::keyReleaseEvent 按键释放的事件 */ void MyWidget::keyReleaseEvent(QKeyEvent *){}
int main(int argc, char* argv[]) {
QApplication app(argc, argv); MyWidget w; w.show(); return app.exec(); } |
运行结果: |
2
QT消息过滤器
|
EventFilter.pro |
|
HEADERS MyWidget.h MyApplication.h SOURCES MyWidget.cpp MyApplication.cpp QT |
|
MyWidget.h |
#ifndef MYWIDGET_H #define MYWIDGET_H #include <QWidget> #include <QPushButton> class MyWidget : public QWidget {
Q_OBJECT public: explicit MyWidget(QWidget *parent); QPushButton* _button; bool eventFilter(QObject *, QEvent *); bool event(QEvent *); signals: public slots: }; #endif // MYWIDGET_H |
|
MyWidget.cpp |
#include "MyWidget.h" #include <QPushButton> #include <QEvent> #include "MyApplication.h" #include <QDebug> #include <QApplication> MyWidget::MyWidget(QWidget *parent) : QWidget(parent) {
QPushButton* button; button = new QPushButton("This button", this);
connect(button, SIGNAL(clicked()), this, SLOT(close())); _button = button; /*button给自己安装了一个消息过滤器,那么经过button的消息, * 都先要调用它的过滤器的eventFilter函数*/ button->installEventFilter(this); } bool MyWidget::eventFilter(QObject *o, QEvent *e) {
#if 0 if(0 == (QObject*)_button &&( e->type() == QEvent::MouseButtonRelease || e->type() == QEvent::MouseButtonDblClick || e->type() == QEvent::MouseButtonPress)) {
return true; } #endif return QWidget::eventFilter(o,e); } bool MyWidget::event(QEvent *e) {
if(e->type() == QEvent::User) {
qDebug() << "User event is comming"; } return QWidget::event(e); } int main(int argc,char *argv[]) {
MyApplication app(argc,argv); MyWidget w; w.show(); //发送一个Event给MyWidget qDebug() << "begin send"; app.postEvent(&w,new QEvent(QEvent::User)); qDebug() << "end send"; return app.exec(); } |
|
MyApplication.h |
#ifndef MYAPPLICATION_H #define MYAPPLICATION_H #include <QApplication> class MyApplication : public QApplication {
Q_OBJECT public: MyApplication(int argc,char *argv[]):QApplication(argc,argv) {}
bool notify(QObject *,QEvent *); signals: public slots: }; #endif // MYAPPLICATION_H |
|
MyApplication.cpp |
#include "MyApplication.h" #include <QEvent> #include <QDebug> bool MyApplication::notify(QObject *o, QEvent *e) {
if(this->topLevelWidgets().count()>0) {
QWidget* mainWnd = this->topLevelWidgets().at(0); if(o==(QObject*)mainWnd && e->type() == QEvent::MouseButtonPress) {
// do ... qDebug() << "mainwnd is clicked"; } } return QApplication::notify(o, e); } |
|
运行结果: |
3.QT事件处理,消息过滤器的更多相关文章
- Qt事件处理机制
研一的时候开始使用Qt,感觉用Qt开发图形界面比MFC的一套框架来方便的多.后来由于项目的需要,也没有再接触Qt了.现在要重新拾起来,于是要从基础学起. Now,开始学习Qt事件处理机制. 先给出原文 ...
- 【转】Qt 事件处理机制 (下篇)
转自:http://mobile.51cto.com/symbian-272816.htm 在Qt中,事件被封装成一个个对象,所有的事件均继承自抽象类QEvent. 接下来依次谈谈Qt中有谁来产生.分 ...
- 9、Qt 事件处理机制
原文地址:http://mobile.51cto.com/symbian-272812.htm 在Qt中,事件被封装成一个个对象,所有的事件均继承自抽象类QEvent. 接下来依次谈谈Qt中有谁来产生 ...
- Qt 事件处理机制
Qt 事件处理机制 因为这篇文章写得特别好,将Qt的事件处理机制能够阐述的清晰有条理,并且便于学习.于是就装载过来了(本文做了排版,并删减了一些冗余的东西,希望原主勿怪),以供学习之用. 简介 在Qt ...
- QT开发(十二)——QT事件处理机制
一.QT事件简介 QT程序是事件驱动的, 程序的每个动作都是由内部某个事件所触发.QT事件的发生和处理成为程序运行的主线,存在于程序整个生命周期. 常见的QT事件类型如下: 键盘事件: 按键按下和松开 ...
- Qt 事件处理机制 (下篇)
继续我们上一篇文章继续介绍,Qt 事件处理机制 (上篇) 介绍了Qt框架的事件处理机制:事件的产生.分发.接受和处理,并以视窗系统鼠标点击QWidget为例,对代码进行了剖析,向大家分析了Qt框架如何 ...
- 【转】解读Qt 事件处理机制(上篇)
[转自]:http://mobile.51cto.com/symbian-272812.htm 在Qt中,事件被封装成一个个对象,所有的事件均继承自抽象类QEvent. 接下来依次谈谈Qt中有谁来产生 ...
- Qt5学习笔记(消息过滤器)
T06EventFilter.pro HEADERS += \ MyWidget.h SOURCES += \ MyWidget.cpp QT += widgets gui MyWidget.h #i ...
- Qt 事件处理机制 (上篇)
本篇来介绍Qt 事件处理机制 .深入了解事件处理系统对于每个学习Qt人来说非常重要,可以说,Qt是以事件驱动的UI工具集. 大家熟知Signals/Slots在多线程的实现也依赖于Qt的事件处理机制. ...
随机推荐
- C++Primer学习——类
我们在创建类的对象时,类不应该仅仅被声明,还应该被定义过,否则无法知道类占用了多少的内存 但是如果一个类的名字已经出现过就被认为是已经声明过了,所以允许包含自己的指针或者引用. 默认构造函数: 当类中 ...
- 【uva 1411 Ants蚂蚁们】
题目大意: ·给你一个n,表示输入n个白点和n个黑点(输入每一个点的坐标).现在需要将各个白点和各个黑点一一用线段连接起来,需要满足这些线段不能够相交. ·特色: 我们如何保证线段间不相交. ·分析: ...
- hdu 4288 离线线段树+间隔求和
Coder Time Limit: 20000/10000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Su ...
- 图像融合之拉普拉斯融合(laplacian blending)
一.拉普拉斯融合基本步骤 1. 两幅图像L,R,以及二值掩模mask,给定金字塔层数level. 2. 分别根据L,R构建其对应的拉普拉斯残差金字塔(层数为level),并保留高斯金字塔下采样最顶端的 ...
- C++Sizeof与Strlen的区别与联系
一.sizeof sizeof(...)是运算符,在头文件中typedef为unsigned int,其值在编译时即计算好了,参数可以是数组.指针.类型.对象.函数等. 它的功能是:获得保 ...
- DDD实战进阶第一波(七):开发一般业务的大健康行业直销系统(实现产品上下文接口与测试)
前一篇文章我们介绍了如何将创建产品的领域逻辑与产品的持久化仓储通过上架产品的用例组织起来,完成了一个功能.在实际的项目中,多种前端的形态比如PC Web. 微信小程序.原生APP等要调用后端的功能,通 ...
- 开发网页时,127.0.0.1或者localhost能访问,而本机地址不能访问的解决
第一 ping试试 127.0.0.1 和 本机地址 若127.0.0.1可以 说明可以自己ping自己 若本机地址可以 说明host正常 第二 检查服务器部署 再部署一个新的 若新的正常 说明你项目 ...
- 传统方法过渡到ES6去优雅地实现JavaScript的继承
众所周知,面向对象编程有三个重要的概念: 封装.继承.多态.而JS作为面向对象的弱类型语言,应该说是基于对象的语言,正如常说的,JS的世界里,万物皆对象.虽然JS本身不是面向对象的语言,我们可以通过模 ...
- Python小代码_1_九九乘法表
Python小代码_1_九九乘法表 max_num = 9 row = 1 while row <= max_num: col = 1 while col <= row: print(st ...
- Jmeter_ForEach控制器实现网页爬虫
一直以来,爬虫似乎都是写代码去实现的,今天像大家介绍一下Jmeter如何实现一个网页爬虫! Jmeter的爬虫原理其实很简单,就是对网页提交一个请求,然后把返回的所有href提取出来,利用ForEac ...