OpenCV 几何变换-图像缩放

图像的缩放主要用于改变图像的大小,缩放后图像的图像的宽度和高度会发生变化。在图像处理中是一种很基础的几何变换,但是具有很重要的作用,比如:当输入图片尺寸过大时,处理速度会很慢,适当的缩小图像可以在不影响处理效果的同时有效提高代码执行速度。
opencv提供了resize函数实现图片缩放功能,函数原型为:

CV_EXPORTS_W void resize( 
InputArray src, 
OutputArray dst,
Size dsize, 
double fx=0, 
double fy=0,
int interpolation=INTER_LINEAR );

其中:
第一个参数为输入图像
第二个参数为输出图像
第三个参数为输出图像和输入图像尺寸(包含长宽)
第四个参数为输出图像和输入图像水平方向上的比例
第五个参数为输出图像和输入图像垂直方向上的比例
第六个参数为插值方法:
CV_INTER_NN - 最近邻插值,
CV_INTER_LINEAR - 双线性插值 (缺省使用)
CV_INTER_AREA - 使用象素关系重采样。当图像缩小时候,该方法可以避免波纹出现。当图像放大时,类似于 CV_INTER_NN 方法…
CV_INTER_CUBIC - 立方插值.

需要注意的是:
dsize是一个Size类型的数据,它包含图像的长和宽,而fx和fy为double类型,值反应图像的长或宽的比例。所以dsize和fx,fy必须不能同时为零,也就是说要么dsize不为零而fx与fy同时可以为0,要么dsize为0而fx与fy不同时为0;resize函数的目标大小可以是任意的大小,可以不保持长宽比率,删除的像素或者新增的像素值通过interpolation(内插)控制;

如果dsize不为零,fx,fy会自动计算:
fx=dsize.width/src.cols; fy=dsize.height/src.rows;
所以我们可以这样写:

Mat  sizeimage;
Size dsize = Size(srcimage.cols*0.5,srcimage.rows*0.5);
resize(srcimage, sizeimage,dsize);

我们定义比例因子是0.5,手动计算出图像缩放后的尺寸,然后把这个尺寸放在Size中。当然在Size里面也是可以直接输入数值的,这样的话可以做固定尺寸的操作,而不发生裁剪。

Size dsize = Size(100,100);

也可以这样:

Mat  sizeimage;
resize(srcimage, sizeimage,Size(0,0),0.5,0.5);

此时我们直接把比例给入resize函数,效果是相同的。

这里写图片描述

这里写代码片

但是如果出现Size和fx,fy同时都不为0的情况呢?比如:

	Mat sizeimage;
	Size dsize = Size(srcimage.cols*0.2,srcimage.rows*0.2);
	resize(srcimage, sizeimage,dsize,0.5,0.5);

这里写图片描述

这里写图片描述

显然Size的优先级要大于fx和fy

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值