event事件分发器

genius 

事件分发器:用于事件的分发,可以进行事件拦截的操作。事件分发器返回布尔类型:bool event(QEvent ev),如果返回值为true,代表用户自己处理该事件,否者交给基类实现事件。

下方图可以看出当事件发生时需要有一个事件分发器来管理这个事件的处理走向

在qt助手中可以看到有很多事件,其中红色框的是鼠标事件

 下面我们利用事件分发器实现对鼠标点击事件的拦截,废话不多说,上代码

myLabel.h:

#ifndef MYLABEL_H
#define MYLABEL_H

#include <QLabel>

class myLabel : public QLabel
{
    Q_OBJECT
public:
    explicit myLabel(QWidget *parent = nullptr);

    //鼠标进入事件
    void enterEvent(QEnterEvent *) ;
    //鼠标离开事件
    void leaveEvent(QEvent *);
    //鼠标点击事件
   virtual void mousePressEvent(QMouseEvent *ev);
    //鼠标松开事件
   virtual void mouseReleaseEvent(QMouseEvent *ev);
    //鼠标移动事件
   virtual void mouseMoveEvent(QMouseEvent *ev);

   //事件分发
   bool event(QEvent *e);
signals:

};

#endif // MYLABEL_H

 myLabel..cpp:

#include "mylabel.h"
#include<QDebug>
#include<QMouseEvent>

myLabel::myLabel(QWidget *parent)
    : QLabel{parent}
{
    //设置鼠标追踪:不用点击才打印坐标
    setMouseTracking(true);
}
//鼠标进入事件
void myLabel::enterEvent(QEnterEvent *) {
    qDebug()<<"鼠标进来了";
}
//鼠标离开事件
void myLabel::leaveEvent(QEvent *){
  qDebug()<<"鼠标出去了";
}
//鼠标点击事件
void myLabel::mousePressEvent(QMouseEvent *ev){
  //qDebug()<<"鼠标按下了";
  //只反馈左键
  if(ev->button() == Qt::LeftButton){
    //格式化字符串
    QString str = QString("鼠标按下了 x = %1 , y = %2 , globalX = %3 , globalY = %4").arg(ev->x()).arg(ev->y()).arg(ev->globalX()).arg(ev->globalY());
    qDebug()<<str;
 }
}

//鼠标松开事件
void myLabel::mouseReleaseEvent(QMouseEvent *ev){
  //qDebug()<<"鼠标松开了";
  //只反馈左键
  if(ev->button() == Qt::LeftButton){
    //格式化字符串
    QString str = QString("鼠标松开了 x = %1 , y = %2 , globalX = %3 , globalY = %4").arg(ev->x()).arg(ev->y()).arg(ev->globalX()).arg(ev->globalY());
    qDebug()<<str;
  }
}
//鼠标移动事件
void myLabel::mouseMoveEvent(QMouseEvent *ev){
  //qDebug()<<"鼠标按下并移动了";
  //只反馈左键
  if(ev->buttons() & Qt::LeftButton){
    //格式化字符串
    QString str = QString(" x = %1 , y = %2 , globalX = %3 , globalY = %4").arg(ev->x()).arg(ev->y()).arg(ev->globalX()).arg(ev->globalY());
    qDebug()<<str;
  }
}

//事件分发实现
bool myLabel::event(QEvent *e){
  //如果是鼠标按下了,在event事件分发器中做拦截操作
  if(e->type() == QEvent::MouseButtonPress){
    QMouseEvent *ev = static_cast<QMouseEvent *>(e);//将e强制转换成QMouseEvent类型
    QString str = QString("Event:鼠标按下了 x = %1 , y = %2 , globalX = %3 , globalY = %4").arg(ev->x()).arg(ev->y()).arg(ev->globalX()).arg(ev->globalY());
    qDebug()<<str;

    return true;//代表用户自己处理
  }

  //其他时间交给父类处理(默认处理)
  return QLabel::event(e);
}

下图红框标记表示拦截成功

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
下面是一个简单的案例,演示如何使用全局事件分发和局部事件分发。 假设我们有一个主窗口 MainWindow,其中包含一个按钮 button。我们想要在用户点击按钮时执行一些操作,同时也想要在用户在窗口中移动鼠标时输出鼠标坐标。 ```python from PyQt5.QtWidgets import QApplication, QMainWindow, QPushButton from PyQt5.QtCore import QEvent, Qt class MainWindow(QMainWindow): def __init__(self): super().__init__() self.setWindowTitle('事件分发示例') self.setGeometry(100, 100, 400, 300) # 创建一个按钮 self.button = QPushButton('按钮', self) self.button.setGeometry(100, 100, 100, 50) # 将按钮的点击事件连接到槽函数 self.button.clicked.connect(self.on_button_clicked) # 安装全局事件过滤 qapp = QApplication.instance() qapp.installEventFilter(self) def on_button_clicked(self): print('按钮被点击了!') def eventFilter(self, obj, event): if event.type() == QEvent.MouseMove and obj == self: print('鼠标移动到了坐标:', event.pos()) return super().eventFilter(obj, event) if __name__ == '__main__': app = QApplication([]) window = MainWindow() window.show() app.exec_() ``` 在上面的代码中,我们创建了一个 MainWindow 窗口,其中包含一个按钮 button。我们将按钮的点击事件连接到 on\_button\_clicked 槽函数中。 我们还安装了一个全局事件过滤,以便在应用程序中捕获所有事件。在事件过滤中,我们检查了事件类型是否为鼠标移动事件,并且检查了事件对象是否为 MainWindow 窗口。如果是,则输出鼠标坐标。 当用户在窗口中移动鼠标时,我们可以看到鼠标坐标被输出到控制台。当用户点击按钮时,我们也可以看到按钮被点击了的消息被输出到控制台。这说明我们成功地使用了全局事件分发和局部事件分发

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值