原文:http://www.cppblog.com/biao/archive/2011/10/23/158940.html
首先看下效果,左边是没有原始Label,右侧是把图片拖动到Label上显示效果。
思路:
1. 监视Label,当拖动鼠标到Label区域,Label接受拖放动作
2. 当操作放动作时,取得放的内容
3. 显示信息。
代码如下:
#include <QDragEnterEvent>
#include <QDropEvent>
#include <QMimeData>
ImageWidget::ImageWidget(QWidget *parent)
: QWidget(parent)
{
this->setFixedSize(300, 300);
m_pHLayoutImageWidget = new QHBoxLayout(this);
m_pLabelImage = new QLabel(tr("拖拽图片到这里"));
m_pHLayoutImageWidget->addWidget(m_pLabelImage);
m_pLabelImage->installEventFilter(this); // 事件过滤器
m_pLabelImage->setAcceptDrops(true); // 使Label接受拖拽操作
m_pLabelImage->setAlignment(Qt::AlignCenter);
m_pLabelImage->setFixedSize(278, 278);
m_pLabelImage->setStyleSheet("QLabel{font-size: 20px; border:2px dashed black;"
"border-radius:10px; background:rgb(0, 255, 0, 100);}");
setLayout(m_pHLayoutImageWidget);
}
ImageWidget::~ImageWidget()
{
}
bool ImageWidget::eventFilter(QObject *watched, QEvent *event)
{
if(watched == m_pLabelImage)
{
if(event->type() == QEvent::DragEnter)
{
// 当拖放时鼠标进入label时, label接受拖放的动作
QDragEnterEvent *dee = dynamic_cast<QDragEnterEvent *>(event);
dee->acceptProposedAction();
return true;
}
else if(event->type() == QEvent::Drop)
{
// 当放操作发生后, 取得拖放的数据
QDropEvent *de = dynamic_cast<QDropEvent *>(event);
QList<QUrl> urls = de->mimeData()->urls();
if (urls.isEmpty())
{
return true;
}
QString path = urls.first().toLocalFile();
// 在label上显示拖放的图片
QImage image(path); // QImage对I/O优化过, QPixmap对显示优化
if(!image.isNull())
{
image = image.scaled(m_pLabelImage->size(), Qt::KeepAspectRatio,
Qt::SmoothTransformation);
m_pLabelImage->setPixmap(QPixmap::fromImage(image));
}
return true;
}
}
return QWidget::eventFilter(watched, event);
}