【图像处理】OpenCV系列十五 --- 对一幅图像进行放大、放小
上一篇我们学习了图像金字塔,图像金字塔有两种实现方式,一种是高斯金字塔(对图像进行缩放)、另一种是拉普拉斯金字塔(对图像进行放大),但是图像金字塔对图像进行放大放小的时候会对图像的信息造成一定的损失,那么我们本节有另外一种更好的实现方式,这种方式对图像放大放小时,对图像信息造成的损失较小!那么我们正式进入本节的学习吧!
一、OpenCV中resize()函数详解
1、函数原型
void resize(InputArray src, OutputArray dst, Size dsize, double fx = 0, double fy = 0, int interpolation = INTER_LINEAR);
2、函数功能
将原图像src放大(放小)到指定的尺寸,可以不用考虑目标图像的大小和尺寸,因为目标图像的大小和尺寸是根据resize()函数中的src,dsize,fx,fy这四个参数决定的;
调整src图像的大小的方案
(1)调整src图像的大小,可以预先创建一个目标图像dst
例如:
//新建一张512x512尺寸的图片Mat dst = Mat::zeros(512, 512, CV_8UC3);Mat src = imread("lena.png");//显式指定dsize=dst.size(),//那么fx和fy会其计算出来,不用额外指定。resize(src, dst, dst.size());
(2)调整src图像的大小,可以不预先创建目标图像dst,可以用dsize,fx,fy三个个因子来控制目标图像的大小
例如:
Mat dst;Mat src = imread("lena.png")//指定fx和fy,让函数计算出目标图像的大小。resize(src, dst, Size(), 0.5, 0.5);
若要缩小图像,一般情况下最好用INTER_AREA来插值,
而若要放大图像,一般情况下最好用INTER_CUBIC(效率不高,慢,不推荐使用)或CV_INTER_LINEAR(效率较高,速度较快,推荐使用)。
3、参数详解
- 第一个参数,InputArray类型的src,输入图像,即源图像,填Mat类的对象即可;
- 第二个参数,OutputArray类型的dst,输出图像,当其非零时,有着dsize(第三个参数)的尺寸,或者由src.size()计算出来;
- 第三个参数,Size类型的dsize,输出图像的大小;如果它等于零,由下式进行计算:
![b2a0bd111ae8e382852a9078c12c114d.png](https://i-blog.csdnimg.cn/blog_migrate/6a960314e976e10c586e96ba2cf918f9.jpeg)
dsize的计算方式
- 第四个参数,double类型的fx,沿水平轴的缩放系数,有默认值0,且当其等于0时,由下式进行计算:
![3c1324847ad79b7f0c87f45e2205127e.png](https://i-blog.csdnimg.cn/blog_migrate/f93f6726021df67097f25c05950eb31c.jpeg)
fx的计算方式
- 第五个参数,double类型的fy,沿垂直轴的缩放系数,有默认值0,且当其等于0时,由下式进行计算:
![2053566e11d4201b4ec3c0a139739d52.png](https://i-blog.csdnimg.cn/blog_migrate/5a5947f5fdc96807da77a04b5b9631bb.jpeg)
fy的计算方式
- 第六个参数,int类型的interpolation,用于指定插值方式,默认为INTER_LINEAR(线性插值)。
常用的插值方式:
- INTER_NEAREST - 最近邻插值
- INTER_LINEAR - 线性插值(默认值)
- INTER_AREA - 区域插值(利用像素区域关系的重采样插值)
- INTER_CUBIC –三次样条插值(超过4×4像素邻域内的双三次插值)
- INTER_LANCZOS4 -Lanczos插值(超过8×8像素邻域的Lanczos插值)
4、实例
#include #include using namespace cv;int main(){ //载入原始图 Mat srcImage = imread("lena.png"); //临时变量和目标图的定义 Mat tmpImage, dstImage1, dstImage2; //将原始图赋给临时变量 tmpImage = srcImage; //显示原始图 imshow("【原始图】