拖动事件+滚轮事件

通过下面的小案例来记录一下这两个事件

拖动进入事件

当拖动文件进入到窗口/控件中时,触发该事件,它对应的子类是QDragEnterEvent

对应的枚举类型是:QEvent::DragEnter

需要重写的方法是:

void dragEnterEvent(QDragEnterEvent* ev) override

拖动离开事件

当拖动文件离开窗口/控件中时,触发该事件,它对应的子类是QDragLeaveEvent

对应的枚举类型是:QEvent::DragLeave

需要重写的方法是:

void dragLeaveEvent(QDragLeaveEvent* ev) override

拖动移动事件

当拖动文件在窗口/控件中移动时,触发该事件,它对应的子类是QDragMoveEvent

对应的枚举类型是:QEvent::DragMove

需要重写的方法是:

void dragMoveEvent(QDragMoveEvent* ev) override

拖动放入事件

当拖动文件在窗口/控件中释放时,触发该事件,它对应的子类是QDropEvent

对应的枚举类型是:QEvent::Drop

需要重写的方法是:

void dropEvent(QDropEvent* ev) override

drop事件默认是不接受的

需要调用窗口或控件的setAcceptDrops(true)方法

鼠标滚轮事件

当滚轮滚动时,触发该事件,它对应的子类是QWheelEvent

对应的枚举类型是:QEvent::Wheel

需要重写的方法是:

void wheelEvent(QWheelEvent* ev) override

常用方法

QDragEnterEvent:

ev->acceptProposedAction();//默认不接受拖动进来的文件,在重写拖动进入事件函数时调用该方法来可以接收拖动进来的文件

QDropEvent:

ev->mimeData();//该方法能够获取到拖进窗口然后放进来的文件的相关信息

QWheelEvent:

ev->angleDelta().y();//小于0,滚轮往前滚,大于0,滚轮往后滚

举例

自定义一个TextEdit,重写拖动进入事件、拖动放入事件,鼠标事件,让他可以接收拖动文件放入,并且可以按住ctrl+滚轮进行文字的缩小和放大

#ifndef MYTEXTEDIT_H
#define MYTEXTEDIT_H

#include <QWidget>
#include<QTextEdit>
#include<QDragEnterEvent>
#include<QDragLeaveEvent>
#include<QDragMoveEvent>
#include<QDropEvent>
#include<QMimeData>
#include<QFile>
#include<QApplication>
#include<QWheelEvent>

class MyTextEdit : public QTextEdit
{
    Q_OBJECT
public:
    explicit MyTextEdit(QWidget *parent = nullptr):QTextEdit{parent}
    {
        //接受drop事件,在构造函数中设置为接受
        this->setAcceptDrops(true);
    }

protected:
    void dragEnterEvent(QDragEnterEvent* ev) override
    {
        //默认不接受拖动事件拖动的东西,需要在拖动进入事件中打开,通过该方法
        ev->acceptProposedAction();
    }
    void dragLeaveEvent(QDragLeaveEvent* ev) override
    {

    }
    void dragMoveEvent(QDragMoveEvent* ev) override
    {

    }
    void dropEvent(QDropEvent* ev) override
    {
        //通过该方法获取到拖进来然后放进去的东西的链接
        QList<QUrl> urls =ev->mimeData()->urls();

        if(urls.empty())
        {
            return;
        }
        
        //获取到拖进来的文件的路径
        auto file_name=urls.first().toLocalFile();

        QFile file(file_name);
        //只读打开
        if(file.open(QIODevice::ReadOnly))
        {
            //读取所有内容
            setPlainText(file.readAll());
        }


    }

    //鼠标滚轮滚动事件(鼠标滚动时放大和缩小内容)
    void wheelEvent(QWheelEvent* ev) override
    {
        //通过该方法获取:鼠标滚轮滚动时按下了ctrl键
        if(QApplication::keyboardModifiers()==Qt::ControlModifier)
        {
            //鼠标滚轮滚动的变化量
            if(ev->angleDelta().y()<0)
            {
                //若小于0,则表示滚轮往前滚。进行放大
                this->zoomOut();
            }
            else
            {
                //若大于0,则表示滚轮往后滚。进行缩小
                this->zoomIn();
            }
        }
        else
        {
            //没有按ctrl键时,就执行父类自己的鼠标滚动事件处理函数
            QTextEdit::wheelEvent(ev);
        }

    }

};

#endif // MYTEXTEDIT_H

Qt中,可以通过重写QWidget类中的鼠标事件函数来处理鼠标事件,包括鼠标点击、移动、释放等。常用的鼠标事件函数有: - mousePressEvent(QMouseEvent *event):鼠标按下事件 - mouseMoveEvent(QMouseEvent *event):鼠标移动事件 - mouseReleaseEvent(QMouseEvent *event):鼠标释放事件 另外,在处理鼠标移动事件时,可以通过调用QWidget类中的setMouseTracking(bool enable)函数来开启或关闭鼠标跟踪功能,以便在鼠标移动时及时获取鼠标位置信息。 而处理鼠标滚轮事件,可以通过重写QWidget类中的wheelEvent(QWheelEvent *event)函数来实现。在该函数中,可以通过QWheelEvent类提供的delta()函数获取鼠标滚轮滚动的距离。 下面是一个简单的例子,演示了如何在QWidget窗口中处理鼠标事件滚轮事件: ```cpp #include <QtWidgets> class MyWidget : public QWidget { public: MyWidget(QWidget *parent = nullptr) : QWidget(parent) { setMouseTracking(true); // 开启鼠标跟踪功能 } protected: void mousePressEvent(QMouseEvent *event) override { if (event->button() == Qt::LeftButton) { qDebug() << "Left button pressed at" << event->pos(); } } void mouseMoveEvent(QMouseEvent *event) override { qDebug() << "Mouse moved to" << event->pos(); } void mouseReleaseEvent(QMouseEvent *event) override { if (event->button() == Qt::LeftButton) { qDebug() << "Left button released at" << event->pos(); } } void wheelEvent(QWheelEvent *event) override { qDebug() << "Mouse wheel rotated by" << event->delta(); } }; int main(int argc, char *argv[]) { QApplication app(argc, argv); MyWidget widget; widget.show(); return app.exec(); } ``` 在上面的例子中,我们重写了QWidget类中的mousePressEvent()、mouseMoveEvent()、mouseReleaseEvent()和wheelEvent()函数,分别处理鼠标按下、移动、释放和滚轮事件。同时,在构造函数中调用了setMouseTracking(true)函数开启鼠标跟踪功能。最后创建了一个MyWidget对象并显示出来。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值