Opencv-Python 影象透視變換cv2.warpPerspective
# -*- coding:utf-8 -*-
import cv2
import numpy as np
import sys
img = cv2.imread('test.jpg')
# cv2.imshow("original", img)
# 可選,擴充套件影象,保證內容不超出可視範圍
img = cv2.copyMakeBorder(img, 200, 200, 200, 200, cv2.BORDER_CONSTANT, 0)
w, h = img.shape[0:2]
anglex = 0
angley = 30
anglez = 0 # 是旋轉
fov = 42
r = 0
def rad(x):
return x * np.pi / 180
def get_warpR():
global anglex,angley,anglez,fov,w,h,r
# 鏡頭與影象間的距離,21為半可視角,算z的距離是為了保證在此可視角度下恰好顯示整幅影象
z = np.sqrt(w ** 2 + h ** 2) / 2 / np.tan(rad(fov / 2))
# 齊次變換矩陣
rx = np.array([[1, 0, 0, 0],
[0, np.cos(rad(anglex)), -np.sin(rad(anglex)), 0],
[0, -np.sin(rad(anglex)), np.cos(rad(anglex)), 0, ],
[0, 0, 0, 1]], np.float32)
ry = np.array([[np.cos(rad(angley)), 0, np.sin(rad(angley)), 0],
[0, 1, 0, 0],
[-np.sin(rad(angley)), 0, np.cos(rad(angley)), 0, ],
[0, 0, 0, 1]], np.float32)
rz = np.array([[np.cos(rad(anglez)), np.sin(rad(anglez)), 0, 0],
[-np.sin(rad(anglez)), np.cos(rad(anglez)), 0, 0],
[0, 0, 1, 0],
[0, 0, 0, 1]], np.float32)
r = rx.dot(ry).dot(rz)
# 四對點的生成
pcenter = np.array([h / 2, w / 2, 0, 0], np.float32)
p1 = np.array([0, 0, 0, 0], np.float32) - pcenter
p2 = np.array([w, 0, 0, 0], np.float32) - pcenter
p3 = np.array([0, h, 0, 0], np.float32) - pcenter
p4 = np.array([w, h, 0, 0], np.float32) - pcenter
dst1 = r.dot(p1)
dst2 = r.dot(p2)
dst3 = r.dot(p3)
dst4 = r.dot(p4)
list_dst = [dst1, dst2, dst3, dst4]
org = np.array([[0, 0],
[w, 0],
[0, h],
[w, h]], np.float32)
dst = np.zeros((4, 2), np.float32)
# 投影至成像平面
for i in range(4):
dst[i, 0] = list_dst[i][0] * z / (z - list_dst[i][2]) + pcenter[0]
dst[i, 1] = list_dst[i][1] * z / (z - list_dst[i][2]) + pcenter[1]
warpR = cv2.getPerspectiveTransform(org, dst)
return warpR
def control():
global anglex,angley,anglez,fov,r
# 鍵盤控制
if 27 == c: # Esc quit
sys.exit()
if c == ord('w'):
anglex += 1
if c == ord('s'):
anglex -= 1
if c == ord('a'):
angley += 1
print(angley)
# dx=0
if c == ord('d'):
angley -= 1
if c == ord('u'):
anglez += 1
if c == ord('p'):
anglez -= 1
if c == ord('t'):
fov += 1
if c == ord('r'):
fov -= 1
if c == ord(' '):
anglex = angley = anglez = 0
if c == ord('e'):
print("======================================")
print('Rotation Matrix:')
print(r)
print('angle alpha(anglex):')
print(anglex)
print('angle beta(angley):')
print(angley)
print('dz(anglez):')
print(anglez)
while True:
warpR = get_warpR()
result = cv2.warpPerspective(img, warpR, (h, w))
cv2.namedWindow('result',2)
cv2.imshow("result", result)
c = cv2.waitKey(30)
control()
cv2.destroyAllWindows()
執行效果:
控制:
- s控制垂直方向上的形變
- a和d控制水平方向上的行變
- u和p控制角度旋轉
- e 輸出當前旋轉矩陣引數
相關文章
- 【OpenCV-Python】:影像的傅立葉變換與逆傅立葉變換OpenCVPython
- OpenGL模型檢視變換、投影變換、視口變換模型
- 影象處理 二維小波變換
- 影象處理1--傅立葉變換(Fourier Transform )ORM
- 相位掩膜+傅立葉變換進行影象加密加密
- OpenCV-Python 視訊讀取OpenCVPython
- 小波變換在數字影象上的應用(上)
- OpenGL 使用矩陣變換改變檢視矩陣
- MATLAB數字影象處理(一)基礎操作和傅立葉變換Matlab
- 【數字影象處理】六.MFC空間幾何變換之影象平移、映象、旋轉、縮放詳解
- View Transform(檢視變換)詳解ViewORM
- [Python影象處理] 五.影象融合、加法運算及影象型別轉換Python型別
- OpenCV計算機視覺學習(3)——影像灰度線性變換與非線性變換(對數變換,伽馬變換)OpenCV計算機視覺
- 15分鐘理解數字影象中的二維傅立葉變換語義
- 如何透過css變數實現主題切換?CSS變數
- 透過v$sql_bind_capture 檢視繫結變數。SQLAPT變數
- 深入學習OpenCV文件掃描及OCR識別(文件掃描,影像矯正,透視變換,OCR識別)OpenCV
- OpenCV-Python教程(9)(10)(11): 使用霍夫變換檢測直線 直方圖均衡化 輪廓檢測OpenCVPython直方圖
- Python資料視覺化影象庫MatPlotLib基本影象操作Python視覺化
- Win10如何改變切換視窗開啟所有視窗Win10
- 計算機視覺—影象特效(3)計算機視覺特效
- 透視表excel透視表怎麼做 excel的資料透視表怎麼弄Excel
- OpenCV計算機視覺學習(10)——影像變換(傅立葉變換,高通濾波,低通濾波)OpenCV計算機視覺
- 醫學影象資料格式和格式轉換
- 計算機視覺—圖片幾何變換(2)計算機視覺
- 視覺化學習:CSS transform與仿射變換視覺化CSSORM
- OpenCV-Python -- Fourier TransformOpenCVPythonORM
- opencv-python 影像 二OpenCVPython
- ps透視裁剪扣取透視面上的相框內容
- Daguerre Android 影象視訊選擇器Android
- Hough變換
- 傅立葉變換
- Swift 影象轉換為Base64字串Swift字串
- 理解SVG座標系統和變換: 建立新視窗SVG
- OpenCV計算機視覺學習(11)——影像空間幾何變換(影像縮放,影像旋轉,影像翻轉,影像平移,仿射變換,映象變換)OpenCV計算機視覺
- 最新openCV-Python安裝教程(opencv-python版本4.4.0, Python版本: 3.9)OpenCVPython
- 仿射變換及其變換矩陣的理解矩陣
- 小波變換與傅立葉變換的區別