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 ...
随机推荐
- nginx 11个过程
nginx在处理每一个用户请求时,都是按照若干个不同的阶段依次处理的,与配置文件上的顺序没有关系,详细内容可以阅读<深入理解nginx:模块开发与架构解析>这本书,这里只做简单介绍: 1. ...
- js数组与字符串的相互转换方法 数组常用的方法
1 数组转字符串 需要将数组元素用某个字符连接成字符串,示例代码如下: var a, b; a = new Array(0,1,2,3,4); b = a.join("-"); 二 ...
- How Javascript works (Javascript工作原理) (十三) CSS 和 JS 动画底层原理及如何优化其性能
个人总结:读完这篇文章需要20分钟. 这是 JavaScript 工作原理的第十三章. 概述 正如你所知,动画在创建令人叹服的网络应用中扮演着一个关键角色.由于用户越来越注重用户体验,商户开始意识到完 ...
- QQ空间说说爬虫
QQ空间说说爬虫 闲来无事,写了一个QQ空间的爬虫,主要是爬取以前的说说,然后生成词云. 这次采用的主要模块是selenium,这是一个模拟浏览器的模块,一开始我不想用这个模块写的,但是后面分析的时候 ...
- Redis 数据持久化的方案的实现
原文:Redis 数据持久化的方案的实现 版权声明:m_nanle_xiaobudiu https://blog.csdn.net/m_nanle_xiaobudiu/article/details/ ...
- jquery事件 【mousedown与mouseup ----keydown与keypress与keyup】focus--blur--orrer--pageX-pageY
<html xmlns="http://www.w3.org/1999/xhtml"> <head> <title></title> ...
- GO语言为结构体排序
package main import ( "fmt" "io/ioutil" "sort" "time" ) type ...
- HTTP请求具体解释
1. HTTP请求格式 做过Socket编程的人都知道,当我们设计一个通信协议时,"消息头/消息体"的切割方式是非经常常使用的.消息头告诉对方这个消息是干什么的,消息体告诉对方怎么 ...
- VS添加程序集
项目->添加->引用->程序集 可在项目的引用目录中,查看引用的程序集
- Raid阵列之简单介绍
1.raid分类 软raid:用软件模拟raid芯片 硬raid:集成的后来添加的 2.raid基本简介 (1)raid是由廉价磁盘冗余阵列发展成为独立磁盘冗余阵列 (2)linux是借助MD(Mui ...