python在OpenCV里實現(xiàn)投影變換效果
前面學(xué)習(xí)了仿射變換,是經(jīng)常使用到的變換,也很容易理解。在日常生活中,經(jīng)常會遇到下面這種的情況:

仔細(xì)地觀察比亞迪秦這臺汽車的車牌,發(fā)現(xiàn)它拍照的角度不是垂直的方向,而是有一個角度,當(dāng)要進行車牌識別的時候,發(fā)現(xiàn)字符是變形的,與電腦里比較的圖片肯定有區(qū)別,因此識別不出來。這時怎么辦呢?就需要經(jīng)過一個投影變換才可以把車牌號糾正過來,才能進入識別過程。
好吧,到這里認(rèn)識到投影變換的感性認(rèn)識了,那么你又會繼續(xù)考慮下一個問題,在軟件里怎么樣計算呢,難道還是使用仿射變換的矩陣。從這里看一下,前面閩A比較大,后面88比較小,說明原本平行的兩邊已經(jīng)不平行了。仿射變換之后,平行的線還是平行的,因此這一點也是仿射變換與投影變換的區(qū)別。
投影變換只是保證同一條直線的點還是在同一條直線上,但不再保證平行了。因為投影變換是一個二維圖像(車牌)經(jīng)過一個三維變換,然后映射到另外一個二維空間,二維圖像的二維空間與映射后的二維空間不一樣,如果一樣,就是仿射變換。投影變換也可以使用矩陣來進行描述,如下:

投影變換的矩陣是8個未知數(shù),所以要四組不同的坐標(biāo)點才可以計算出來,與前面的矩陣比較一下:

在OpenCV里是使用下面的公式計算:

因此只要構(gòu)造了投影變換矩陣,其它的計算與仿射變換是一樣的。下面通過例子來演示投影變換的功能:
#python 3.7.4,opencv4.1
#蔡軍生 https://blog.csdn.net/caimouse/article/details/51749579
#
import cv2
import numpy as np
#圖片的路徑
imgname = "img1.jpg"
#讀取圖片
image = cv2.imread(imgname, cv2.IMREAD_COLOR)
#圖片的高度和寬度
h,w = image.shape[:2]
#從目標(biāo)坐標(biāo)計算出3X3的矩陣,然后調(diào)用warpPerspective執(zhí)行
src = np.array([[0,0], [w-1,0], [0,h-1], [w-1,h-1]], np.float32)
dst = np.array([[100,50], [w/2.0,50], [100,h-1], [w-1,h-1]], np.float32)
A1 = cv2.getPerspectiveTransform(src, dst)
d1 = cv2.warpPerspective(image, A1, (w, h), borderValue = 125)
#顯示操作之后的圖片
cv2.imshow("d1",d1)
#顯示圖像
cv2.imshow("image", image)
#等待用戶輸入,然后刪除所有窗口
cv2.waitKey(0)
cv2.destroyAllWindows()
結(jié)果輸出如下:

在這個例子里,先行構(gòu)造四組坐標(biāo)點,然后調(diào)用getPerspectiveTransform函數(shù)計算投影變換矩陣,然后調(diào)用函數(shù)warpPerspective來計算變換。如果要糾正圖片,也是一樣的,只要給出前后的四組的坐標(biāo)值即可。
總結(jié)
以上所述是小編給大家介紹的python在OpenCV里實現(xiàn)投影變換效果,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!
- Python實現(xiàn)PS濾鏡中馬賽克效果示例
- 利用python、tensorflow、opencv、pyqt5實現(xiàn)人臉實時簽到系統(tǒng)
- Python Opencv提取圖片中某種顏色組成的圖形的方法
- Python在OpenCV里實現(xiàn)極坐標(biāo)變換功能
- python openCV獲取人臉部分并存儲功能
- python opencv實現(xiàn)證件照換底功能
- Python下opencv圖像閾值處理的使用筆記
- Python+Opencv識別兩張相似圖片
- python結(jié)合opencv實現(xiàn)人臉檢測與跟蹤
- python-opencv在有噪音的情況下提取圖像的輪廓實例
- python使用opencv實現(xiàn)馬賽克效果示例
相關(guān)文章
Python-apply(lambda x: )的使用及說明
這篇文章主要介紹了Python-apply(lambda x: )的使用及說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-02-02
Python調(diào)用百度根據(jù)經(jīng)緯度查詢地址的示例代碼
今天小編就為大家分享一篇Python調(diào)用百度根據(jù)經(jīng)緯度查詢地址的示例代碼,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-07-07
Anaconda安裝之后Spyder打不開解決辦法(親測有效!)
這篇文章主要給大家介紹了關(guān)于Anaconda安裝之后Spyder打不開解決辦法,文中將解決的過程介紹的非常詳細(xì),親測有效,對同樣遇到這個問題的朋友具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2023-04-04
python 牛頓法實現(xiàn)邏輯回歸(Logistic Regression)
這篇文章主要介紹了python 牛頓法實現(xiàn)邏輯回歸(Logistic Regression),幫助大家更好的進行機器學(xué)習(xí),感興趣的朋友可以了解下2020-10-10
Python實踐之使用Pandas進行數(shù)據(jù)分析
在數(shù)據(jù)分析領(lǐng)域,Python的Pandas庫是一個非常強大的工具。這篇文章將為大家詳細(xì)介紹如何使用Pandas進行數(shù)據(jù)分析,希望對大家有所幫助2023-04-04

