Qt拖拽事件简单实现

1.相关说明

重写resizeEvent(这个按需重写)、dragEnterEvent(拖拽事件函数)、dropEvent(放下事件函数),可以将本地图片拖拽到label标签中

2.相关界面

 

3.相关代码

#include "widget.h"
#include "ui_widget.h"
#include <QDragEnterEvent>
#include <QMimeData>
#include <QFileInfo>

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);
    setAcceptDrops(true);
    ui->plainTextEdit->setAcceptDrops(false);
    ui->label->setAcceptDrops(false);
    ui->label->setScaledContents(true);
}

Widget::~Widget()
{
    delete ui;
}

void Widget::resizeEvent(QResizeEvent *event)
{
    QSize sz = ui->plainTextEdit->size();
    ui->plainTextEdit->move(5, 5);
    ui->label->move(5, sz.height()+10);
    ui->plainTextEdit->resize(this->width()-10, sz.height());
    ui->label->resize(this->width()-10, this->height()-sz.height()-20);
    event->accept();
}

void Widget::dropEvent(QDropEvent *event)
{
    QString fullPath = event->mimeData()->urls().at(0).path();
    fullPath = fullPath.right(fullPath.length()-1);
    QPixmap pixmap(fullPath);
    ui->label->setPixmap(pixmap);
    event->accept();
}

void Widget::dragEnterEvent(QDragEnterEvent *event)
{
    ui->plainTextEdit->clear();
    ui->plainTextEdit->appendPlainText("dragEvent事件,mimeData的format:");
    for(auto &item : event->mimeData()->formats()){
        ui->plainTextEdit->appendPlainText(item);
    }
    ui->plainTextEdit->appendPlainText("dragEvent事件,mimeData的urls:");
    for(auto &item : event->mimeData()->urls()){
        ui->plainTextEdit->appendPlainText(item.path());
    }
    if(event->mimeData()->hasUrls()){
        QString filename = event->mimeData()->urls().at(0).fileName();
        QFileInfo fileInfo(filename);
        QString ex = fileInfo.suffix().toUpper();
        if(ex == "JPG"){
            event->acceptProposedAction();
        } else {
            event->ignore();
        }
    } else {
        event->ignore();
    }
}

  • 9
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值