OpenCV-Python实现人脸美白算法的实例


Posted in Python onJune 11, 2021

人脸美白原理

人脸美白原理说透了,就是一种图像的颜色空间处理,所以我们需要通过颜色空间进行设计。

不过,我们先来参考以下PS对于图像美白的处理步骤:

  • 首先,新建一个图层,将这个图层设置为白色
  • 接着,将白色图层与原本图像进行alpha通道的颜色混合,这样就可以使图像整体变白。

通过PS的操作,我们大致可以知道需要创建一个与原图同等大小维度的图像,然后全部赋值为白色,然后通过图像图像加权和将两个图像叠加即可。

不过,这里明显存在很多问题,在PS中,我们虽然创建了全白色的图层,但是我们可以剪裁或者使用画笔工具只让白色叠加倒人物身上。而程序中,我们这么做会导致整个图像偏白,效果非常不理想。

那么,我们就需要考虑一个新的思路来实现人脸美白效果。

根据论文“A Two-Stage Contrast Enhancement Algorithm for Digital Images”,采用映射表,使原图在色阶上有所增强,并在图像两端亮度相对减弱,中间增强,则会产生不错的美白效果,又能使图像白的更自然。

这里,我们提供一个美白映射表Color_list:

Color_list = [
	1, 2, 4, 6, 8, 10, 12, 14, 16, 18, 20, 22, 24, 26, 28, 30, 31, 33, 35, 37, 39,
	41, 43, 44, 46, 48, 50, 52, 53, 55, 57, 59, 60, 62, 64, 66, 67, 69, 71, 73, 74,
	76, 78, 79, 81, 83, 84, 86, 87, 89, 91, 92, 94, 95, 97, 99, 100, 102, 103, 105,
	106, 108, 109, 111, 112, 114, 115, 117, 118, 120, 121, 123, 124, 126, 127, 128,
	130, 131, 133, 134, 135, 137, 138, 139, 141, 142, 143, 145, 146, 147, 149, 150,
	151, 153, 154, 155, 156, 158, 159, 160, 161, 162, 164, 165, 166, 167, 168, 170,
	171, 172, 173, 174, 175, 176, 178, 179, 180, 181, 182, 183, 184, 185, 186, 187,
	188, 189, 190, 191, 192, 193, 194, 195, 196, 197, 198, 199, 200, 201, 202, 203,
	204, 205, 205, 206, 207, 208, 209, 210, 211, 211, 212, 213, 214, 215, 215, 216,
	217, 218, 219, 219, 220, 221, 222, 222, 223, 224, 224, 225, 226, 226, 227, 228,
	228, 229, 230, 230, 231, 232, 232, 233, 233, 234, 235, 235, 236, 236, 237, 237,
	238, 238, 239, 239, 240, 240, 241, 241, 242, 242, 243, 243, 244, 244, 244, 245,
	245, 246, 246, 246, 247, 247, 248, 248, 248, 249, 249, 249, 250, 250, 250, 250,
	251, 251, 251, 251, 252, 252, 252, 252, 253, 253, 253, 253, 253, 254, 254, 254,
	254, 254, 254, 254, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
	255, 255, 255, 256]

实现人脸美白

既然人脸美白的原理,以及美白的颜色映射表都给到了你。下面,我们就可以实现人脸美白效果,具体代码如下所示:

def face_whitening(fileName):
    img = cv2.imread(fileName)
    img = cv2.bilateralFilter(img, 19, 75, 75)
    height, width, n = img.shape
    img2 = img.copy()
    for i in range(height):
        for j in range(width):
            b = img2[i, j, 0]
            g = img2[i, j, 1]
            r = img2[i, j, 2]
            img2[i, j, 0] = Color_list[b]
            img2[i, j, 1] = Color_list[g]
            img2[i, j, 2] = Color_list[r]
    cv2.imwrite("59_1.jpg",img2)

    image = Image.open("59_1.jpg")
    # 锐度调节
    enh_img = ImageEnhance.Sharpness(image)
    image_sharped = enh_img.enhance(1.2)
    # 颜色均衡调节
    con_img = ImageEnhance.Contrast(image_sharped)
    image_con = con_img.enhance(1.2)
    image_con.save("59_2.jpg")

    img1 = cv2.imread("58.jpg")
    img2 = cv2.imread("59_2.jpg")
    cv2.imshow("1", img1)
    cv2.imshow("2", img2)
    cv2.waitKey()
    cv2.destroyAllWindows()


if __name__ == "__main__":
    face_whitening("58.jpg")

运行之后,效果如下:

OpenCV-Python实现人脸美白算法的实例

到此这篇关于OpenCV-Python实现人脸美白算法的实例的文章就介绍到这了,更多相关OpenCV人脸美白 内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
pymssql数据库操作MSSQL2005实例分析
May 25 Python
利用django如何解析用户上传的excel文件
Jul 24 Python
Python定时器实例代码
Nov 01 Python
基于Django URL传参 FORM表单传数据 get post的用法实例
May 28 Python
Python参数类型以及常见的坑详解
Jul 08 Python
python实现列表中最大最小值输出的示例
Jul 09 Python
Python解析json代码实例解析
Nov 25 Python
python在不同条件下的输入与输出
Feb 13 Python
Python参数传递实现过程及原理详解
May 14 Python
Python面向对象多态实现原理及代码实例
Sep 16 Python
OpenCV-Python实现怀旧滤镜与连环画滤镜
Jun 09 Python
python脚本框架webpy模板赋值实现
Nov 20 Python
Matplotlib可视化之添加让统计图变得简单易懂的注释
教你用Python matplotlib库制作简单的动画
PyQt5实现多张图片显示并滚动
pyqt5蒙版遮罩mask,setmask的使用
详解Python描述符的工作原理
用Python爬取各大高校并可视化帮弟弟选大学,弟弟直呼牛X
用python修改excel表某一列内容的操作方法
You might like
关于PHP中Object对象的笔记分享
2011/06/28 PHP
php仿QQ验证码的实例分析
2013/07/01 PHP
php实现将二维关联数组转换成字符串的方法详解
2017/07/31 PHP
php单元测试phpunit入门实例教程
2017/11/17 PHP
js 匿名调用实现代码
2009/06/19 Javascript
调试Javascript代码(浏览器F12及VS中debugger关键字)
2013/01/25 Javascript
页面载入结束自动调用js函数示例
2013/09/23 Javascript
Ajax提交与传统表单提交的区别说明
2014/02/07 Javascript
一个网页标题title的闪动提示效果实现思路
2014/03/22 Javascript
JavaScript使用HTML5的window.postMessage实现跨域通信例子
2014/04/11 Javascript
深入理解JavaScript中的对象
2015/06/04 Javascript
使用JQuery FancyBox插件实现图片展示特效
2015/11/16 Javascript
jQuery Ajax传值到Servlet出现乱码问题的解决方法
2016/10/09 Javascript
VUE中v-model和v-for指令详解
2017/06/23 Javascript
Vue2.0点击切换类名改变样式的方法
2018/08/22 Javascript
vue2 v-model/v-text 中使用过滤器的方法示例
2019/05/09 Javascript
javascript防抖函数debounce详解
2019/06/11 Javascript
Vue拖拽组件列表实现动态页面配置功能
2019/06/17 Javascript
vue页面切换项目实现转场动画的方法
2019/11/12 Javascript
微信小程序如何实现精确的日期时间选择器
2020/01/21 Javascript
详解element上传组件before-remove钩子问题解决
2020/04/08 Javascript
Python数据类型详解(三)元祖:tuple
2016/05/08 Python
解决Python中字符串和数字拼接报错的方法
2016/10/23 Python
Python数据结构与算法之图的最短路径(Dijkstra算法)完整实例
2017/12/12 Python
python生成以及打开json、csv和txt文件的实例
2018/11/16 Python
python3读取图片并灰度化图片的四种方法(OpenCV、PIL.Image、TensorFlow方法)总结
2019/07/04 Python
python 实现return返回多个值
2019/11/19 Python
python实现图片横向和纵向拼接
2020/03/05 Python
CSS3实现滚动条动画效果代码分享
2016/08/03 HTML / CSS
HTML5 SEO优化的一些建议
2020/08/27 HTML / CSS
国际鲜花速递专家:Floraqueen
2016/11/24 全球购物
Nike德国官网:Nike.com (DE)
2018/11/13 全球购物
Aquatalia官网:意大利著名鞋履品牌
2019/09/26 全球购物
Expedia瑞典官网:预订度假屋、酒店、汽车租赁、机票等
2021/01/23 全球购物
校园歌手大赛策划书
2014/01/17 职场文书
Python实现简繁体转换
2021/06/07 Python