利用OpenCV的函数warpPerspective()作图像的透视变换
Posted 昊虹AI笔记
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了利用OpenCV的函数warpPerspective()作图像的透视变换相关的知识,希望对你有一定的参考价值。
图像的透视变换是指按照物体的成像投影规律进行变换。通过透视变换可以将图像投影到新的成像平面上。
图像的透视变换通常用来解决相机的视线与物体所在平面不垂直的问题。
比如,下面这幅图中,如果相机的视线与正方形是垂直的,那么应该是下面这样的成像效果:
但我们相机的视线很多时候与要拍摄的物体平面不垂直,比如下面示意图中的相机与物体平面:
当相机的视线与要拍摄的物体平面不垂直时,就照成了下面这样:
我们可以利用透视变换对上面的图像进行校正操作。
在OpenCV开发环境下,我们可以利用函数warpPerspective()作图像的透视变换。
利用函数warpPerspective()作图像的透视变换前需要有一个3×3的透视变换矩阵,可以利用函数getPerspectiveTransform()得到3×3的透视变换矩阵。
函数getPerspectiveTransform()的原型如下:
Mat cv::getPerspectiveTransform(const Point2f src[],
const Point2f dst[],
int solveMethod = DECOMP_LU )
retval=cv.getPerspectiveTransform(src, dst[, solveMethod])
参数意义如下:
src—原图像中4个像素点的坐标,注意坐标值的数据类型为float。
dst—目标图像中4个像素点的坐标,注意坐标值的数据类型为float。
solveMethod—选择计算透视变换矩阵的方法,默认值为DECOMP_LU,其枚举值有如下这些:
DECOMP_LU:最佳主轴元素的高斯消元法。
DECOMP_SVD :奇异值分解(SVD)方法。
DECOMP_EIG :特征值分解法。
DECOMP_CHOLESKY :Cholesky分解法。
DECOMP_QR :QR分解法。
DECOMP_NORMAL :使用归一化公式,可以与前面的标志一起使用。
函数warpPerspective()的原型如下:
void cv::warpPerspective(InputArray src,
OutputArray dst,
InputArray M,
Size dsize,
int flags = INTER_LINEAR,
int borderMode = BORDER_CONSTANT,
const Scalar & borderValue = Scalar() )
dst=cv.warpPerspective(src, M, dsize[, dst[, flags[, borderMode[, borderValue]]]])
参数意义如下:
src—输入图像。
M—尺寸为2×3的仿射变换矩阵。
dsize—输出图像的尺寸。
dst—仿射变换后的图像,与输入图像的数据类型相同,但是尺寸由参数dsize指定。
flags—插值方法和正反变换的标志位。
borderMode—像素边界外推方法的标志,详情见博文 https://www.hhai.cc/thread-178-1-1.html
borderValue—边界填充时的填充值,默认情况下为0。
给大家使用OpenCV的函数warpPerspective()作图像的透视变换的Python示例代码,
示例代码请访问本博文的原文获取。
本博文的原文链接如下:
https://www.hhai.cc/thread-192-1-1.html
代码说明:
透视变换前的四个点选取的就是图中正方形框的四个角点。
透视变换后的四个点的坐标就根据自己的需要自己设定了,不过也不是随便设定,比如在上面的代码中,我希望透视变换后的正方形是真正的正方形,那么四个点的坐标连接起来显然应该是一个是正方形。
运行结果如下图所示:
C++代码暂略,需要C++的朋友可以联系昊虹君,昊虹君可以把上面的代码改为C++代码。
以上是关于利用OpenCV的函数warpPerspective()作图像的透视变换的主要内容,如果未能解决你的问题,请参考以下文章
OpenCV2学习笔记(十五):利用Cmake高速查找OpenCV函数源代码
利用OpenCV的函数split()和merge()实现通道的分离与合并
利用OpenCV的仿射变换函数warpAffine()实现图像的亚像素级平移