我们在opencv中进行图片的尺寸缩放的方法一般为;
1,resize函数最为直接
2,pyrDown和pyrUp函数,即为图像金字塔相关的两个函数,对图像进行向上向下采样操作
图像金字塔最初用于机器视觉和图像压缩,一幅图像的金字塔是一系列以金字塔形状排列的分辨率逐步降低,且来源于同一张原始图的图像集合。其通过梯次向下采样获得,直到达到某个终止条件才停止采样。
金字塔的底部是待处理图像的高分辨率表示,而顶部是低分辨率的近似。
我们将一层一层的图像比喻成金字塔,层级越高,则图像越小,分辨率越低。
当图像向金字塔的上层移动时,尺寸和分辨率就降低。OpenCV中,从金字塔中上一级图像生成下一级图像的可以用PryDown。而通过PryUp将现有的图像在每个维度都放大两遍。
图像金字塔中的向上和向下采样分别通过OpenCV函数 pyrUp 和 pyrDown 实现。
概括起来就是:
对图像向上采样:pyrUp函数(放大图像)
对图像向下采样:pyrDown函数(缩小图像)
这里的向下与向上采样,是对图像的尺寸而言的(和金字塔的方向相反),向上就是图像尺寸加倍,向下就是图像尺寸减半。而如果我们按上图中演示的金字塔方向来理解,金字塔向上图像其实在缩小,这样刚好是反过来了。
1,resize函数最为直接
2,pyrDown和pyrUp函数,即为图像金字塔相关的两个函数,对图像进行向上向下采样操作
图像金字塔最初用于机器视觉和图像压缩,一幅图像的金字塔是一系列以金字塔形状排列的分辨率逐步降低,且来源于同一张原始图的图像集合。其通过梯次向下采样获得,直到达到某个终止条件才停止采样。
金字塔的底部是待处理图像的高分辨率表示,而顶部是低分辨率的近似。
我们将一层一层的图像比喻成金字塔,层级越高,则图像越小,分辨率越低。
当图像向金字塔的上层移动时,尺寸和分辨率就降低。OpenCV中,从金字塔中上一级图像生成下一级图像的可以用PryDown。而通过PryUp将现有的图像在每个维度都放大两遍。
图像金字塔中的向上和向下采样分别通过OpenCV函数 pyrUp 和 pyrDown 实现。
概括起来就是:
对图像向上采样:pyrUp函数(放大图像)
对图像向下采样:pyrDown函数(缩小图像)
这里的向下与向上采样,是对图像的尺寸而言的(和金字塔的方向相反),向上就是图像尺寸加倍,向下就是图像尺寸减半。而如果我们按上图中演示的金字塔方向来理解,金字塔向上图像其实在缩小,这样刚好是反过来了。
拉普拉斯金字塔简单介绍:
代码:
#include"stdafx.h"
#include <opencv2/core/utility.hpp>
#include "opencv2/imgproc.hpp"
#include "opencv2/imgcodecs.hpp"
#include "opencv2/highgui.hpp"
#include"opencv2/core/core.hpp"
#include <iostream>
using namespace cv;
using namespace std;
// 描述:全局变量声明
//定义原始图,目标图,灰度图,掩码图
Mat image, g_srcImage, g_dstImage, g_grayImage, g_maskImage, tempImage;
//-----------------------------------【main( )函数】--------------------------------------------
// 描述:控制台应用程序的入口函数,我们的程序从这里开始
//-----------------------------------------------------------------------------------------------
int main()
{
//改变console字体颜色
system("color 4F");
//载入原图
image = imread("E:\\pictures\\For_Project\\Opencv_Test\\哈尔施特塔\\shufan.jpeg",1);
if (!image.data) { printf("Oh,no,读取srcImage错误~! \n"); return false; }
//显示原始图
namedWindow("【原始图】");
imshow("【原始图】", image);
//定义操作后保存结果图
Mat g_dstImage1, g_dstImage2, g_dstImage3, g_dstImage4;
g_srcImage = image.clone();
//复制原图到临时变量
tempImage = g_srcImage;
resize(tempImage, g_dstImage1, Size(tempImage.cols / 2, tempImage.rows / 2), (0, 0), (0, 0), INTER_AREA);
resize(tempImage, g_dstImage2, Size(tempImage.cols * 2, tempImage.rows * 2), (0, 0), (0, 0), INTER_LINEAR);
pyrUp(tempImage, g_dstImage3, Size(tempImage.cols * 2, tempImage.rows * 2));
pyrDown(tempImage, g_dstImage4, Size(tempImage.cols / 2, tempImage.rows / 2));
imshow("【效果图一resize缩小】", g_dstImage1);
imshow("【效果图二resize放大】", g_dstImage2);
imshow("【效果图一向上采样】", g_dstImage3);
imshow("【效果图二向下采样】", g_dstImage4);
//等待键盘按键‘q’退出
while (char(waitKey(1)) != 'q') {}
return 0;
}
效果图: