Qt:拖拽图片到QLabel上并显示

44 篇文章 4 订阅

转载自:http://www.cppblog.com/biao/archive/2011/10/23/158940.html

仅供参考!

实现代码:

#include "mainwindow.h"
#include "ui_mainwindow.h"
#include <QDragEnterEvent>
#include <QDropEvent>
#include <QUrl>
#include <QList>
#include <QMimeData>

MainWindow::MainWindow(QWidget *parent) :
    QMainWindow(parent),
    ui(new Ui::MainWindow)
{
    ui->setupUi(this);

    ui->label->installEventFilter(this);
    ui->label->setAcceptDrops(true);
}

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


bool MainWindow::eventFilter(QObject *watched, QEvent *event)
{
    if (watched == ui->label) {
            if (event->type() == QEvent::DragEnter) {
                // [[2]]: 当拖放时鼠标进入label时, label接受拖放的动作
                QDragEnterEvent *dee = dynamic_cast<QDragEnterEvent *>(event);
                dee->acceptProposedAction();
                return true;
            } else if (event->type() == QEvent::Drop) {
                // [[3]]: 当放操作发生后, 取得拖放的数据
                QDropEvent *de = dynamic_cast<QDropEvent *>(event);
                QList<QUrl> urls = de->mimeData()->urls();

                if (urls.isEmpty()) { return true; }
                QString path = urls.first().toLocalFile();

                // [[4]]: 在label上显示拖放的图片
                QImage image(path); // QImage对I/O优化过, QPixmap对显示优化
                if (!image.isNull()) {
                    image = image.scaled(ui->label->size(),
                                         Qt::KeepAspectRatio,
                                         Qt::SmoothTransformation);
                    ui->label->setPixmap(QPixmap::fromImage(image));
                }

                return true;
            }
        }

        return QMainWindow::eventFilter(watched, event);
}
运行效果:


  • 2
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值