摘要
OpenCv作为开源机器视觉,可以很好的进行图像的处理,如图像的放大、缩小、旋转和平移等。在这里记录图像的放大和缩小原理,作为自己后续参考的文献,也给看到本文的同学参考。
图像缩放原理
图像的缩放包含图像的放大和图像的缩小,在介绍图像的缩小和放大前,先介绍图像的比例缩放,图像的比例缩放是指将给定的图像在x轴方向和y轴方向分别按比例a倍和b倍进行缩放,从而获得一幅新的图像。如果a=b,称这样的比例缩放为全比例缩放;如果a≠b,图像的比例缩放会改变原始图像的相对位置,产生几何畸变。
图像缩小即使对原有图像的像素值进行挑选和处理,进而获得期望的缩小尺寸图像,且保证原有的特征不丢失。
图像的放大,从字面上可以理解成是图像缩小的逆操作,但是,在实际操作中,要保证图像放大中多出的空位进行相关的填充或者操作。
图像缩放的实现
设原图像大小为MN,缩放的图像(目标图像)为k1Mk2N,过程如下:
1)设原图为A(i,j),i=1,2…M,j=1,2…N
2)压缩后的图像B(x,y),x=1,2…k1M,y=1,2…k2N
3)B(x,y) = A(x/k1,y/k2)
注意:图像缩放要注意目标图像的大小需要在循环范围内,即注意越界问题
实现代码
# include <iostream>
#include <opencv.hpp>
using namespace cv;
using namespace std;
//图片缩放
void funImageZoom(Mat& A, Mat B, double kx, double ky)
{
for (int i = 0; i < A.rows * kx; i++)
{
for (int j = 0; j < A.cols * ky; j++)
{
int m = floor(i / kx);
int n = floor(j / ky);
B.at<Vec3b>(i, j) = A.at<Vec3b>(m, n);//获取图像的像素值
}
}
}
int main() {
Mat A = imread("d:\\1.jpg", 1);//1正色 0灰色,存放原图
if (A.data != NULL) {
//放大图像
double kx, ky;
cout<<"请输入图片放大的倍数(高和宽):"<<endl;
cin>>kx >> ky;
Mat bigImage(A.rows * kx, A.cols * ky, A.type()); //放大图像,rows表示行,cols表示列
funImageZoom(A, bigImage, kx, ky)
//缩小图像
double km, kn;
cout << "请输入图片缩小的倍数(高和宽):" << endl;
cin >> km >> kn;
Mat smallImage(ceil(A.rows * km), ceil(A.cols * kn), A.type()); //缩小图像,rows表示行,cols表示列
funImageZoom(A, smallImage, km, kn)
//显示图片
imshow("原始图像", A);
imshow("放大图像", bigImage);
imshow("缩小图像", smallImage);
}
else
{
cout << "图片加载失败,请检查文件是否存在!" << endl;
}
//保持等待状态
waitKey();//括号里可以填任意正整数,意味着,图像显示的毫秒时
return 0;
}
实验结果
注本文为自己学习过程中的学习记录,如有错误,请批评指责!