【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)
其中疑问或错误,欢迎联系交流,

目录
相关文章
|
20天前
|
算法 计算机视觉
opencv图像形态学
图像形态学是一种基于数学形态学的图像处理技术,它主要用于分析和修改图像的形状和结构。
31 4
|
30天前
|
算法 计算机视觉 Python
python利用opencv进行相机标定获取参数,并根据畸变参数修正图像附有全部代码(流畅无痛版)
该文章详细介绍了使用Python和OpenCV进行相机标定以获取畸变参数,并提供了修正图像畸变的全部代码,包括生成棋盘图、拍摄标定图像、标定过程和畸变矫正等步骤。
python利用opencv进行相机标定获取参数,并根据畸变参数修正图像附有全部代码(流畅无痛版)
WK
|
28天前
|
编解码 计算机视觉 Python
如何在OpenCV中进行图像转换
在OpenCV中,图像转换涉及颜色空间变换、大小调整及类型转换等操作。常用函数如`cvtColor`可实现BGR到RGB、灰度图或HSV的转换;`resize`则用于调整图像分辨率。此外,通过`astype`或`convertScaleAbs`可改变图像数据类型。对于复杂的几何变换,如仿射或透视变换,则可利用`warpAffine`和`warpPerspective`函数实现。这些技术为图像处理提供了强大的工具。
WK
59 1
|
1月前
|
机器人 计算机视觉
巧用 OpenCV solvePnP() 函数完成由图像坐标系到机器人坐标系的转换(二维坐标系之间的转换)
巧用 OpenCV solvePnP() 函数完成由图像坐标系到机器人坐标系的转换(二维坐标系之间的转换)
44 2
|
1月前
|
计算机视觉
使用QT显示OpenCV读取的图片
使用QT显示OpenCV读取的图片
34 1
|
3月前
|
算法 计算机视觉
【Qt&OpenCV 图像的感兴趣区域ROI】
【Qt&OpenCV 图像的感兴趣区域ROI】
97 1
|
3月前
|
运维 算法 计算机视觉
【Qt&OpenCV 图像的模板匹配 matchTemplate/minMaxLoc】
【Qt&OpenCV 图像的模板匹配 matchTemplate/minMaxLoc】
55 1
|
2月前
|
机器学习/深度学习 XML 计算机视觉
OpenCV(Open Source Computer Vision Library)是一个开源的计算机视觉和机器学习库,它提供了大量的函数和工具,用于处理图像和视频数据。
OpenCV(Open Source Computer Vision Library)是一个开源的计算机视觉和机器学习库,它提供了大量的函数和工具,用于处理图像和视频数据。
|
2月前
|
机器学习/深度学习 人工智能 计算机视觉
好的资源-----打卡机+Arm+Qt+OpenCV嵌入式项目-基于人脸识别的考勤系统-----B站神经网络与深度学习,商城
好的资源-----打卡机+Arm+Qt+OpenCV嵌入式项目-基于人脸识别的考勤系统-----B站神经网络与深度学习,商城
|
3月前
|
存储 编解码 算法
【Qt&OpenCV 检测图像中的线/圆/轮廓 HoughLinesP/HoughCircles/findContours&drawContours】
【Qt&OpenCV 检测图像中的线/圆/轮廓 HoughLinesP/HoughCircles/findContours&drawContours】
63 0

推荐镜像

更多