问题描述:
图像透视的定义是什么呢?这里的pts1、pts2、M分别是什么呢?dst = cv2.warpPerspective(img, M, (300, 300))透视变换的3个参数是什么呢?
import cv2
import numpy as np
from matplotlib import pyplot as plt
img = cv2.imread('logo4.jpg')
rows, cols, ch = img.shape
pts1 = np.float32([[56, 65], [368, 52], [28, 387], [389, 390]])
pts2 = np.float32([[0, 0], [300, 0], [0, 300], [300, 300]])
M = cv2.getPerspectiveTransform(pts1, pts2)
dst = cv2.warpPerspective(img, M, (300, 300))
# 使用 plt.imshow 之前先创建子图
plt.subplot(121)
plt.imshow(cv2.cvtColor(img, cv2.COLOR_BGR2RGB))
plt.title('Input')
plt.subplot(122)
plt.imshow(cv2.cvtColor(dst, cv2.COLOR_BGR2RGB))
plt.title('Output')
plt.show()
问题解答:
图像透视变换是一种用于图像的几何变换,能够将图像中的四个点映射到新的位置,从而改变视角。它可以用于校正图像中的透视畸变或将图像进行不同的视角展示。
在你的代码中:
- pts1: 这是源图像中的四个点的坐标,它们代表了图像中需要被变换的区域。
- pts2: 这是目标图像中四个点的坐标,表示变换后对应的位置。
- M: 这是透视变换矩阵,通过
cv2.getPerspectiveTransform(pts1, pts2)
计算得出,定义了如何将pts1
中的点映射到pts2
中。
dst = cv2.warpPerspective(img, M, (300, 300))
的三个参数分别是:
- img: 输入图像。
- M: 透视变换矩阵。
- (300, 300): 输出图像的尺寸,即变换后的图像大小。