事件分发器——event()函数

事件过滤

事件进入窗口之前被拦截 eventFilter

#include "mywidget.h"
#include "ui_mywidget.h"
#include <QDebug> MyWidget::MyWidget(QWidget *parent) :
QWidget(parent),
ui(new Ui::MyWidget)
{
ui->setupUi(this);
// 给MyLabel 安装事件过滤器
// 参数 谁来过滤label 的事件
ui->mylabel->installEventFilter(this);
ui->label_2->installEventFilter(this);
} MyWidget::~MyWidget()
{
delete ui;
} void MyWidget::mousePressEvent(QMouseEvent *)
{
qDebug() << "+++++++++++++";
} bool MyWidget::eventFilter(QObject *obj, QEvent *e)
{
// 判断对象
if (obj == ui->mylabel) {
// 过滤事件
if (e->type() == QEvent::MouseMove)
{
ui->mylabel->setText("++++++++++");
return true;
}
}
if (obj == ui->label_2) {
if (e->type() == QEvent::MouseMove)
{
ui->label_2->setText("**********");
return true;
}
}
// 执行默认处理
return QWidget::eventFilter(obj,e);
}

mywidget.cpp

#include "mylabel.h"
#include <QMouseEvent>
#include <QTimerEvent>
#include <QTimer>
#include <QEvent> // QWidget 默认是不追踪鼠标事件的
MyLabel::MyLabel(QWidget *parent) : QLabel(parent)
{
// 设置窗口追踪鼠标键
this->setMouseTracking(true); // 启动定时器
// 参数 1: 触发定时器的时间, 单位: ms
// 参数2: 使用默认值
// 返回值: 定时器ID
id = startTimer();
id1 = startTimer(); // 第二种定时器用法
// QTimer * timer = new QTimer(this);
// timer->start(100);
// connect(timer, &QTimer::timeout, this, [=]()
// {
// static int number = 0;
// this->setText(QString::number(number++));
// }); } // 进入还是离开边界的一瞬间来完成的
// 鼠标进入
void MyLabel::enterEvent(QEvent *)
{
setText("你不要在我身上乱摸!!!!");
} // 鼠标离开
void MyLabel::leaveEvent(QEvent *)
{
setText("终于离开了...");
} void MyLabel::mousePressEvent(QMouseEvent *ev)
{
// 字符串拼接 QString().arg()
// %1, %2, %3 -- 占位符
QString btn;
if(ev->button() == Qt::LeftButton)
{
btn = "LeftButton";
}
else if(ev->button() == Qt::RightButton)
{
btn = "RightButton";
}
else if(ev->button() == Qt::MidButton)
{
btn = "MidButton";
}
QString str = QString("MousePree[%3]:(%1, %2)").arg(ev->x()).arg(ev->y()).arg(btn); setText(str);
} void MyLabel::mouseReleaseEvent(QMouseEvent *ev)
{
QString btn;
if(ev->button() == Qt::LeftButton)
{
btn = "LeftButton";
}
else if(ev->button() == Qt::RightButton)
{
btn = "RightButton";
}
else if(ev->button() == Qt::MidButton)
{
btn = "MidButton";
}
QString str = QString("MouseRelease[%3]:(%1, %2)").arg(ev->x()).arg(ev->y()).arg(btn); setText(str);
} void MyLabel::mouseMoveEvent(QMouseEvent *ev)
{
QString btn;
if(ev->buttons() & (Qt::LeftButton | Qt::RightButton))
{
btn = "LeftButton";
}
else if(ev->buttons() & Qt::RightButton)
{
btn = "RightButton";
}
else if(ev->buttons() & Qt::MidButton)
{
btn = "MidButton";
}
QString str = QString("MouseMove[%3]:(%1, %2)").arg(ev->x()).arg(ev->y()).arg(btn); setText(str);
} // 每触发一次定时器, 进入该函数中
void MyLabel::timerEvent(QTimerEvent *e)
{
QString str;
if(e->timerId() == id)
{
static int num = -;
str = QString("%1: %2").arg("Time out: ").arg(num++);
if(num >= )
{
// 关闭定时器
killTimer(id);
} }
else if(e->timerId() == id1)
{
static int num1 = ;
str = QString("%1: %2").arg("Time out: ").arg(num1++);
if(num1 >= +)
{
// 关闭定时器
killTimer(id1);
}
} setText(str);
} bool MyLabel::event(QEvent *e)
{
// 返回值
// true -- 代表事件被处理了,不再继续下发,停止了
// false -- 事件没有被处理,会继续向下分发
// 大概的处理步骤
// switch(e->type()){
// case QEvent::MouseMove:
// mouseMoveEvent(e);
// break;
// case QEvent::Timer:
// timerEvent(e);
// break;
// } // 过滤定时器事件
if (e->type() == QEvent::Timer) {
return true;// return false,将事件抛给父类
}
// else if (e->type() == QEvent::MouseMove) {
// return true;
// }
else if (e->type() == QEvent::MouseButtonPress) {
return false;
}
// 让父类执行默认的处理
return QLabel::event(e);
}

mylabel.cpp

#ifndef MYWIDGET_H
#define MYWIDGET_H #include <QWidget> namespace Ui {
class MyWidget;
} class MyWidget : public QWidget
{
Q_OBJECT public:
explicit MyWidget(QWidget *parent = nullptr);
~MyWidget();
void mousePressEvent(QMouseEvent *);
bool eventFilter(QObject *obj, QEvent *e);
private:
Ui::MyWidget *ui;
}; #endif // MYWIDGET_H

mywidget.h

#ifndef MYLABEL_H
#define MYLABEL_H #include <QWidget>
#include <QLabel> class MyLabel : public QLabel
{
Q_OBJECT
public:
explicit MyLabel(QWidget *parent = nullptr);
void enterEvent(QEvent *);
void leaveEvent(QEvent *);
void mousePressEvent(QMouseEvent *ev);
void mouseReleaseEvent(QMouseEvent *ev);
void mouseMoveEvent(QMouseEvent *ev);
void timerEvent(QTimerEvent *e);
bool event(QEvent *e);
private:
int id;
int id1;
signals: public slots:
}; #endif // MYLABEL_H

mylabel.h

(十三)事件分发器——event()函数,事件过滤的更多相关文章

  1. QT_8_Qt中的事件处理_定时器事件_定时器类_事件分发器_事件过滤器_绘图事件_高级绘图事件_绘图设备_QFile 文件读写_QFileInfo文件信息

    Qt中的事件处理 1.1. 捕获QLabel中是鼠标事件 1.2. enterevent 鼠标进入 1.3. leaveevent 鼠标离开 1.4. 鼠标按下MyLabel::mousePressE ...

  2. cocos2d JS 自定义事件分发器(接收与传递数据) eventManager

    简而言之,它不是由系统自动触发,而是人为的干涉 较多情况用于传递数据 var _listener1 = cc.EventListener.create({ event: cc.EventListene ...

  3. MySQL事件调度器Event Scheduler

    我们都知道windows的计划任务和linux的crontab都是用来实现一些周期性的任务和固定时间须要运行的任务. 在mysql5.1之前我们完毕数据库的周期性操作都必须借助这些操作系统实现. 在m ...

  4. Android事件分发机制三:事件分发工作流程

    前言 很高兴遇见你~ 本文是事件分发系列的第三篇. 在前两篇文章中,Android事件分发机制一:事件是如何到达activity的? 分析了事件分发的真正起点:viewRootImpl,Activit ...

  5. MySQL计划任务(事件调度器)(Event Scheduler)

    http://www.cnblogs.com/c840136/articles/2388512.html https://dev.mysql.com/doc/refman/5.7/en/events- ...

  6. MySQL事件调度器event的使用

    Q:假设,有一个需求,希望在某一个时刻系统调用一个begin end执行一下:十分钟以后执行一下begin end.亦或有一个需求,每个多长时间周期性执行begin end.那么这个时候该怎么办呢? ...

  7. MySQL计划任务(事件调度器)(Event Scheduler)[转]

    原文链接: http://www.cnblogs.com/c840136/articles/2388512.html MySQL5.1.x版本中引入了一项新特性EVENT,顾名思义就是事件.定时任务机 ...

  8. Android事件分发机制一:事件是如何到达activity的?

    事件分发,真的一定从Activity开始吗? 前言 很高兴遇见你~ 事件分发,android中一个老生常谈的话题了.基本的流程我们也都知道是从Activity开始分发,但有一个关键问题是:事件是如何到 ...

  9. Qt中事件处理的方法(三种处理方法,四种覆盖event函数,notify函数,event过滤,事件处理器。然后继续传递给父窗口。可观察QWidget::event的源码,它是虚拟保护函数,可改写)

    一.Qt中事件处理的方式   1.事件处理模式一 首先是事件源产生事件,最后是事件处理器对这些事件进行处理.然而也许大家会问, Qt中有这么多类的事件,我们怎么样比较简便的处理每个事件呢?设想,如果是 ...

随机推荐

  1. Javascript之高级数组API的使用实例

    JS代码中我们可以根据需求新建新的对象解决问题的同时,也有一些常用的内置对象供我们使用,我们称之为API,本篇文章只是对数组部分进行了练习. 例一:伪数组,不能修改长短的数组(所以没办法清零),可以修 ...

  2. vue中使用百度地图,悬浮窗搜索功能

    https://www.cnblogs.com/shuaifing/p/8185311.html 侵删 <template> <div id="all"> ...

  3. arcgis api 3.x for js 入门开发系列十四最近设施点路径分析(附源码下载)

    前言 关于本篇功能实现用到的 api 涉及类看不懂的,请参照 esri 官网的 arcgis api 3.x for js:esri 官网 api,里面详细的介绍 arcgis api 3.x 各个类 ...

  4. iOS----------适配iOS12

    library not found for -lstdc++.6.0.9 原因是苹果在XCode10和iOS12中移除了libstdc++这个库,由libc++这个库取而代之,苹果的解释是libstd ...

  5. HP LasterJet 3050驱动安装技巧,面向win7,8,8.1,10

    最近上咸鱼淘二手打印机,看中了这款打印机,HP官网一查发现还是有新驱动的,比较激动就下单买了,200元自提也不贵,打印效果勉强凑合,打印图片有不太明显的白线,不知是何原因····· 买来插上电脑,自动 ...

  6. python接口自动化-post请求4

    云盘登录实操案例: 代码参考: # coding:utf-8 import requests ''' https的请求相对于http安全级别高,需要验证SSL证书 import urllib3 使用这 ...

  7. HashMap源码分析(二)

    前言:上篇文章,笔者分析了jdk1.7中HashMap的源码,这里将对jdk1.8的HashMap的源码进行分析. 注:jdk版本:jdk1.8.0_172 1.再看put操作 public V pu ...

  8. codeforces div2 220 解题

    这套题我只写了a, b, c..  对不起,是我太菜了. A:思路:就是直接简化为一个矩阵按照特定的步骤从一个顶角走到与之对应的对角线上的顶角.如图所示. 解释一下特定的步骤,就像马走日,象走田一样. ...

  9. 基于jQuery实现简单的js模块化

    在多人合作完成网页,经常遇到大家的js代码相互影响的问题.现在有许多模块化的前端框架,应该是可以解决这个问题.但本人并非前端开发人员,那些框架都没用过,只对jQuery相对熟悉,就想用jQuery来解 ...

  10. BAT面试题:使用数组实现一个简单的阻塞队列

    这道题是我亲身经历的一道大厂面试题,非常值得分享! 这道题可以分为两个步骤进行编码解答,第一步是基于数组实现一个队列,第二步是实现线程阻塞. 如果是基于数组实现栈的数据结构,那么我们只需要一个指针进行 ...