欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

Python3+OpenCV2實現圖像的幾何變換(平移、鏡像、縮放、旋轉、仿射)

系統 2017 0

前言

總結一下最近看的關于opencv圖像幾何變換的一些筆記.

這是原圖:

Python3+OpenCV2實現圖像的幾何變換(平移、鏡像、縮放、旋轉、仿射)_第1張圖片

1.平移

            
import cv2
import numpy as np

img = cv2.imread("image0.jpg", 1)
imgInfo = img.shape
height = imgInfo[0]
width = imgInfo[1]
mode = imgInfo[2]

dst = np.zeros(imgInfo, np.uint8)

for i in range( height ):
  for j in range( width - 100 ):
    dst[i, j + 100] = img[i, j]

cv2.imshow('image', dst)
cv2.waitKey(0)
          

demo很簡單,就是將圖像向右平移了100個像素.如圖:

Python3+OpenCV2實現圖像的幾何變換(平移、鏡像、縮放、旋轉、仿射)_第2張圖片

2.鏡像

            
import cv2
import numpy as np


img = cv2.imread('image0.jpg', 1)
cv2.imshow('src', img)
imgInfo = img.shape
height= imgInfo[0]
width = imgInfo[1]
deep = imgInfo[2]

dst = np.zeros([height*2, width, deep], np.uint8)

for i in range( height ):
  for j in range( width ):
    dst[i,j] = img[i,j]
    dst[height*2-i-1,j] = img[i,j]

for i in range(width):
  dst[height, i] = (0, 0, 255)
cv2.imshow('image', dst)
cv2.waitKey(0)
          

demo生成一個如下效果:

Python3+OpenCV2實現圖像的幾何變換(平移、鏡像、縮放、旋轉、仿射)_第3張圖片

3.縮放

            
import cv2
img = cv2.imread("image0.jpg", 1)
imgInfo = img.shape
print( imgInfo )
height = imgInfo[0]
width = imgInfo[1]
mode = imgInfo[2]

# 1 放大 縮小 2 等比例 非等比例
dstHeight = int(height * 0.5)
dstWeight = int(width * 0.5)

# 最近鄰域插值 雙線性插值 像素關系重采樣 立方插值
dst = cv2.resize(img, (dstWeight,dstHeight))
print(dst.shape)
cv2.imshow('image', dst)
cv2.waitKey(0)
          

使用resize直接進行縮放操作,同時還可以使用鄰域插值法進行縮放,代碼如下:

            
# 1 info 2 空白模板 3 重新計算x, y
import cv2
import numpy as np
img = cv2.imread('image0.jpg', 1)
imgInfo = img.shape # 先高度,后寬度
height = imgInfo[0]
width = imgInfo[1]
dstHeight = int(height/2)
dstWidth = int(width/2)

dstImage = np.zeros([dstHeight, dstWidth, 3], np.uint8)
for i in range( dstHeight ):
  for j in range(dstWidth):
    iNew = i * ( height * 1.0 / dstHeight )
    jNew = j * ( width * 1.0 / dstWidth )

    dstImage[i,j] = img[int(iNew),int(jNew)]

cv2.imshow('image', dstImage)
cv2.waitKey(0)
          

4.旋轉

            
import cv2

img = cv2.imread('image0.jpg', 1)
cv2.imshow('src', img)
imgInfo = img.shape
height= imgInfo[0]
width = imgInfo[1]
deep = imgInfo[2]

# 定義一個旋轉矩陣
matRotate = cv2.getRotationMatrix2D((height*0.5, width*0.5), 45, 0.7) # mat rotate 1 center 2 angle 3 縮放系數

dst = cv2.warpAffine(img, matRotate, (height, width))

cv2.imshow('image',dst)
cv2.waitKey(0)
          

旋轉需要先定義一個旋轉矩陣,cv2.getRotationMatrix2D(),參數1:需要旋轉的中心點.參數2:需要旋轉的角度.參數三:需要縮放的比例.效果如下圖:

Python3+OpenCV2實現圖像的幾何變換(平移、鏡像、縮放、旋轉、仿射)_第4張圖片

5.仿射

            
import cv2
import numpy as np

img = cv2.imread('image0.jpg', 1)
cv2.imshow('src', img)
imgInfo = img.shape
height= imgInfo[0]
width = imgInfo[1]
deep = imgInfo[2]
# src 3 -> dst 3 (左上角, 左下角,右上角)
matSrc = np.float32([[0,0],[0,height-1],[width-1, 0]]) # 需要注意的是 行列 和 坐標 是不一致的
matDst = np.float32([[50,50],[100, height-50],[width-200,100]])

matAffine = cv2.getAffineTransform(matSrc,matDst) #mat 1 src 2 dst 形成組合矩陣
dst = cv2.warpAffine(img, matAffine,(height, width))
cv2.imshow('image',dst)
cv2.waitKey(0)
          

需要確定圖像矩陣的三個點坐標,及(左上角, 左下角,右上角).定義兩個矩陣,matSrc 為原圖的三個點坐標,matDst為進行仿射的三個點坐標,通過cv2.getAffineTransform()形成組合矩陣.效果如下:

Python3+OpenCV2實現圖像的幾何變換(平移、鏡像、縮放、旋轉、仿射)_第5張圖片

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

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

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 欧美一区在线观看视频 | 中文字幕精品一区 | 成人免费在线视频观看 | 中文字幕电影在线观看 | 999久久久久久久久6666 | 99久久精品国产毛片 | 午夜视频福利在线 | 国产福利视频一区 | 色午夜日本| 热@国产 | 女人色毛片女人色毛片中国 | 久久99精品久久久久久噜噜 | 国产精选经典三级小泽玛利亚 | 欧美爱爱视频网站 | 偷偷狠狠的日日高清完整视频 | 91精品成人免费国产 | 亚洲人成人| 久久久www成人免费精品 | 日韩18视频在线观看 | 成人国产免费视频 | 91久久精品日日躁夜夜躁国产 | 日韩中文一区二区三区 | 9久热这里只有精品免费 | 在线视频亚洲 | 亚洲91精品 | 久久激情小视频 | 亚洲精品久 | 日韩在线1| 亚洲精品在线播放视频 | 国产在线视频一区二区 | 一区二区三区免费看 | 中文字幕一区二区在线观看 | 亚洲免费观看视频 | 国产一区二区三区免费 | 久久久精品一区 | 久久精品这里是免费国产 | 成人片黄网站A片免费 | 国产一区二区精品丝袜 | 国产精品女A片爽爽波多洁衣 | 国产福利在线永久视频 | 久久香蕉国产精品一区二区三 |