opencv基础知识-图像移位

opencv基础知识-图像移位

笔者工作环境
win10
vscode
图片位移可以通过俩种方法实现,第一个调用api,调用matshift
第二个方法图片移动,即为像素的移动,比如是(10,10)的像素分别向x方向和y方向移动100个像素,可以给x方向和y方向像素点分别加100。(10+100,10+100)

方法一:调用api方式代码

import cv2
import numpy as np


img = cv2.imread(r"C:\Users\lenovo\Desktop\python\python_vision\image.jpg",1)
cv2.imshow("img",img)


imgInfo = img.shape

height = imgInfo[0]
width = imgInfo[1]

matShift = np.float32([[1,0,100],[0,1,100]])   #2*3的偏移矩阵,原图像乘以此矩阵,就可以完成矩阵的平移。

dst = cv2.warpAffine(img,matShift,(height,width))
#
cv2.imshow("dst",dst)
cv2.waitKey(0)

此移位的重点代码是在matShift = np.float32([[1,0,100],[0,1,100]])的矩阵,以及下面的一行dst = cv2.warpAffine(img,matShift,(height,width))
此代码的原理是可以分为俩个部分,23的矩阵可以被分为俩个部分,一个是22的矩阵,一个是后边2*1的矩阵。

a*b+c

图片移位,即为图片为像素点矩阵乘以一个平移矩阵,也可以将平移矩阵换成旋转矩阵,图片即为旋转。
opencv基础知识-图像移位_第1张图片

方法二:

import cv2
import numpy as np

img = cv2.imread(r"C:\Users\lenovo\Desktop\python\python_vision\image.jpg",1)

imgInfo = img.shape
print(imgInfo)
dst = np.zeros(img.shape,np.uint8)  
#第一个参数是图片维度,第二个参数图片数据类型,像素范围0-255

height = imgInfo[0]
width = imgInfo[1]

for i in range(0,height-10):    #因为像素是右移10,向下移动10,需要将图片像素减掉10,不然矩阵维度不一,报错。
    for j in range(0,width-10):
        dst[i+10,j+10] = img[i,j]  
cv2.imshow("dst",dst)
cv2.waitKey(0)

方法二是将像素点通过循环的方式一个个的移动。与方法一调用api方式不一样的
opencv基础知识-图像移位_第2张图片

你可能感兴趣的:(#,ros-机器视觉,opencv,计算机视觉,cv,图像识别)