基于python的图片修复程序-可用于水印去除

发表于:2018-6-05 09:08

字体: | 上一篇 | 下一篇 | 我要投稿

 作者:王磊的博客    来源:博客园

  图片修复程序-可用于水印去除
  在现实的生活中,我们可能会遇到一些美好的或是珍贵的图片被噪声干扰,比如旧照片的折痕,比如镜头上的灰尘或污渍,更或者是某些我们想为我所用但有讨厌水印,那么有没有一种办法可以消除这些噪声呢?
  答案是肯定的,依然是被我们用了无数次的OpenCV这款优秀的框架。
  效果预览
  图片修复原理
  那OpenCV究竟是怎么实现的,简单的来说就是开发者标定噪声的特征,在使用噪声周围的颜色特征推理出应该修复的图片的颜色,从而实现图片修复的。
  程序实现解析
  1.标定噪声的特征,使用cv2.inRange二值化标识噪声对图片进行二值化处理,具体代码:cv2.inRange(img, np.array([240, 240, 240]), np.array([255, 255, 255])),把[240, 240, 240]~[255, 255, 255]以外的颜色处理为0;
  2.使用OpenCV的dilate方法,扩展特征的区域,优化图片处理效果;
  3.使用inpaint方法,把噪声的mask作为参数,推理并修复图片;
  完整代码
  #coding=utf-8
  #图片修复
  import cv2
  import numpy as np
  path = "img/inpaint.png"
  img = cv2.imread(path)
  hight, width, depth = img.shape[0:3]
  #图片二值化处理,把[240, 240, 240]~[255, 255, 255]以外的颜色变成0
  thresh = cv2.inRange(img, np.array([240, 240, 240]), np.array([255, 255, 255]))
  #创建形状和尺寸的结构元素
  kernel = np.ones((3, 3), np.uint8)
  #扩张待修复区域
  hi_mask = cv2.dilate(thresh, kernel, iterations=1)
  specular = cv2.inpaint(img, hi_mask, 5, flags=cv2.INPAINT_TELEA)
  cv2.namedWindow("Image", 0)
  cv2.resizeWindow("Image", int(width / 2), int(hight / 2))
  cv2.imshow("Image", img)
  cv2.namedWindow("newImage", 0)
  cv2.resizeWindow("newImage", int(width / 2), int(hight / 2))
  cv2.imshow("newImage", specular)
  cv2.waitKey(0)
  cv2.destroyAllWindows()



上文内容不用于商业目的,如涉及知识产权问题,请权利人联系博为峰小编(021-64471599-8017),我们将立即处理。
《2023软件测试行业现状调查报告》独家发布~

关注51Testing

联系我们

快捷面板 站点地图 联系我们 广告服务 关于我们 站长统计 发展历程

法律顾问:上海兰迪律师事务所 项棋律师
版权所有 上海博为峰软件技术股份有限公司 Copyright©51testing.com 2003-2024
投诉及意见反馈:webmaster@51testing.com; 业务联系:service@51testing.com 021-64471599-8017

沪ICP备05003035号

沪公网安备 31010102002173号