您好,登錄后才能下訂單哦!
這篇文章主要為大家展示了“Python圖像處理之透視變換的示例分析”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“Python圖像處理之透視變換的示例分析”這篇文章吧。
如果你想對圖像進行校準,那么透視變換是非常有效的變換手段。透視變換的定義為將圖像投影到一個新的視平面,通常也被稱之為投影映射。
一般來說,通用的圖像變換公式如下所示:
上述公式中,u,v代表原始圖像坐標,x,y為經過透視變換的圖片坐標,其中變換矩陣為3X3形式。進而可以得到:
在介紹opencv的透視變換函數之前,我們舉例來講解該算法的原理:
直觀的來看,透視變換的作用就是將左側圖像的坐標點
[[50,0],[150,0],[0,200],[200,200]]
轉化為新的坐標
[[0,0],[200,0],[0,200],[200,200]]
通過計算我們知道,轉換矩陣如下:
我們來驗證一下,采用左上角的點(50,0)帶入公式,如下:
接著我們將列向量的前兩維度除以第三維執行歸一化:
所以我們知道原圖左上角點執行透視變換后的映射關系:
本文以撲克牌的例子來進行講解,樣例結果如下:
首先我們來讀入一副彩色圖像,如下:
import cv2 import numpy as np img = cv2.imread("image/sample.jpg") h, w, c = img.shape # h=240 w=320
接著我們需要挑選四個點,我們這里采用左上,左下,右下和右上,下面的代碼把我們挑選的四個點畫到圖像上
src_list = [(61, 70), (151, 217), (269, 143), (160, 29)] for i, pt in enumerate(src_list): cv2.circle(img, pt, 5, (0, 0, 255), -1) cv2.putText(img,str(i+1),(pt[0]+5,pt[1]+10),cv2.FONT_HERSHEY_SIMPLEX, 0.5, (0, 0, 255), 2) pts1 = np.float32(src_list)
結果如下:
首先選擇四個目的圖像上的點,然后調用openv函數進行透視變換,代碼如下:
pts2 = np.float32([[0, 0], [0, w - 2], [h - 2, w - 2], [h - 2, 0]]) matrix = cv2.getPerspectiveTransform(pts1, pts2) result = cv2.warpPerspective(img, matrix, (h, w)) cv2.imshow("Image", img) cv2.imshow("Perspective transformation", result) cv2.waitKey(0)
得到結果如下:
我們在實際應用中,可以使用透視變換來替換廣告牌中對應的背景圖,結果如下:
廣告牌:
Logo圖:
結果圖:
以上是“Python圖像處理之透視變換的示例分析”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。