基于python的图片修复程序(实现水印去除)

作者:王磊的博客 时间:2021-07-03 13:35:04 

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

在现实的生活中,我们可能会遇到一些美好的或是珍贵的图片被噪声干扰,比如旧照片的折痕,比如镜头上的灰尘或污渍,更或者是某些我们想为我所用但有讨厌水印,那么有没有一种办法可以消除这些噪声呢?

答案是肯定的,依然是被我们用了无数次的OpenCV这款优秀的框架。

OpenCV

目前,OpenCV逐步成为一个通用的基础研究和产品开发平台。OpenCV这一名称包含了Open和 Computer Vision两者的意思。实际上,Open指Open Source(开源,即开放源代码),Computer Vision则指计算机视觉。OpenCV的发展对软件的开发具有重要影响。想要了解更多的话大家可以参考这篇文章:https://www.jb51.net/article/127911.htm

效果预览

基于python的图片修复程序(实现水印去除)

图片修复原理

那OpenCV究竟是怎么实现的,简单的来说就是开发者标定噪声的特征,在使用噪声周围的颜色特征推理出应该修复的图片的颜色,从而实现图片修复的。

程序实现解析

  • 标定噪声的特征,使用cv2.inRange二值化标识噪声对图片进行二值化处理,具体代码:cv2.inRange(img, np.array([240, 240, 240]), np.array([255, 255, 255])),把[240, 240, 240]~[255, 255, 255]以外的颜色处理为0;

  • 使用OpenCV的dilate方法,扩展特征的区域,优化图片处理效果;

  • 使用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()

图片扩展与腐蚀更多资料:http://opencv-python-tutroals.readthedocs.io/en/latest/py_tutorials/py_imgproc/py_morphological_ops/py_morphological_ops.html

来源:https://www.cnblogs.com/vipstone/p/9130688.html

标签:python,图片,水印
0
投稿

猜你喜欢

  • python绘制趋势图的示例

    2022-02-28 07:19:18
  • SQL Server 连接到服务器 错误233的解决办法

    2024-01-24 06:58:34
  • python实现飞行棋游戏

    2021-11-28 14:43:23
  • .Net行为型设计模式之访问者模式(Visitor)

    2024-05-13 09:18:14
  • Python将字符串常量转化为变量方法总结

    2023-07-14 00:36:58
  • python 自定义异常和主动抛出异常(raise)的操作

    2022-03-22 12:43:22
  • python读取并绘制nc数据的保姆级教程

    2023-11-23 02:19:24
  • 建立合理的索引提高SQL Server的性能

    2009-01-23 14:44:00
  • CSS在Internet Explorer 6, 7 和8中的差别

    2009-10-26 18:14:00
  • mytop 使用介绍 mysql实时监控工具

    2024-01-21 23:15:13
  • 蜕变——记QQ医生3.0

    2009-09-16 14:41:00
  • 怎么让按钮更容易被点击

    2007-08-22 09:07:00
  • 手机使用python操作图片文件(pydroid3)过程详解

    2021-06-19 13:45:39
  • thinkphp在模型中自动完成session赋值示例代码

    2024-05-03 15:51:32
  • Go微服务网关的实现

    2023-07-02 22:27:05
  • Python使用struct库的用法小结

    2023-04-29 18:42:53
  • Python实现递归遍历文件夹并删除文件

    2021-09-06 09:51:17
  • pycharm console 打印中文为乱码问题及解决

    2023-06-15 22:30:02
  • 利用python为PostgreSQL的表自动添加分区

    2023-07-07 14:44:58
  • MySQL 基于时间点的快速恢复方案

    2024-01-28 17:27:44
  • asp之家 网络编程 m.aspxhome.com