Qt 图片浏览器 实现图片的放大缩小翻转等功能
图片的功能
源码:
wiget.h
#ifndef WIDGET_H
#define WIDGET_H
#include <QPixmap>
#include <QImage>
#include <QPushButton>
#include <QHBoxLayout>
#include <QScrollArea>
#include <QLabel>
#include <QWidget>
#include <QPalette>
#include <QTimer>
#include <QString>
#include <QPainter>
#include <QPaintEvent>
#include <QDebug>
#include <QFileDialog>
#include <QStringList>
#include <QMessageBox>
#include <QDir>
#include <QFile>
namespace Ui {
class Widget;
}
class Widget : public QWidget
{
Q_OBJECT
public:
explicit Widget(QWidget *parent = 0);
~Widget();
QLabel *label;
QTimer *timer;
QPixmap pix;
private slots:
void W_timergo();
void W_go();
void W_back();
void W_close();
void W_start();
void W_stop();
void W_max();
void W_min();
void W_flip();
void W_delete();
void W_open();
private:
Ui::Widget *ui;
};
#endif // WIDGET_H
wiget.cpp
#include "widget.h"
#include "ui_widget.h"
static int num;
static int flag=1;
QString image[3] = {":/prefix1/1.jpg",":/prefix1/2.jpg",":/prefix1/3.jpg"};
Widget::Widget(QWidget *parent) :
QWidget(parent),
ui(new Ui::Widget)
{
ui->setupUi(this);
QPixmap pix;
label = new QLabel;
timer = new QTimer;
QPalette palette;
ui->scrollArea->setWidget(label);
ui->scrollArea->setAlignment(Qt::AlignCenter);
palette.setBrush(QPalette::Background,QBrush(QPixmap(":/prefix1/4.jpg")));
this->setPalette(palette);
connect(timer,SIGNAL(timeout()),this,SLOT(W_go()));
connect(ui->pushButton,SIGNAL(clicked()),this,SLOT(W_go()));
connect(ui->pushButton_3,SIGNAL(clicked()),this,SLOT(W_close()));
connect(ui->pushButton_4,SIGNAL(clicked()),this,SLOT(W_start()));
connect(ui->pushButton_5,SIGNAL(clicked()),this,SLOT(W_stop()));
connect(ui->pushButton_2,SIGNAL(clicked()),this,SLOT(W_back()));
connect(ui->pushButton_6,SIGNAL(clicked()),this,SLOT(W_max()));
connect(ui->pushButton_7,SIGNAL(clicked()),this,SLOT(W_min()));
connect(ui->pushButton_8,SIGNAL(clicked()),this,SLOT(W_flip()));
connect(ui->pushButton_9,SIGNAL(clicked()),this,SLOT(W_delete()));
connect(ui->pushButton_10,SIGNAL(clicked()),this,SLOT(W_open()));
}
void Widget::W_timergo()
{
pix.load(image[num]);
label->setPixmap(pix);
if(num==2)
{
num = -1;
}
num++;
}
void Widget::W_go()
{
timer->stop();
pix.load(image[num]);
label->setPixmap(pix);
if(num==2)
{
num = -1;
}
num++;
}
void Widget::W_back()
{
if(num < 0)
{
num = 2;
}
timer->stop();
pix.load(image[num]);
label->setPixmap(pix);
num--;
}
void Widget::W_close()
{
this->close();
}
void Widget::W_start()
{
timer->start(2000);
}
void Widget::W_stop()
{
timer->stop();
}
void Widget::W_max()
{
timer->stop();
float MaxX,MaxY;
MaxX = pix.height();
MaxY = pix.width();
pix = pix.scaled(MaxX*2,MaxY*2,Qt::KeepAspectRatio);
label->setPixmap(pix);
}
void Widget::W_min()
{
timer->stop();
float MaxX,MaxY;
MaxX = pix.height();
MaxY = pix.width();
pix = pix.scaled(MaxX/2,MaxY/2,Qt::KeepAspectRatio);
label->setPixmap(pix);
}
void Widget::W_flip()
{
timer->stop();
QMatrix leftmatrix;
leftmatrix.rotate(90*flag);
flag++;
if(flag == 4)
{
flag = 0;
}
label->setPixmap(QPixmap(image[num]).transformed(leftmatrix,Qt::SmoothTransformation));
}
void Widget::W_delete()
{
timer->stop();
QStringList list;
list=QFileDialog::getOpenFileNames(this,"open image","/","*.jpg");
qDebug()<<list.at(0);
pix.load(list.at(0));
label->setPixmap(pix);
QMessageBox::StandardButton rb = QMessageBox::question(NULL,"Warning",
"Do you want to delete the picture? ",QMessageBox::Yes | QMessageBox::No, QMessageBox::Yes);
if(rb == QMessageBox::Yes)
{
QFile::remove(list.at(0));//刪除文件
}
}
void Widget::W_open()
{
timer->stop();
QStringList list;
list=QFileDialog::getOpenFileNames(this,"open image","/","*.jpg");
qDebug()<<list.at(0);
pix.load(list.at(0));
label->setPixmap(pix);
}
Widget::~Widget()
{
delete ui;
}
main.cpp
#include "widget.h"
#include <QApplication>
int main(int argc, char *argv[])
{
QApplication a(argc, argv);
Widget w;
w.show();
return a.exec();
}
Qt 图片浏览器 实现图片的放大缩小翻转等功能的更多相关文章
- Android 图片浏览器 从原来位置放大至全屏显示
android 图片浏览器 特点: 1.从网络加载图片,只需要传图片地址数组即可 2.点击图片,从原来位置放大至全屏 3.支持手势操作 4.完全自定义布局 项目源码请到GitHub下载:https:/ ...
- wxParse解析富文本内容使点击图片可以选中并实现放大缩小
wxParse解析富文本内容不多说,之前写过步骤介绍,主要是在使用过程中发现解析的富文本内容里有图片时有的可以点击放大缩小,有的点击却报错,找不到imgUrls. 经过排查发现:循环解析的富文本内容正 ...
- Js图片缩放代码 鼠标滚轮放大缩小 图片向右旋转
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- c# 调用系统默认图片浏览器打开图片
private void OpenImage(string fileName) { try { Process.Start(fileName); } catch (Exception ex) { // ...
- 调Windows 7的图片浏览器查看图片
public static void viewPicFromWindows(string pPicPath) { if (pPicPath!="" && Syste ...
- 使用qt写的简单的图片浏览器
功能特别简单,支持png,jpg,bmp,gif文件,支持自适应窗口大小,支持放大缩小,旋转功能还有点问题,支持上下按键选择图片 因为初学qt,所以很多东西都不太会,而且c++学的不是太好,没有怎么使 ...
- JS微信网页使用图片预览(放大缩小)
前言 需求在微信网页中客户点击图片可进行预览放大缩小功能,网上找了各种js方式实现, 唯一的麻烦就是不兼容或者和项目框架不兼容 次函数只只用于部分客户端,否则会出现 WeixinJSBridge is ...
- 纯JS打造比QQ空间更强大的图片浏览器-支持拖拽、缩放、过滤、缩略图等
在线演示地址(打开网页后,点击商家图册): http://www.sport7.cn/cc/jiangnan/football5.html 先看一看效果图: 该图片浏览器实现的功能如下: 1. 鼠标滚 ...
- [翻译] AGPhotoBrowser 好用的图片浏览器
AGPhotoBrowser 好用的图片浏览器 https://github.com/andreagiavatto/AGPhotoBrowser A photo browser for iOS6 a ...
随机推荐
- 22. Angular 中用 a 标签 href 路由时在浏览器中显示异常 "%2F" 路由失败问题
转自:https://blog.csdn.net/duansale/article/details/77455355 <a href="#/index">index&l ...
- Hyper-v Server安装与配置-新加GUI界面配置工具介绍
650) this.width=650;" onclick='window.open("http://blog.51cto.com/viewpic.php?refimg=" ...
- Retrofit请求数据对错误以及网络异常的处理
http://blog.csdn.net/jdsjlzx/article/details/51566683
- Alternating Sum
http://codeforces.com/problemset/problem/963/A 不考虑正负的话,每两项之间之间公比为b/a,考虑正负,则把k段作为循环节,循环节育循环节之间公比为(b/a ...
- C++入门之HelloWorld
1.在VS2017上新建一个C++空白项目,命名为hello 2.在资源文件下新建添加新建项main.cpp 3.在main.cpp中编写hello world输出代码 #include<std ...
- 在Docker应用场景下 如何使用新技术快速实现DevOps
在Docker应用场景下 如何使用新技术快速实现DevOps @Container容器技术大会是由国内容器技术社区DockOne组织的专为一线开发者和运维工程师设计的顶级容器技术会议,会议强调实践和交 ...
- python程序转exe程序之一——cx_Freeze
原始网页 : http://keliang.blog.51cto.com/3359430/661884 本人用的64位系统,一开始装了32位的cx_freeze,结果貌似无法自动找到本地的python ...
- ThinkPHP数据分页Page.class.php
获取分页类 ThinkPHP提供了数据分页的扩展类库Page,能够在http://www.thinkphp.cn/extend/241.html下载,或者下载官方的完整扩展包(http://www.t ...
- [React] Validate Custom React Component Props with PropTypes
In this lesson we'll learn about how you can use the prop-types module to validate a custom React co ...
- Linux下经常使用的C/C++开源Socket库
1. Linux Socket Programming In C++ : http://tldp.org/LDP/LG/issue74/tougher.html 2. ACE: h ...