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


Posted in Python onJune 04, 2018

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

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

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

OpenCV

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

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

Python 相关文章推荐
python调用新浪微博API项目实践
Jul 28 Python
Python实现从url中提取域名的几种方法
Sep 26 Python
Python简单操作sqlite3的方法示例
Mar 22 Python
非递归的输出1-N的全排列实例(推荐)
Apr 11 Python
简单谈谈Python中的json与pickle
Jul 19 Python
创建Django项目图文实例详解
Jun 06 Python
Python 将json序列化后的字符串转换成字典(推荐)
Jan 06 Python
Python连接SQLite数据库并进行增册改查操作方法详解
Feb 18 Python
社区版pycharm创建django项目的方法(pycharm的newproject左侧没有项目选项)
Sep 23 Python
python Xpath语法的使用
Nov 26 Python
Python Parser的用法
May 12 Python
Python Django获取URL中的数据详解
Nov 01 Python
python实现requests发送/上传多个文件的示例
Jun 04 #Python
python3写的简单本地文件上传服务器实例
Jun 04 #Python
Python装饰器的执行过程实例分析
Jun 04 #Python
使用Python监控文件内容变化代码实例
Jun 04 #Python
Python操作mongodb的9个步骤
Jun 04 #Python
Python中property函数用法实例分析
Jun 04 #Python
使用Python快速搭建HTTP服务和文件共享服务的实例讲解
Jun 04 #Python
You might like
PHP实现图片的等比缩放和Logo水印功能示例
2017/05/04 PHP
laravel 输出最后执行sql 附:whereIn的使用方法
2019/10/10 PHP
为你的 Laravel 验证器加上多验证场景的实现
2020/04/07 PHP
QQ登录简单实现代码
2021/03/09 Javascript
JavaScript 滚轮事件使用说明
2010/03/07 Javascript
jquery 单击li防止重复加载的实现代码
2010/12/24 Javascript
js的写法基础分析
2011/01/17 Javascript
精心挑选的15个jQuery下拉菜单制作教程
2012/06/15 Javascript
使用js修改客户端注册表的方法
2013/08/09 Javascript
document节点对象的获取方式示例介绍
2013/12/24 Javascript
浅析jquery ajax异步调用方法中不能给全局变量赋值的原因及解决方法
2014/01/10 Javascript
JavaScript设计模式之工厂方法模式介绍
2014/12/28 Javascript
集合Bootstrap自定义confirm提示效果
2017/09/19 Javascript
浅谈vue中.vue文件解析流程
2018/04/24 Javascript
js实现动态添加上传文件页面
2018/10/22 Javascript
如何从头实现一个node.js的koa框架
2019/06/17 Javascript
[38:21]2018DOTA2亚洲邀请赛3月30日 小组赛A组 LGD VS Newbee
2018/03/31 DOTA
[09:37]2018DOTA2国际邀请赛寻真——不懈追梦的Team Serenity
2018/08/13 DOTA
详解Python3.1版本带来的核心变化
2015/04/07 Python
Python复制文件操作实例详解
2015/11/10 Python
python机器学习理论与实战(六)支持向量机
2018/01/19 Python
Python实现的拉格朗日插值法示例
2019/01/08 Python
Python PyCharm如何进行断点调试
2019/07/05 Python
pandas的to_datetime时间转换使用及学习心得
2019/08/11 Python
python+OpenCV实现车牌号码识别
2019/11/08 Python
Python-openpyxl表格读取写入的案例详解
2020/11/02 Python
基于Html5实现的语音搜索功能
2019/05/13 HTML / CSS
英国最专业的健身器材供应商之一:Best Gym Equipment
2017/12/22 全球购物
NBA欧洲商店(西班牙):NBA Europe Store ES
2019/04/16 全球购物
装修致歉信
2014/01/15 职场文书
《观舞记》教学反思
2014/04/16 职场文书
战略合作意向书
2014/07/29 职场文书
邻里守望志愿服务活动方案
2014/08/15 职场文书
党的群众路线教育实践活动个人对照检查材料(企业)
2014/11/05 职场文书
表扬信范文
2015/05/04 职场文书
Redis三种集群模式详解
2021/10/05 Redis