图像镜像翻转

将图像左右镜像翻转,生成翻转后的图像

python3代码

import numpy as np
import cv2
import matplotlib.pyplot as plt
#图片镜像翻转
def left2right(img_path):
  im=cv2.imread(img_path)
  h,w,_=im.shape
  result=np.zeros(im.shape,dtype=np.uint8)
  for i in range(h):
    for j in range(w):
      #每一行倒序翻转
      result[i][j]=im[i][np.abs(j-w+1)]
  return result
  
def main():
  img_path1='./1.jpg'
  #保存图片路径
  img_path2='./result'+img_path1.split('/')[1]
  #得到镜像翻转后的图片数据
  result=left2right(img_path1)
  #保存为图片
  cv2.imwrite(img_path2,result)

  #结果展示
  #opencv的颜色通道顺序为[B,G,R],而matplotlib颜色通道顺序为[R,G,B],所以需要调换一下通道位置
  plt.rcParams['font.sans-serif'] = ['SimHei']  # 中文乱码
  #子图1,原始图像
  plt.subplot(121)
  #imshow()对图像进行处理,画出图像,show()进行图像显示
  plt.imshow(cv2.imread(img_path1)[:,:,(2,1,0)])
  plt.title('原图')
  #不显示坐标轴
  plt.axis('off')

  #子图2,镜像翻转后图像
  plt.subplot(122)
  plt.imshow(result[:,:,(2,1,0)])
  plt.title('镜像翻转后图像')
  plt.axis('off')
  plt.show()


if __name__ =='__main__':
  main()

实验结果

在这里插入图片描述

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

z2bns

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值