用PIL、cv2、matplotlib.pyplot、numpy库简单实现一个图像的水平镜像变换
水平镜像变换原理很简单,只是对宽操作而已,提取图片的高和宽,遍历每个像素,然后用宽减去当前的y坐标即可,注意一定要先创造一个原图片的副本,即img_copy,不然对原图的迭代修改过程中会不断修改图片数据,导致会出现镜像一半的情况。
from PIL import Image
import cv2 as cv
import matplotlib.pyplot as plt
import numpy as np
def Mirror(img):
img_copy = np.copy(img)
h, w = img_copy.shape
for x in range(w):
for y in range(h):
img_copy[x, y] = img[x, h-y-1]
return img_copy
Img = cv.imread('图片路径',cv.IMREAD_GRAYSCALE)
plt.figure(figsize=(20,8))
plt.subplot(131)
plt.imshow(Img, cmap='gray')
plt.title("Original image")
Mirror_Image = Mirror(Img)
plt.subplot(132)
plt.imshow(Mirror_Image , cmap='gray')
plt.title("Original image")