cv2.warpAffine 參數詳解


本文鏈接:https://blog.csdn.net/qq878594585/article/details/81838260
本文為作者原創文章,未經同意嚴禁轉載!

opencv中的仿射變換在python中的應用並未發現有細致的講解,函數cv2.warpAffine的參數也模糊不清,今天和大家分享一下參數的功能和具體效果,如下:

官方給出的參數為:

cv2.warpAffine(src, M, dsize[, dst[, flags[, borderMode[, borderValue]]]]) → dst

其中:

src - 輸入圖像。
M - 變換矩陣。
dsize - 輸出圖像的大小。
flags - 插值方法的組合(int 類型!)
borderMode - 邊界像素模式(int 類型!)
borderValue - (重點!)邊界填充值; 默認情況下,它為0。

上述參數中:M作為仿射變換矩陣,一般反映平移或旋轉的關系,為InputArray類型的2×3的變換矩陣。

flages表示插值方式,默認為 flags=cv2.INTER_LINEAR,表示線性插值,此外還有:cv2.INTER_NEAREST(最近鄰插值)   cv2.INTER_AREA (區域插值)  cv2.INTER_CUBIC(三次樣條插值)    cv2.INTER_LANCZOS4(Lanczos插值)

日常進行仿射變換時,在只設置前三個參數的情況下,如 cv2.warpAffine(img,M,(rows,cols))可以實現基本的仿射變換效果,但可以出現“黑邊”現象,如圖:

 

這對后續的處理往往造成很大的困擾,第六個參數可以選擇填充的顏色,默認為黑色。在python中設置warpAffine的參數與c++中有所不同,必須指明參數的名稱,具體如下:

c++中:warpAffine(src,img,M,Size(a,b),1,0,Scalar(255,255,255));

python中:

cv2.warpAffine(img,M,(rows,cols),flags=cv2.INTER_,borderMode=cv2.BORDER_REFLECT,borderValue=(255,255,255))

在python 中有一個好處是不必按順序設置,直接指明所設置的參數即可,如將上述圖片邊界區域填充為白色:

cv2.warpAffine(img,M,(lengh,lengh),borderValue=(255,255,255))
效果圖:


————————————————
版權聲明:本文為CSDN博主「gqcngu」的原創文章,遵循 CC 4.0 BY-SA 版權協議,轉載請附上原文出處鏈接及本聲明。
原文鏈接:https://blog.csdn.net/qq878594585/article/details/81838260


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM