主頁(yè) > 知識(shí)庫(kù) > opencv實(shí)現(xiàn)圖像幾何變換

opencv實(shí)現(xiàn)圖像幾何變換

熱門標(biāo)簽:電話運(yùn)營(yíng)中心 百度AI接口 Win7旗艦版 語(yǔ)音系統(tǒng) 客戶服務(wù) 呼叫中心市場(chǎng)需求 企業(yè)做大做強(qiáng) 硅谷的囚徒呼叫中心

本文實(shí)例為大家分享了opencv實(shí)現(xiàn)圖像幾何變換的具體代碼,供大家參考,具體內(nèi)容如下

圖像伸縮(cv2.resize)

圖像的擴(kuò)大與縮小有專門的一個(gè)函數(shù),cv2.resize(),那么關(guān)于伸縮需要確定的就是縮放比例,可以是x與y方向相同倍數(shù),也可以單獨(dú)設(shè)置x與y的縮放比例。另外一個(gè)就是在縮放以后圖像必然就會(huì)變化,這就又涉及到一個(gè)插值問題。那么這個(gè)函數(shù)中,縮放有幾種不同的插值(interpolation)方法,在縮小時(shí)推薦cv2.INTER_ARER,擴(kuò)大是推薦cv2.INTER_CUBIC和cv2.INTER_LINEAR。默認(rèn)都是cv2.INTER_LINEAR,比如:

import cv2
import matplotlib.pyplot as plt

img = cv2.imread('d:/1.jpg')
# 插值:interpolation
# None本應(yīng)該是放圖像大小的位置的,后面設(shè)置了縮放比例,
#所有就不要了
res1 = cv2.resize(img,None,fx=2,fy=2,interpolation=cv2.INTER_CUBIC)
#直接規(guī)定縮放大小,這個(gè)時(shí)候就不需要縮放因子
height,width = img.shape[:2]
res2 = cv2.resize(img,(2*width,2*height),interpolation=cv2.INTER_CUBIC)
plt.subplot(131)
plt.imshow(img)
plt.subplot(132)
plt.imshow(res1)
plt.subplot(133)
plt.imshow(res2)
plt.show()

圖像平移(cv2.warpAffine)

import cv2
import numpy as np
import matplotlib.pyplot as plt

img = cv2.imread('d:/1.jpg')
H = np.float32([[1, 0, 100], [0, 1, 50]])
rows, cols = img.shape[:2]
res = cv2.warpAffine(img, H, (rows, cols)) # 需要圖像、變換矩陣、變換后的大小
plt.subplot(121)
plt.imshow(img)
plt.subplot(122)
plt.imshow(res)
plt.show()

圖像旋轉(zhuǎn)(逆時(shí)針旋轉(zhuǎn),cv2.warpAffine和cv2.getRotationMatrix2D)

為了構(gòu)造這個(gè)矩陣,opencv提供了一個(gè)函數(shù):

cv2.getRotationMatrix2D(),這個(gè)函數(shù)需要三個(gè)參數(shù),旋轉(zhuǎn)中心,旋轉(zhuǎn)角度,旋轉(zhuǎn)后圖像的縮放比例,比如下例:

import cv2
 import matplotlib.pyplot as plt

 img = cv2.imread('d:/1.jpg')
 rows, cols = img.shape[:2]
 # 第一個(gè)參數(shù)旋轉(zhuǎn)中心,第二個(gè)參數(shù)旋轉(zhuǎn)角度,第三個(gè)參數(shù):縮放比例
 M = cv2.getRotationMatrix2D((cols / 2, rows / 2), 45, 1)
 # 第三個(gè)參數(shù):變換后的圖像大小
 res = cv2.warpAffine(img, M, (rows, cols))

 plt.subplot(121)
 plt.imshow(img)
 plt.subplot(122)
 plt.imshow(res)
 plt.show()

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • python opencv捕獲攝像頭并顯示內(nèi)容的實(shí)現(xiàn)
  • python opencv 實(shí)現(xiàn)讀取、顯示、寫入圖像的方法
  • opencv 圖像輪廓的實(shí)現(xiàn)示例
  • opencv中圖像疊加/圖像融合/按位操作的實(shí)現(xiàn)
  • 基于Python的OpenCV骨架化圖像并顯示(skeletonize)

標(biāo)簽:安康 海南 山西 山西 濟(jì)南 長(zhǎng)沙 喀什 崇左

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《opencv實(shí)現(xiàn)圖像幾何變換》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266