Qt 拖动事件

5 篇文章 0 订阅


在这里插入图片描述

QEvent::DragEnter

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

QEvent::DragLeave

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

QEvent::DragMove

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

QEvent::Drop

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

1 自定义控件 TextEdit

自定义一个标签控件TextEditx,让它继承自QTextEdit,然后重写拖放相关的函数。

添加自定义控件类TextEditX ,在 texteditx.h 文件中

// TextEditX.h
protected:
    // 重写父类的方法
    void dragEnterEvent(QDragEnterEvent *e);
    void dragMoveEvent(QDragMoveEvent *e);
    void dragLeaveEvent(QDragLeaveEvent *e);
    void dropEvent(QDropEvent *e);

texteditx.cpp 文件中

// TextEditX.cpp
TextEditX::TextEditX(QWidget *parent) : QTextEdit{parent} {
    // 部件将接受鼠标拖放事件
    this->setAcceptDrops(true);
}

void TextEditX::dragEnterEvent(QDragEnterEvent *e) {
    qDebug() << "dragEnterEvent";
    // 默认情况下,窗口部件不接受拖动
    e->acceptProposedAction();
}

void TextEditX::dragMoveEvent(QDragMoveEvent *e) {
    qDebug() << "dragMoveEvent";
}

void TextEditX::dragLeaveEvent(QDragLeaveEvent *e) {
    qDebug() << "dragLeaveEvent";
}

void TextEditX::dropEvent(QDropEvent *e) {
    qDebug() << "dropEvent";
}

2 实现打开文件功能

texteditx.cpp文件中

// texteditx.cpp
void TextEditX::dropEvent(QDropEvent *e) {
    qDebug() << "dropEvent";
    QList<QUrl> urls = e->mimeData()->urls();
    if (urls.isEmpty()) {
        return;
    }
    // 获取这个文件名
    QString fileName = urls.first().toLocalFile();
    qDebug() << urls.first() << "\n" << fileName;

    // 打开文件
    QFile file(fileName);

    // 打开失败返回 false
    if (file.open(QIODevice::ReadOnly)) {
        setPlainText(file.readAll());
    }
}

3 实现鼠标滚轮放大字体

texteditx.h 文件中

protected:
    // 重写滚轮事件
    void wheelEvent(QWheelEvent *e);

texteditx.cpp 文件中

void TextEditX::wheelEvent(QWheelEvent *e) {
    if (QApplication::keyboardModifiers() == Qt::ControlModifier) {
        if (e->angleDelta().y() > 0) {
            // 滚轮远离使用者, 进行放大
            this->zoomIn();
        } else {
            // 滚轮靠近使用者, 进行缩小
            this->zoomOut();
        }
    } else {
        // 调用父类的实现, 否则无法实现文本的上下滚动
        QTextEdit::wheelEvent(e);
    }
}
  • 6
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Qt 中,拖拽事件需要重写 QWidget 或其子类的以下方法: 1. void mousePressEvent(QMouseEvent *event):当鼠标按下时触发,通常在此方法中开始拖拽操作。 2. void mouseMoveEvent(QMouseEvent *event):当鼠标移动时触发,通常在此方法中更新拖拽操作的状态。 3. void mouseReleaseEvent(QMouseEvent *event):当鼠标释放时触发,通常在此方法中结束拖拽操作。 下面是一个简单的示例,演示了如何在一个 QLabel 控件中实现拖拽操作: ```cpp #include <QLabel> #include <QMouseEvent> class DragLabel : public QLabel { public: DragLabel(QWidget *parent = nullptr) : QLabel(parent) {} protected: void mousePressEvent(QMouseEvent *event) override { if (event->button() == Qt::LeftButton) { // 开始拖拽操作 QDrag *drag = new QDrag(this); QMimeData *mimeData = new QMimeData; mimeData->setText(text()); drag->setMimeData(mimeData); drag->exec(Qt::MoveAction); } } void mouseMoveEvent(QMouseEvent *event) override { if (event->buttons() & Qt::LeftButton) { // 更新拖拽状态 QPixmap pixmap = grab(); QDrag *drag = new QDrag(this); QMimeData *mimeData = new QMimeData; mimeData->setText(text()); drag->setMimeData(mimeData); drag->setPixmap(pixmap); drag->setHotSpot(event->pos()); drag->exec(Qt::MoveAction); } } void mouseReleaseEvent(QMouseEvent *event) override { // 结束拖拽操作 QLabel::mouseReleaseEvent(event); } }; ``` 在上面的代码中,我们重写了 QWidget 的三个方法,分别是 mousePressEvent、mouseMoveEvent 和 mouseReleaseEvent。在 mousePressEvent 中,我们创建了一个 QDrag 对象,并将文本数据设置为拖拽操作的数据类型。在 mouseMoveEvent 中,我们更新了拖拽操作的状态,并将 QWidget 转换为 QPixmap,作为 QDrag 的图像数据。在 mouseReleaseEvent 中,我们不需要做任何事情,只需要调用 QLabel 的 mouseReleaseEvent 方法即可。 使用 DragLabel 控件时,只需要将它添加到窗口中即可: ```cpp DragLabel *label = new DragLabel("Drag me", this); label->setAlignment(Qt::AlignCenter); label->setFixedSize(100, 50); label->move(50, 50); label->show(); ``` 这样,当用户按下鼠标左键并移动时,就会触发拖拽操作。在拖拽过程中,QLabel 控件会跟随鼠标移动,并在释放鼠标左键时结束拖拽操作。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值