本文共 791 字,大约阅读时间需要 2 分钟。
是一个很实用的功能,当用手机去拍证件或者名片时,经常会拍歪,或者有边框。如果你使用过类似“扫描全能王”的软件,你应该知道,他们会自动把证件矫正并除边框,它就是通过透视变换实现的,和numpy中的仿射变换一样。
import cv2import numpy as npimport matplotlib.pyplot as pltimg = cv2.imread('E:\\card2.jpg')rows, cols = img.shape[:2]# 原图中书本的四个角点pts1 = np.float32([[69, 163], [704, 62], [162, 675], [970, 411]])# 变换后分别在左上、右上、左下、右下四个点pts2 = np.float32([[0, 1000], [0, 0], [750, 1000], [750, 0]])# 生成透视变换矩阵M = cv2.getPerspectiveTransform(pts1, pts2)# 进行透视变换dst = cv2.warpPerspective(img, M, (750, 1000))plt.subplot(121), plt.imshow(img[:, :, ::-1]), plt.title('input')plt.subplot(122), plt.imshow(dst[:, :, ::-1]), plt.title('output')# img[:, :, ::-1]是将BGR转化为RGBplt.show()
转载地址:http://mjvwo.baihongyu.com/