在現實的圖像操作軟件中,經常碰到的不是給出放大多少倍,而是由用戶在軟件的界面上選擇多大的區域,或者選擇幾個點,那么這樣情況下,怎么樣來計算出變換矩陣呢?從前面知道變換矩陣是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里實現仿射變換―坐標變換效果,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!
更多文章、技術交流、商務合作、聯系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
