OpenCV 4.10.0
开源计算机视觉
|
OpenCV 提供了两个变换函数,cv.warpAffine 和 cv.warpPerspective,你可以用它们执行所有类型的变换。cv.warpAffine 采用一个 2x3 的变换矩阵,而 cv.warpPerspective 采用一个 3x3 的变换矩阵作为输入。
缩放就是简单的图像重设尺寸。OpenCV 为此提供了一个函数 cv.resize()。图像的大小可以手动指定,或者你可以指定缩放因子。不同的插值方法是可用的。对于缩小,较好的插值方法是 cv.INTER_AREA,而对于放大,较好的插值方法是 cv.INTER_CUBIC(较慢)和 cv.INTER_LINEAR。默认情况下,插值方法 cv.INTER_LINEAR 被用于所有重新设置尺寸的目的。你可以通过以下两种方法之一缩放输入图像
翻译是对象位置的移动。如果您知道了 (x,y) 方向的偏移,并将其设为 \((t_x,t_y)\),您可以按照如下所示创建变换矩阵 \(\textbf{M}\)
\[M = \begin{bmatrix} 1 & 0 & t_x \\ 0 & 1 & t_y \end{bmatrix}\]
您可以将其变成一个 np.float32 类型的 Numpy 数组,并将其传递给 cv.warpAffine() 函数。请参见以下示例,了解 (100,50) 的偏移
警告
cv.warpAffine() 函数的第三个参数是输出图像的大小,其形式应为 **(宽,高)**。记住,宽度 = 列数,且高度 = 行数。
请参见下方的结果
对图像进行 \(\theta\) 角度的旋转,可通过以下形式的变换矩阵实现
\[M = \begin{bmatrix} cos\theta & -sin\theta \\ sin\theta & cos\theta \end{bmatrix}\]
但 OpenCV 提供了可调节旋转中心的缩放旋转,以便您可以在任何您喜欢的位置旋转。修改后的变换矩阵由下式给出
\[\begin{bmatrix} \alpha & \beta & (1- \alpha ) \cdot center.x - \beta \cdot center.y \\ - \beta & \alpha & \beta \cdot center.x + (1- \alpha ) \cdot center.y \end{bmatrix}\]
其中
\[\begin{array}{l} \alpha = 缩放 \cdot \cos \theta , \\ \beta = 缩放 \cdot \sin \theta \end{array}\]
要找到此变换矩阵,OpenCV 提供了一个函数,cv.getRotationMatrix2D。查看以下示例,它将图像相对于中心旋转 90 度,没有任何缩放。
查看结果
在仿射变换中,原始图像中的所有平行线在输出图像中仍将保持平行。要找到变换矩阵,我们需要从输入图像中获取三个点及其在输出图像中的对应位置。然后,cv.getAffineTransform 将创建一个 2x3 矩阵,然后将其传递给 cv.warpAffine。
查看以下示例,并查看我选择的点(以绿色标示)
查看结果
对于透视变换,你需要一个 3x3 变换矩阵。即使经过变换,直线仍将保持直线。要找到此变换矩阵,你需要获取输入图像上的 4 个点,以及输出图像上的对应点。在这 4 个点中,其中 3 个点不应共线。然后,可以使用函数 cv.getPerspectiveTransform 找到变换矩阵。然后,使用此 3x3 变换矩阵应用 cv.warpPerspective。
参见以下代码
结果