图片读取
import cv2
img = cv2.imread('t.jpeg',cv2.IMREAD_COLOR)
cv2.namedWindow('img', cv2.WINDOW_AUTOSIZE)
cv2.imshow('input_image', img)
roi=img[100:200,300:400]
img[50:150,200:300]=roi
b=img[:,:,0]
key=cv2.waitKey(0)
if key==27:
print(img.shape)
print(img.size)
print(b)
cv2.imwrite("3.jpg",img)
cv2.destroyAllWindows()
平移
import cv2
import matplotlib.pyplot as plt
import numpy as np
img1 = cv2.imread('t1.jpeg',cv2.IMREAD_COLOR)
print(img1.shape)
img1 =cv2.resize(img1,(1600,1200))
print(img1.shape)
h=img1.shape[0]
w=img1.shape[1]
newimg=np.zeros(img1.shape, np.uint8)
for i in range(h-100):
for j in range(w):
newimg[i+100,j]=img1[i,j]
cv2.imshow('input_image', newimg)
key=cv2.waitKey(0)
if key==27:
cv2.destroyAllWindows()
旋转
getRotationMatrix2D函数是得到一个旋转矩阵
需要1.中心点 2.旋转角度 3.缩放比列
warpAffine函数 仿射变换,可得到两个图像的关系
详情见
warpAffine.
import cv2
import matplotlib.pyplot as plt
import numpy as np
img1 = cv2.imread('t1.jpeg',cv2.IMREAD_COLOR)
print(img1.shape)
img1 =cv2.resize(img1,(1600,1200))
print(img1.shape)
h=img1.shape[0]
w=img1.shape[1]
rotate= cv2.getRotationMatrix2D((200,300),45,1)
res=cv2.warpAffine(img1,rotate,(h,w))
cv2.imshow('input_image', res)
key=cv2.waitKey(0)
if key==27:
cv2.destroyAllWindows()
缩放
这里可以直接通过计算缩放后图片尺寸与原图片尺寸大小比,再用resize函数进行转换,也可以直接对每个点的坐标计算 最近邻插值法
import cv2
import matplotlib.pyplot as plt
import numpy as np
img1 = cv2.imread('t1.jpeg',cv2.IMREAD_COLOR)
print(img1.shape)
img1 =cv2.resize(img1,(1600,1200))
print(img1.shape)
h=img1.shape[0]
w=img1.shape[1]
newimg=np.zeros(img1.shape, np.uint8)
ch=800
cw=400
newimg2=np.zeros([ch,cw,3],np.uint8)
for i in range (ch) :
for j in range (cw):
newimg2[i,j]=img1[int(i*(h/ch))][(int)(j*(w/cw))]
cv2.imshow('input_image', newimg2)
key=cv2.waitKey(0)
if key==27:
cv2.destroyAllWindows()