Qt实战案例(36)——利用QImage类实现对图像的基本操作(图像显示、图像缩放、图像旋转)

一、项目介绍

利用QImage类实现对图像的基本操作,包括图像显示、图像缩放、图像旋转等。

二、项目基本配置

新建一个Qt案例,项目名称为“ImageTest”,基类选择“QWidget”,点击选中创建UI界面复选框,完成项目创建。

三、UI界面设计

UI界面布局如下:
在这里插入图片描述
界面中创建了5个控件,其名称和类型如下:

序号名称类型属性
ChooseQPushButtontext:选择图像
RotateQPushButtontext:图像旋转
ZoomQPushButtontext:图像缩放
imagelabelQLabel\
horizontalSliderQSliderminimum:0
maximum:359

四、主程序实现

4.1 widget.h头文件

头文件中声明原始图像img:

public:
    QImage img;//原始图像

声明三个按钮点击槽函数和一个滑动条滑动槽函数:

private slots:
    void on_Choose_clicked();

    void on_Rotate_clicked();

    void on_Zoom_clicked();

    void on_horizontalSlider_valueChanged(int value);

4.2 widget.cpp源文件

定义选择图像槽函数:

//选择图像
void Widget::on_Choose_clicked()
{
    QString path=QFileDialog::getOpenFileName(this,tr("选择图像"),"E:\\image\\",tr("Images (*.png *.bmp *.jpg *.tif *.GIF )"));
    if(path.isEmpty())
    {
         return;
    }
    else
    {
        if(! ( img.load(path) ) ) //加载图像
        {
            QMessageBox::information(this,tr("打开图像失败"),tr("打开图像失败!"));
            //delete img;
            return;
        }
        //img.load(path);
        ui->imagelabel->setPixmap(QPixmap::fromImage(img));
    }

}

定义图像缩放槽函数:

//图像缩放
void Widget::on_Zoom_clicked()
{
    QImage* imgScaled = new QImage;
    int width=ui->imagelabel->width()/2;
    int height=ui->imagelabel->height()/2;
    *imgScaled=img.scaled(width,height,Qt::KeepAspectRatio);//对半缩放
    ui->imagelabel->setPixmap(QPixmap::fromImage(*imgScaled));
}

定义图像旋转槽函数:

//图像旋转
void Widget::on_Rotate_clicked()
{
    ui->horizontalSlider->setVisible(true);//显示滑动条
}

定义滑动条值变化槽函数:

//进度条值变化
void Widget::on_horizontalSlider_valueChanged(int value)
{
    qDebug()<<value;//输出旋转角度
    QImage* imgRatate = new QImage;
    QMatrix matrix;
    matrix.rotate(value);
    *imgRatate = img.transformed(matrix);
    ui->imagelabel->setPixmap(QPixmap::fromImage(*imgRatate));
}

五、效果演示

完整效果如下:
在这里插入图片描述

如果没有看懂的话,完整代码可以参考:
https://download.csdn.net/download/didi_ya/80304648


ok,以上便是本文的全部内容了,如果对你有所帮助,记得点个赞哟~

  • 6
    点赞
  • 51
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

wendy_ya

您的鼓励将是我创作的最大动力~

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值