通过python改变图片特定区域的颜色详解


Posted in Python onJuly 15, 2019

首先让我祭出一张数学王子高斯的照片,这位印在德国马克上的神人有多牛呢? 他是近代数学的奠基人之一,与牛顿, 阿基米德并称顶级三大数学家,随便找一个编程语言的数学库,里面一定有和他名字相关的一堆函数。

通过python改变图片特定区域的颜色详解

开始正文之前,让我们再来膜拜一下19岁的高斯如何用一把圆规和没有刻度的尺子画出正十七边形。

通过python改变图片特定区域的颜色详解

下面我就拿高斯这张肖像画作为示例如何用Python将他帽子的颜色换了。

计算机分析图片不可能像人类的肉眼一样进行观察,再用右脑进行思考,它能识别的只有数字,下面我们从计算机的角度来对图片做一个简单的认知。

机器的认知中任何一个图片都是由很多像素排列组成,每个像素点就是图片组成的最小原子,因此图片可以看作是一个二维数组,包含坐标和颜色。

其中坐标可以继续拆成一个二维数组分别是X轴和Y轴,而颜色用RGB来表示则可拆解为红绿蓝三维数组。

我先用python来几行简单代码把数学王子的照片转化为数组看看到底是什么内容。

通过python改变图片特定区域的颜色详解

看看打印结果的输出,这张图的像素有607行(宽度),474列(高度),也就是287718个像素组成了这张图片。我再用photoshop打开这张图片看看像素大小,完全匹配。

打印像素

通过python改变图片特定区域的颜色详解

核对像素

通过python改变图片特定区域的颜色详解

接下来再来几行代码把整张图片的矩阵打印出来看看,同时用photoshop框选一下高斯帽子的范围,大概是两个矩形的拼接,在此范围内我也挑几个点(帽子,皮肤,背景)打印出来看看。为何是两个矩形? 因为大神的眼珠也是黑色和帽子比较相似,所以绕道划取范围。

选取范围

通过python改变图片特定区域的颜色详解

采样打印

通过python改变图片特定区域的颜色详解

通过python改变图片特定区域的颜色详解

打印矩阵

通过python改变图片特定区域的颜色详解

简单分析一下规律,其实帽子,背景,皮肤的颜色色差还是比较明显的。为了让帽子从黑色变成红色就把RGB定为(200, 20, 20)先来两个两重循环把两个长方形拼接的范围都替换掉,重新调出图片看看效果,已经成功刷上红色了,接下来就要看如何更精准的上色。

通过python改变图片特定区域的颜色详解

通过python改变图片特定区域的颜色详解

接下来判断一下这个范围内的像素颜色哪些应该替换哪些应该保留。随便根据经验设置一下参数,看看效果再调整几次。

我选择的判断条件是RGB均小于45, 比较保守,因为画多了比较麻烦,画少了还可以修复。运行一下,果然按这个参数上色后覆盖不均匀,于是我加了个简单粗暴的颜色扩散方法,判断一下左右两边或者上下是否有红色,有则替换当前像素为红色。对比间距从大到小(10, 5, 2)修复了三次后效果就差不多了。

到此为止帽子的边缘还比较毛糙,颜色扩散的方式也比较粗暴,下一篇再研究如何用OpenCV的Canny Edge Detection勾画图案边缘,用Gaussian Blurring(看,高斯的名字又出现了)平滑处理交界处。

通过python改变图片特定区域的颜色详解

通过python改变图片特定区域的颜色详解

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python创建日历实例
Aug 21 Python
python实现模拟按键,自动翻页看u17漫画
Mar 17 Python
python 实现在Excel末尾增加新行
May 02 Python
matplotlib savefig 保存图片大小的实例
May 24 Python
python实现对求解最长回文子串的动态规划算法
Jun 02 Python
Python日期时间模块datetime详解与Python 日期时间的比较,计算实例代码
Sep 14 Python
python生成每日报表数据(Excel)并邮件发送的实例
Feb 03 Python
Linux上使用Python统计每天的键盘输入次数
Apr 17 Python
如何在sublime编辑器中安装python
May 20 Python
keras中的History对象用法
Jun 19 Python
解决python对齐错误的方法
Jul 16 Python
python3中for循环踩过的坑记录
Dec 14 Python
用Python+OpenCV对比图像质量的几种方法
Jul 15 #Python
python3实现斐波那契数列(4种方法)
Jul 15 #Python
为什么从Python 3.6开始字典有序并效率更高
Jul 15 #Python
django settings.py 配置文件及介绍
Jul 15 #Python
python项目对接钉钉SDK的实现
Jul 15 #Python
用Python识别人脸,人种等各种信息
Jul 15 #Python
django中账号密码验证登陆功能的实现方法
Jul 15 #Python
You might like
php使用GD实现颜色渐变实例
2015/06/02 PHP
php实现的简单中文验证码功能示例
2017/01/03 PHP
php生成微信红包数组的方法
2019/09/05 PHP
php设计模式之状态模式实例分析【星际争霸游戏案例】
2020/03/26 PHP
Code:findPosX 和 findPosY
2006/12/20 Javascript
javascript编程起步(第四课)
2007/01/10 Javascript
JS 文字符串转换unicode编码函数
2009/05/30 Javascript
利用onresize使得div可以随着屏幕大小而自适应的代码
2010/01/15 Javascript
IE6背景图片不缓存问题解决方案及图片使用策略多个方法小结
2012/05/14 Javascript
用jQuery获取IE9下拉框默认值问题探讨
2013/07/22 Javascript
Javascript玩转继承(三)
2014/05/08 Javascript
nodejs实现获取某宝商品分类
2015/05/28 NodeJs
javascript针对不确定函数的执行方法
2015/12/16 Javascript
Bootstrap学习笔记之css样式设计(1)
2016/06/07 Javascript
Easyui Tree获取当前选择节点的所有顶级父节点
2017/02/14 Javascript
Easyui使用Dialog行内按钮布局的实例
2017/07/27 Javascript
vue.js 嵌套循环、if判断、动态删除的实例
2018/03/07 Javascript
浅谈关于iview表单验证的问题
2018/09/29 Javascript
vue3.0中使用postcss-pxtorem的具体方法
2019/11/20 Javascript
Python中正则表达式的详细教程
2015/04/30 Python
python实现随机梯度下降(SGD)
2020/03/24 Python
Python实现迭代时使用索引的方法示例
2018/06/05 Python
Python通过VGG16模型实现图像风格转换操作详解
2020/01/16 Python
python 函数嵌套及多函数共同运行知识点讲解
2020/03/03 Python
python speech模块的使用方法
2020/09/09 Python
10个python爬虫入门实例(小结)
2020/11/01 Python
css3实现的多级渐变下拉菜单导航效果代码
2015/08/31 HTML / CSS
friso美素佳儿官方海外旗舰店:荷兰原产原罐
2017/07/03 全球购物
Desigual美国官方网站:西班牙服装品牌
2019/03/29 全球购物
Java模拟试题
2014/11/10 面试题
项目经理的岗位职责
2013/11/23 职场文书
自荐书4要点
2014/01/25 职场文书
学校课外活动总结
2014/05/08 职场文书
浅谈Redis中的RDB快照
2021/06/29 Redis
Java基于Dijkstra算法实现校园导游程序
2022/03/17 Java/Android
详解在SQLPlus中实现上下键翻查历史命令的功能
2022/03/18 SQL Server