QT完成图片拖拽显示【本文转载自网络】
来源:互联网 发布:地图数据质量 编辑:程序博客网 时间:2024/06/05 23:30
拖拽前:
拖拽图片到窗口的label里,显示效果如下:
Qt已经提供了强大的拖拽功能,实现如上效果,只需要很简单的几步即可。
1. 使用QtCreator创建一个窗口,在里面放置一个QLabel,如下图:
^_^,里面的QLabel与你的不一样?
在此加个小知识点,给label加上stylesheet,像CSS一样简单的就可以做出上图效果,按下图操作即可:
图上了这么多,实现代码如下,几步即可完成,是不是很简单?:
#include"Widget.h"
#include"ui_Widget.h"
#include<QUrl>
#include<QList>
#include<QtGui/QPixmap>
#include<QtGui/QDragEnterEvent>
#include<QtGui/QDropEvent>
Widget::Widget(QWidget*parent) : QWidget(parent), ui(newUi::Widget) {
ui->setupUi(this);
ui->label->installEventFilter(this);
ui->label->setAcceptDrops(true);//[[1]]:使label可接受拖放操作
}
Widget::~Widget(){
deleteui;
}
boolWidget::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();
returntrue;
}elseif(event->type() == QEvent::Drop) {
//[[3]]:当放操作发生后,取得拖放的数据
QDropEvent*de =dynamic_cast<QDropEvent*>(event);
QList<QUrl>urls = de->mimeData()->urls();
if(urls.isEmpty()) { returntrue;}
QStringpath = urls.first().toLocalFile();
//[[4]]:在label上显示拖放的图片
QImageimage(path);//QImage对I/O优化过,QPixmap对显示优化
if(!image.isNull()) {
image= image.scaled(ui->label->size(),
Qt::KeepAspectRatio,
Qt::SmoothTransformation);
ui->label->setPixmap(QPixmap::fromImage(image));
}
returntrue;
}
}
returnQWidget::eventFilter(watched, event);
}
- QT完成图片拖拽显示【本文转载自网络】
- Qt显示网络图片
- qt QLabel 显示网络图片
- Qt之显示网络图片
- 基于Drectshow的GetCurrentImage使用方法无法显示图片的解决方法(本文转载)
- Qt技巧:QTextEdit显示网络图片
- windows下qt程序发布【转载自网络】
- sizeof--转载自网络
- 转载自网络
- Qt 获取网络gif图片并保存到本地显示
- qt 通过http获取网络图片并且显示
- Qt:拖拽图片到QLabel上并显示
- Qt:拖拽图片到QLabel上并显示
- Qt:拖拽图片到QLabel上并显示
- Qt:拖拽图片到QLabel上并显示
- QT显示图片
- Qt:显示、保存图片
- QT显示图片
- effective STL 读书笔记 二
- QT-杂
- 双目立体匹配回顾笔记
- QT中编写自己的动态链接库
- 四叉树与八叉树
- QT完成图片拖拽显示【本文转载自网络】
- oracle 查询效率
- 图片验证码的实现
- 利用java nio 实现简单的消息通讯
- 14. 66. 3.一个简单的树 Create JTree from Vector
- EBS fnd_global.apps_initialize的使用
- 查看“直接查询结果为空”的视图
- 操纵文件类
- typedef用法总结