可以看出,经过透视变换后我们可以将原本倾斜的本子变成规规矩矩的。♂️♂️♂️这样的操作后我们就可以集中精力来处理我们所关注的本子的信息,而不受外界环境的影响,是不是很神奇,下面让我们一起来学习一下。✈✈✈
import cv2 #opencv读取的格式是BGR
import numpy as np
import matplotlib.pyplot as plt#Matplotlib是RGB
%matplotlib inline
def cv_show(img,name):
cv2.imshow(name,img)
cv2.waitKey()
cv2.destroyAllWindows()
#读取图片
image=cv2.imread('book.jpg') #这里传入所需图片路径
cv_show(image,"image")
width,height = 750,950
pts1 = np.float32([[1037,1109],[1893,237],[3113,2641],[4624,3472]])
pts2 = np.float32([[0,0],[width,0],[0,height],[width,height]])
pts1中的坐标位置我们怎么得到呢,我们可以借助画图工具来获取本子四个顶点的坐标,如下图:【当鼠标移动到对应位置,左下角会显示对应的像素坐标】
M = cv2.getPerspectiveTransform(pts1, pts2)
warped = cv2.warpPerspective(image, M, (width, height))
这部分是核心,主要是通过opencv中的函数来实现的,输出的warped就是经过透视变换后的图片。感兴趣的可以看一下透视变换的原理,这里不赘述,主要的思想就是把二维的图片先拉到三维,然后再输出为二维。
cv_show(warped,'warped')
cv2.imwrite('warped.png',warped)
咻咻咻咻~~duang~~点个赞呗