您好,登錄后才能下訂單哦!
這篇文章主要介紹“opencv怎么保持圖像內容的旋轉”,在日常操作中,相信很多人在opencv怎么保持圖像內容的旋轉問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”opencv怎么保持圖像內容的旋轉”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
在opencv中,旋轉圖像只需調用以下代碼:
M = cv2.getRotationMatrix2D((width//2, height//2), 45, 1) image_new = cv2.warpAffine(image, M, (width, height))
但這樣調用會損失圖像內容,如下: cdn.nlark.com/yuque/0/2020/png/1445121/1599750201721-e1633576-dcb6-45a7-8550-da35510ff367.png">
但很多時候我們希望旋轉之后圖像依然完整:
下面給出一種解決方案:
def rotate_keep(degree, width, height): """ 無損圖像的旋轉 @param degree: @param width: @param height: @return: 旋轉矩陣,新的寬高 """ height_new = int(width * fabs(sin(radians(degree))) + height * fabs(cos(radians(degree)))) width_new = int(height * fabs(sin(radians(degree))) + width * fabs(cos(radians(degree)))) mat_rotation = cv2.getRotationMatrix2D((width / 2, height / 2), degree, 1) mat_rotation[0, 2] += (width_new - width) / 2 mat_rotation[1, 2] += (height_new - height) / 2 return mat_rotation, width_new, height_new angle = 45 height, width = image.shape[0:2] M, width_new, height_new = rotate_keep(45, width, height) image_new = cv2.warpAffine(image, M, (width_new, height_new))
代碼是把整個過程分為三個步驟
先將圖片旋轉
計算旋轉之后理論的圖像大小
將圖像平移使得坐標為負的地方平移后坐標為正
到此,關于“opencv怎么保持圖像內容的旋轉”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。