QT实现“图图秀”

本文介绍了如何使用Qt库创建了一个名为ShowImageDialog的自定义QWidget,用于显示和控制图片的预览,通过m_index变量管理图片索引,并响应上一张和下一张按钮的点击事件。paintEvent函数负责根据当前索引动态绘制图片。
摘要由CSDN通过智能技术生成

showimageDialog.h

#ifndef SHOWIMAGEDIALOG_H
#define SHOWIMAGEDIALOG_H

#include <QWidget>
#include <QImage>//图片对象
#include <QPainter>//画家类

namespace Ui {
class ShowImageDialog;
}

class ShowImageDialog : public QWidget
{
    Q_OBJECT

public:
    explicit ShowImageDialog(QWidget *parent = 0);
    ~ShowImageDialog();

private slots:
    //上一张按钮的槽函数
    void on_m_btnPrev_clicked();
    //下一张按钮的槽函数
    void on_m_btnNext_clicked();
private:
    //绘图事件处理函数,窗口改变会自动运行或者调用update触发运行
    void paintEvent(QPaintEvent *);
private:
    Ui::ShowImageDialog *ui;
    int m_index;//图片索引
};

#endif // SHOWIMAGEDIALOG_H



showimagedialog.cpp

#include "showimagedialog.h"
#include "ui_showimagedialog.h"
#include <QDebug>

ShowImageDialog::ShowImageDialog(QWidget *parent) :
    QWidget(parent),
    ui(new Ui::ShowImageDialog)
{
    ui->setupUi(this);
    m_index = 0;
}

ShowImageDialog::~ShowImageDialog()
{
    delete ui;
}
//上一张按钮的槽函数
void ShowImageDialog::on_m_btnPrev_clicked()
{
    if(--m_index < 0){
        m_index = 9;
    }
    update();//触发绘图事件
}
//下一张按钮的槽函数
void ShowImageDialog::on_m_btnNext_clicked()
{
    if(++m_index > 9){
        m_index = 0;
    }
    while(1);
    update();//触发绘图事件
}
//绘图事件处理函数,窗口改变会自动运行或者调用update触发运行
void ShowImageDialog::paintEvent(QPaintEvent *)
{
    //1)创建画家对象
    QPainter painter(this);
    //2)获取绘图的矩形区域,QRect表示矩形区域的对象
    QRect rect = ui->frame->frameRect();
    //平移rect坐标值,让其和父窗口(painter)坐标系一致
    rect.translate(ui->frame->pos());

    //frame相对父窗口位置
    //qDebug() << "frame:" << ui->frame->pos();
    //打印rect记录frame控件的位置
    //qDebug() << "rect:" << rect.x() << "," << rect.y();

    //3)准备要绘制的图片对象,QImage表示图片对象
    //":/new/prefix1/images/m_index.jpg"
    QImage image(":/new/prefix1/images/"+QString::number(m_index)+".jpg");
    //4)使用painter将image绘制到rect
    painter.drawImage(rect,image);
}










main.cpp

#include "showimagedialog.h"
#include <QApplication>

int main(int argc, char *argv[])
{
    QApplication a(argc, argv);
    ShowImageDialog w;
    w.show();

    return a.exec();
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值