最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當(dāng)前位置: 首頁(yè) - 科技 - 知識(shí)百科 - 正文

在Python下利用OpenCV來旋轉(zhuǎn)圖像的教程

來源:懂視網(wǎng) 責(zé)編:小采 時(shí)間:2020-11-27 14:32:41
文檔

在Python下利用OpenCV來旋轉(zhuǎn)圖像的教程

在Python下利用OpenCV來旋轉(zhuǎn)圖像的教程:OpenCV是應(yīng)用最被廣泛的的開源視覺庫(kù)。他允許你使用很少的代碼來檢測(cè)圖片或視頻中的人臉。 這里有一些互聯(lián)網(wǎng)上的教程來闡述怎么在OpenCV中使用仿射變換(affine transform)旋轉(zhuǎn)圖片--他們并沒有處理旋轉(zhuǎn)一個(gè)圖片里的矩形一般會(huì)把矩形的邊角切掉這一問題,所
推薦度:
導(dǎo)讀在Python下利用OpenCV來旋轉(zhuǎn)圖像的教程:OpenCV是應(yīng)用最被廣泛的的開源視覺庫(kù)。他允許你使用很少的代碼來檢測(cè)圖片或視頻中的人臉。 這里有一些互聯(lián)網(wǎng)上的教程來闡述怎么在OpenCV中使用仿射變換(affine transform)旋轉(zhuǎn)圖片--他們并沒有處理旋轉(zhuǎn)一個(gè)圖片里的矩形一般會(huì)把矩形的邊角切掉這一問題,所

OpenCV是應(yīng)用最被廣泛的的開源視覺庫(kù)。他允許你使用很少的代碼來檢測(cè)圖片或視頻中的人臉。

這里有一些互聯(lián)網(wǎng)上的教程來闡述怎么在OpenCV中使用仿射變換(affine transform)旋轉(zhuǎn)圖片--他們并沒有處理旋轉(zhuǎn)一個(gè)圖片里的矩形一般會(huì)把矩形的邊角切掉這一問題,所以產(chǎn)生的圖片需要修改。當(dāng)正確的使用一點(diǎn)代碼時(shí),這是一點(diǎn)瑕疵。

def rotate_about_center(src, angle, scale=1.):
 w = src.shape[1]
 h = src.shape[0]
 rangle = np.deg2rad(angle) # angle in radians
 # now calculate new image width and height
 nw = (abs(np.sin(rangle)*h) + abs(np.cos(rangle)*w))*scale
 nh = (abs(np.cos(rangle)*h) + abs(np.sin(rangle)*w))*scale
 # ask OpenCV for the rotation matrix
 rot_mat = cv2.getRotationMatrix2D((nw*0.5, nh*0.5), angle, scale)
 # calculate the move from the old center to the new center combined
 # with the rotation
 rot_move = np.dot(rot_mat, np.array([(nw-w)*0.5, (nh-h)*0.5,0]))
 # the move only affects the translation, so update the translation
 # part of the transform
 rot_mat[0,2] += rot_move[0]
 rot_mat[1,2] += rot_move[1]
 return cv2.warpAffine(src, rot_mat, (int(math.ceil(nw)), int(math.ceil(nh))), flags=cv2.INTER_LANCZOS4)

從原始圖像的中心到目標(biāo)圖像的中心,在旋轉(zhuǎn)中的仿射變換必須結(jié)合 仿射變換的平移。一個(gè)在平面中(2D)的仿射變換是一個(gè)2x2的矩陣A和一個(gè)平移的向量a-它取得原始點(diǎn)p = (x,y)到目標(biāo):Ap + a.結(jié)合了兩次變換Ap + a和Bp+b,先做A然后是B,軟后得到了 B(Ap + a)+ b --另一個(gè)與矩陣BA和向量Ba + b的仿射變換。


在此情況下,我們正在把旋轉(zhuǎn)功能與平移合并。作為相似變換的平移具有2x2矩陣I與運(yùn)動(dòng)矢量m的特征,所以,以Ip + m表示,我們想首先平移到新的中心,飯后旋轉(zhuǎn)它,這樣,在應(yīng)用Ip + m 后我們旋轉(zhuǎn)Rp + r,產(chǎn)生Rp + Rm + r,這解釋了為什么我們不得不只增加兩個(gè)系數(shù)。

附言:悲哀地說,如果numpy把輸入的數(shù)據(jù)看作是矢量的矢量,而不是矩陣,那解釋了乘法算子不是矩陣乘法,所以,我們必須明確地寫入np.dot。

又附言:我們使用蘭索斯插值,這一般對(duì)擴(kuò)展有利而對(duì)把規(guī)??s得非常小不利;考慮到應(yīng)用方面,我們應(yīng)該改編這個(gè)插值。

再附言:與Python的相互作用因cv2模塊而改善很多,但是因?yàn)閚umpy的坐標(biāo)不同于OpenCV,所以仍不可避免地有一些為完善之處。另外,因某個(gè)原因,OpenCV始終把各單元當(dāng)作度數(shù)而不是弧度使用,等等。就numpy而言,圖像陣列中的坐標(biāo)是以[y,x]次序存取的,如首先垂直向下增加,接著水平向右增加一樣。就OpenCV而言,大小用(寬度,高度)表示,次序正相反。

聲明:本網(wǎng)頁(yè)內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問題請(qǐng)及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

在Python下利用OpenCV來旋轉(zhuǎn)圖像的教程

在Python下利用OpenCV來旋轉(zhuǎn)圖像的教程:OpenCV是應(yīng)用最被廣泛的的開源視覺庫(kù)。他允許你使用很少的代碼來檢測(cè)圖片或視頻中的人臉。 這里有一些互聯(lián)網(wǎng)上的教程來闡述怎么在OpenCV中使用仿射變換(affine transform)旋轉(zhuǎn)圖片--他們并沒有處理旋轉(zhuǎn)一個(gè)圖片里的矩形一般會(huì)把矩形的邊角切掉這一問題,所
推薦度:
標(biāo)簽: 教程 的教程 python
  • 熱門焦點(diǎn)

最新推薦

猜你喜歡

熱門推薦

專題
Top