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的事件处理机制. ...
随机推荐
- codeforces round #419 B. Karen and Coffee
To stay woke and attentive during classes, Karen needs some coffee! Karen, a coffee aficionado, want ...
- 51nod 1686 第k大区间
1686 第K大区间 基准时间限制:1 秒 空间限制:131072 KB 分值: 40 难度:4级算法题 定义一个区间的值为其众数出现的次数.现给出n个数,求将所有区间的值排序后,第K大的值为多少. ...
- 2015 多校联赛 ——HDU5402(模拟)
For each test case, in the first line, you should print the maximum sum. In the next line you should ...
- VK-Cup2017 Wild Card Round 2
来自FallDream的博客,未经允许,请勿转载,谢谢. Cf的Vkcup外卡赛2 上次round2和ditoly翻车了 所以只好来打打了 规则是给一道比较特殊的题目,你要找出较优的解 Unive ...
- [APIO2014]
T1.回文树裸题. #include<cstdio> #include<iostream> #define ll long long using namespace std; ...
- String,StringBuilder,StringBuffer三者的区别
参考 String,StringBuilder,StringBuffer三者的区别 这三个类之间的区别主要是在两个方面,即运行速度和线程安全这两方面. 1.运行速度 首先说运行速度,或者说是执行速 ...
- 线性表 linear_list 顺序存储结构
可以把线性表看作一串珠子 序列:指其中的元素是有序的 注意last和length变量的内在关系 注意:将元素所占的空间和表长合并为C语言的一个结构类型 静态分配的方式,分配给一个固定大小的存储空间之后 ...
- 关于一些基础的Java问题的解答(四)
16. Java面向对象的三个特征与含义 java中的面向对象的三大基本特征分别是:封装.继承.多态: 封装:把过程和数据包围起来,对数据的访问只能通过已定义的界面,主要是方便类的修改 继承:对象的一 ...
- CRM客户关系管理系统(三)
第四章.kingadmin开发设计 4.1.kingadmin设计 自定义admin注册model的写法 crm/admin.py class CustomerAdmin(admin.ModelAdm ...
- 关于 minor allele frequency(次等位基因频率)的理解
引用自NCBI的概念(https://www.ncbi.nlm.nih.gov/projects/SNP/docs/rs_attributes.html#gmaf) Global minor alle ...