您好,登錄后才能下訂單哦!
這篇文章主要為大家展示了“Python在OpenCV里如何實現仿射變換”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“Python在OpenCV里如何實現仿射變換”這篇文章吧。
在現實的圖像操作軟件中,經常碰到的不是給出放大多少倍,而是由用戶在軟件的界面上選擇多大的區域,或者選擇幾個點,那么這樣情況下,怎么樣來計算出變換矩陣呢?從前面知道變換矩陣是2X3的矩陣,說明有六個未知數,又有中學的代數知識知道要解決六個未知數,那么方程組至少要聯立三條方程,要準備三條方程的先決條件,就是要有三組坐標。因此,只要在用戶選擇的區域里找到三個不同點的坐標,就可以計算出變換矩陣。如果給出三組坐標[0, 0], [200, 0], [0, 200],通過變換之后新坐標是[0, 0], [128, 0], [0, 50],那用什么函數來計算這個矩陣呢?這是要使用OpenCV里的getAffineTransform函數。
下面通過例子來演示這個功能:
#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] #從目標坐標計算出2X3的矩陣,然后調用warpAffine執行 src = np.array([[0, 0], [200, 0], [0, 200]], np.float32) dst = np.array([[0, 0], [128, 0], [0, 50]], np.float32) A1 = cv2.getAffineTransform(src, dst) d1 = cv2.warpAffine(image, A1, (w, h), borderValue = 125) #顯示操作之后的圖片 cv2.imshow("d1",d1) #顯示圖像 cv2.imshow("image", image) #等待用戶輸入,然后刪除所有窗口 cv2.waitKey(0) cv2.destroyAllWindows()
輸出結果如下:
使用坐標變換的方法,可以不用知道中間是否先旋轉,還是先平移的操作。
以上是“Python在OpenCV里如何實現仿射變換”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。