【Qt&OpenCV 图像缩放resize()】

简介: 【Qt&OpenCV 图像缩放resize()】

前言

越来越多的开发人员选择基于开源的Qt框架与OpenCV来实现界面和算法,其原因不单单是无版权问题,更多是两个社区的发展蓬勃,可用来学习的资料与例程特别丰富。以下是关于利用cv::resize()实现图像缩放。

软件版本:Qt-5.12.0/OpenCV-4.5.3

平台:Windows10/11–64


一、函数介绍

cv::resize(InputArray src, OutputArray dst, Size dsize,

double fx=0, double fy=0, int interpolation=INTER_LINEAR )

参数解释:

InputArray src :输入,原图像,即待改变大小的图像;

OutputArray dst: 输出,改变后的图像。这个图像和原图像具有相同的内容,只是大小和原图像不一样而已;

dsize:输出图像的大小。

如果这个参数不为0,那么就代表将原图像缩放到这个Size(width,height)指定的大小;如果这个参数为0,那么原图像缩放之后的大小就要通过公式来计算:dsize = Size(round(fxsrc.cols), round(fysrc.rows))

其中,fx和fy就是下面要说的两个参数,是图像width方向和height方向的缩放比例。

fx:width方向的缩放比例,如果它是0,那么它就会按照(double)dsize.width/src.cols来计算;

fy:height方向的缩放比例,如果它是0,那么它就会按照(double)dsize.height/src.rows来计算;

interpolation:这个是指定插值的方式,图像缩放之后,肯定像素要进行重新计算的,就靠这个参数来指定重新计算像素的方式,有以下几种:

INTER_NEAREST - 最邻近插值;

INTER_LINEAR - 双线性插值,如果最后一个参数你不指定,默认使用这种方法;

INTER_AREA - resampling using pixel area relation. It may be a preferred method for image decimation, as it gives moire’-free results. But when the image is zoomed, it is similar to the INTER_NEAREST method.

INTER_CUBIC - 4x4像素邻域内的双立方插值;

INTER_LANCZOS4 - 8x8像素邻域内的Lanczos插值;

二、演示

1.GUI

如上图创建Scale的功能按钮QPushButtonQDoubleSpinBoxQSlider用来输入缩放系数。

2.实现代码

scaleBtn的clicked()槽函数实现如下:

void MainWindow::on_scaleBtn_clicked()
{
    double ratio = ui->scaleDSpin->value(); // 读取缩放系数
    std::size_t numView = ui->tabWidget->currentIndex() % 4;  // 获取当前图片的窗口
    if (ratio > 0)
    {
        if (!dispMat[numView]->empty())
        {
            cv::resize(*dispMat[numView], *dispMat[numView],
                   cv::Size(static_cast<int>(dispMat[numView]->cols * ratio),
                        static_cast<int>(dispMat[numView]->rows *ratio)),
                   0, 0, cv::INTER_LINEAR);
            cvtMatPixmap(dispMat, dispPixmap, numView); // 显示图片
            outputInfo(1, tr("Scale: %1 done!").arg(ratio));  // 输出信息
        }
        else
        {
            outputInfo(2, tr("Please make sure the Mat exist!"));
            return ;
        }
    }
    else
    {
        outputInfo(2, tr("Please make sure the ratio!"));
    }
}

scaleSlider的released()槽函数实现如下:

void MainWindow::on_scaleSlider_sliderReleased()
{
    double ratio = ui->scaleSlider->value() * 0.1;    // 读取缩放系数 value*0.1
    std::size_t numView = ui->tabWidget->currentIndex() % 4;  // 获取当前图片的窗口号
    if (ratio > 0)
    {
        if (!dispMat[numView]->empty())
        {
            cv::resize(*dispMat[numView], *dispMat[numView],
                   cv::Size(static_cast<int>(dispMat[numView]->cols * ratio),
                        static_cast<int>(dispMat[numView]->rows *ratio)),
                   0, 0, cv::INTER_LINEAR);
            cvtMatPixmap(dispMat, dispPixmap, numView);
            ui->scaleDSpin->setValue(ratio);  // 同步转换系数到scaleDSpin控件
            outputInfo(1, tr("Scale: %1 done!").arg(ratio));
        }
        else
        {
            outputInfo(2, tr("Please make sure the Mat exist!"));
            return ;
        }
    }
    else
    {
        outputInfo(2, tr("Please make sure the ratio!"));
    }
}


总结

以上是关于利用Qt进行GUI构建并使用OpenCV中的resize()函数进行图像缩放的介绍。
参考:
  链接: [link](https://blog.csdn.net/richard_yuu/article/details/124097798)
  链接: [link](https://blog.csdn.net/richard_yuu/article/details/124140746)
其中疑问或错误,欢迎联系交流,

目录
相关文章
|
4月前
|
算法 计算机视觉
基于qt的opencv实时图像处理框架FastCvLearn实战
本文介绍了一个基于Qt的OpenCV实时图像处理框架FastCvLearn,通过手撕代码的方式详细讲解了如何实现实时人脸马赛克等功能,并提供了结果展示和基础知识回顾。
172 7
|
4月前
|
文字识别 计算机视觉 开发者
基于QT的OCR和opencv融合框架FastOCRLearn实战
本文介绍了在Qt环境下结合OpenCV库构建OCR识别系统的实战方法,通过FastOCRLearn项目,读者可以学习Tesseract OCR的编译配置和在Windows平台下的实践步骤,文章提供了技术资源链接,帮助开发者理解并实现OCR技术。
198 9
基于QT的OCR和opencv融合框架FastOCRLearn实战
|
3月前
|
计算机视觉
Opencv学习笔记(三):图像二值化函数cv2.threshold函数详解
这篇文章详细介绍了OpenCV库中的图像二值化函数`cv2.threshold`,包括二值化的概念、常见的阈值类型、函数的参数说明以及通过代码实例展示了如何应用该函数进行图像二值化处理,并展示了运行结果。
751 0
Opencv学习笔记(三):图像二值化函数cv2.threshold函数详解
|
4月前
|
算法 计算机视觉
opencv图像形态学
图像形态学是一种基于数学形态学的图像处理技术,它主要用于分析和修改图像的形状和结构。
62 4
|
4月前
|
存储 计算机视觉
Opencv的基本操作(一)图像的读取显示存储及几何图形的绘制
本文介绍了使用OpenCV进行图像读取、显示和存储的基本操作,以及如何绘制直线、圆形、矩形和文本等几何图形的方法。
Opencv的基本操作(一)图像的读取显示存储及几何图形的绘制
|
4月前
|
计算机视觉
基于QT的opencv插件框架qtCvFrameLearn实战
这篇文章详细介绍了如何基于Qt框架开发一个名为qtCvFrameLearn的OpenCV插件,包括项目配置、插件加载、Qt与OpenCV图像转换,以及通过各个插件学习OpenCV函数的使用,如仿射变换、卡通效果、腐蚀、旋转和锐化等。
70 10
|
4月前
|
机器学习/深度学习 Java 计算机视觉
opencv4.5.5+qt5.15.2+vtk9.1+mingw81_64编译记录
本文记录了使用mingw81_64编译OpenCV 4.5.5、Qt 5.15.2、VTK 9.1的详细过程,包括编译结果截图、编译步骤、遇到的问题及其解决方案,以及相关参考链接。文中还提到了如何编译boost源码为静态库,并提供了测试代码示例。
125 0
opencv4.5.5+qt5.15.2+vtk9.1+mingw81_64编译记录
|
5月前
|
算法 计算机视觉 Python
python利用opencv进行相机标定获取参数,并根据畸变参数修正图像附有全部代码(流畅无痛版)
该文章详细介绍了使用Python和OpenCV进行相机标定以获取畸变参数,并提供了修正图像畸变的全部代码,包括生成棋盘图、拍摄标定图像、标定过程和畸变矫正等步骤。
python利用opencv进行相机标定获取参数,并根据畸变参数修正图像附有全部代码(流畅无痛版)
WK
|
5月前
|
编解码 计算机视觉 Python
如何在OpenCV中进行图像转换
在OpenCV中,图像转换涉及颜色空间变换、大小调整及类型转换等操作。常用函数如`cvtColor`可实现BGR到RGB、灰度图或HSV的转换;`resize`则用于调整图像分辨率。此外,通过`astype`或`convertScaleAbs`可改变图像数据类型。对于复杂的几何变换,如仿射或透视变换,则可利用`warpAffine`和`warpPerspective`函数实现。这些技术为图像处理提供了强大的工具。
WK
159 1
|
5月前
|
计算机视觉
使用QT显示OpenCV读取的图片
使用QT显示OpenCV读取的图片
120 1