当前位置: 首页 > news >正文

Qt中的鼠标事件

1.鼠标进入事件和鼠标离开事件

1.1添加新文件

1.2ui界面

拖出一个Label控件,修改frameShape为Box,使边框更明显

1.3代码实现

#ifndef MYLABEL_H
#define MYLABEL_H

#include <QLabel>

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

    //鼠标进入事件
    void enterEvent(QEvent *event);

    //鼠标离开
    void leaveEvent(QEnterEvent *);

signals:
};

#endif // MYLABEL_H
#include "mylabel.h"
#include"QDebug"

myLabel::myLabel(QWidget *parent)
    : QLabel{parent}
{}

//鼠标进入事件
void myLabel::enterEvent(QEnterEvent *event)
{
    qDebug()<<"鼠标进入了";
}

//鼠标离开
void myLabel::leaveEvent(QEvent *)
{
    qDebug()<<"鼠标离开了";
}

1.4结果展示

2.鼠标的按下、释放、移动事件

代码:

先在myLabel.h文件中声明

    //鼠标按下
    void mousePressEvent(QMouseEvent *ev);


    //鼠标释放
    void mouseReleaseEvent(QMouseEvent *ev);

    //鼠标移动
    void mouseMoveEvent(QMouseEvent *ev);

再在myLabel.cpp中实现

//鼠标按下
void myLabel::mousePressEvent(QMouseEvent *ev)
{
    qDebug()<<"鼠标按下了";
}

//鼠标释放
void myLabel::mouseReleaseEvent(QMouseEvent *ev)
{
    qDebug()<<"鼠标释放了";
}
//鼠标移动
void myLabel::mouseMoveEvent(QMouseEvent *ev)
{
    qDebug()<<"鼠标移动了";
}

运行结果:

注意:只有在按下时移动才会有打印

3.按下时的坐标

3.1基于控件

代码:

void myLabel::mousePressEvent(QMouseEvent *ev)
{
    QString str=QString("鼠标按下了 x=%1  y=%2").arg(ev->x()).arg(ev->y());
    qDebug()<<str;
}

只需将鼠标按下这段代码修改一下,%1就表示后面的第一个(.arg(ev->x())),%2就表示 第二个

这样就可以得到鼠标按下去时在Label控件中的位置

3.2基于屏幕

代码:

void myLabel::mousePressEvent(QMouseEvent *ev)
{
    QString str=QString("鼠标按下了 x=%1  y=%2").arg(ev->x()).arg(ev->y());
    qDebug()<<str;
}

同理鼠标释放、鼠标移动也可以这样修改

4.判断按键

鼠标的左键按下、释放才打印

代码:

//鼠标按下
void myLabel::mousePressEvent(QMouseEvent *ev)
{
    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)
{
    if(ev->button()==Qt::LeftButton)
    {
        qDebug()<<"鼠标释放了";
    }
}

移动

代码:

//鼠标移动
void myLabel::mouseMoveEvent(QMouseEvent *ev)
{
    if(ev->button()==Qt::LeftButton)
    {
        qDebug()<<"鼠标移动了";
    }
}

因为按下和释放是一个瞬时的操作,而移动是一个连续的操作,就不能这样判断,需要用与来判断

代码:

//鼠标移动
void myLabel::mouseMoveEvent(QMouseEvent *ev)
{
    if(ev->buttons() & Qt::LeftButton)
    {
        qDebug()<<"鼠标移动了";
    }
}

5.鼠标追踪

实现不按鼠标,只在Label控件中移动就打印移动信息

代码:

在构造函数的实现中写

myLabel::myLabel(QWidget *parent)
    : QLabel{parent}
{
    //设置鼠标追踪状态
    setMouseTracking(true);
}

将移动中判断按键的按钮注释掉

相关文章:

  • React七案例中
  • 函数指针数组的用途
  • 【现代深度学习技术】循环神经网络02:文本预处理
  • powerbi制作中国式复杂报表
  • Poission 时间点过程
  • 列表之链表_C
  • 三维空间中的离散曲线段匹配方法
  • 数据库学习
  • 程序化广告行业(73/89):买卖双方需求痛点及应对策略深度剖析
  • 通过可组合的数字体验平台(DXP)提升运营效率与个性化体验
  • echarts地图详解
  • spark课后总结
  • 【Java异步】解决@Async注解,同类下调用不生效
  • python自定义自己的类库
  • 基于django大数据平台的交通数据可视化设计与实现(源码+lw+部署文档+讲解),源码可白嫖!
  • pig 权限管理开源项目学习
  • 第 28 场 蓝桥入门赛 JAVA 完整题解
  • 训练数据清洗(文本/音频/视频)
  • 大数据 CDH 排除故障的步骤与技巧
  • AAAI 2025新研究!大语言模型+MARL=论文新思路?
  • 做移动网站建设/免费制作网站的软件
  • 视频怎么转wordpress/青海网站seo
  • 网站制作服务价格/每日舆情信息报送
  • 制作个人网站实例/百度市场应用官方app
  • 做国厂家的网站/seo中国
  • 如何用js做网站/长春seo网站管理