python可以写什么视觉特效_Python实现视觉特效:一行命令给头像自动戴上口罩的案例...
Python实现视觉特效:一行命令给头像自动戴上口罩的案例
发布时间:2020-07-23 16:22:40
来源:亿速云
阅读:90
作者:清晨
小编给大家分享一下Python实现视觉特效:一行命令给头像自动戴上口罩的案例,希望大家阅读完这篇文章后大所收获,下面让我们一起去探讨吧!
Python 实现视觉特效:秒变超级赛亚人
face-mask的命令行工具,能够轻松的给图片中的人像戴上口罩,而且口罩的方向和大小还能自适
应人脸。
安装 face-mask
确保 Python 版本在 3.6 及以上pip install face-mask
使用 face-mask
直接指定图片路径即可为图片中的人像戴上口罩,并会生成一个新的图片(额外有 -with-mask 后缀):face-mask /path/to/face/picture
通过指定 --show 选项,还可以使用默认图片查看器打开新生成的图片:face-mask /path/to/face/picture --show
效果
给一个人戴上口罩
给多个人戴上口罩
给动漫人物戴上口罩
实现
思路
要想实现上面的效果,我们应该怎么做?不妨这么想:
首先是识别出人的鼻子(nose_bridge)和脸轮廓(chin)
通过脸轮廓确定出脸左点(chin_left_point)、脸底点(chin_bottom_point)和脸右点(chin_right_point)
由鼻子和脸底点确定口罩大小的高度、中心线
将口罩左右平均分为两个部分
调整左口罩大小,宽度为脸左点到中心线的距离
调整右口罩大小,宽度为脸右点到中心线的距离
合并左右口罩为新口罩
旋转新口罩,角度为中心线相对于 y 轴的旋转角
将新口罩放在原图适当位置
关于人脸识别,可以使用 face_recognition 库进行识别。
关于图像处理,可以使用 Pillow库进行处理。
代码
有了思路之后,实现就是件相对轻松的事情。不过对库的熟悉和图片的变换计算可能要花些时间。
详细的代码请阅读 face-mask[4]。这里仅说明下最核心的步骤。
人脸识别import face_recognition
face_image_np = face_recognition.load_image_file('/path/to/face/picture')
face_landmarks = face_recognition.face_landmarks(face_image_np)
借助 face_recognition 库可以轻松的识别出人像,最终得到的 face_landmarks 是一个列表,里面的每个 face_landmark 都表示一个人
像数据。
face_landmark 是一个字典,其中的键表示人像特征,值表示该特征的点的列表。比如:
键 nose_bridge 表示鼻梁
键 chin 表示脸颊
我们需要根据每个 face_landmark,给对应的头像戴上口罩。
获得鼻子和脸颊的特征点import numpy as np
nose_bridge = face_landmark['nose_bridge']
nose_point = nose_bridge[len(nose_bridge) * 1 // 4]
nose_v = np.array(nose_point)
chin = face_landmark['chin']
chin_len = len(chin)
chin_bottom_point = chin[chin_len // 2]
chin_bottom_v = np.array(chin_bottom_point)
chin_left_point = chin[chin_len // 8]
chin_right_point = chin[chin_len * 7 // 8]
通过上述代码,我们获得了:表示上鼻梁的一个点 nose_point
表示脸左点 chin_left_point
表示脸右点 chin_right_point
表示脸底点 chin_bottom_point
拆分、缩放和合并口罩from PIL import Image
_face_img = Image.fromarray(face_image_np)
_mask_img = Image.open('/path/to/mask/picture')
# split mask and resize
width = _mask_img.width
height = _mask_img.height
width_ratio = 1.2
new_height = int(np.linalg.norm(nose_v - chin_bottom_v))
# left
mask_left_img = _mask_img.crop((0, 0, width // 2, height))
mask_left_width = get_distance_from_point_to_line(chin_left_point, nose_point, chin_bottom_point)
mask_left_width = int(mask_left_width * width_ratio)
mask_left_img = mask_left_img.resize((mask_left_width, new_height))
# right
mask_right_img = _mask_img.crop((width // 2, 0, width, height))
mask_right_width = get_distance_from_point_to_line(chin_right_point, nose_point, chin_bottom_point)
mask_right_width = int(mask_right_width * width_ratio)
mask_right_img = mask_right_img.resize((mask_right_width, new_height))
# merge mask
size = (mask_left_img.width + mask_right_img.width, new_height)
mask_img = Image.new('RGBA', size)
mask_img.paste(mask_left_img, (0, 0), mask_left_img)
mask_img.paste(mask_right_img, (mask_left_img.width, 0), mask_right_img)
上述代码主要做了如下内容:
将口罩左右平均分为两个部分
调整左口罩大小,宽度为脸左点到中心线的距离 * 宽度系数 1.2
调整右口罩大小,宽度为脸右点到中心线的距离 * 宽度系数 1.2
合并左右口罩为新口罩
get_distance_from_point_to_line 用来获取一个点到一条线的距离,具体实现可看源代码。
width_ratio 是宽度系数,用来适当扩大口罩。原因我们是根据脸颊的宽度计算口罩的宽度,但口罩是待在耳朵上的,真实宽度应该要更宽。
旋转口罩、并放到原图适当位置# rotate mask
angle = np.arctan2(chin_bottom_point[1] - nose_point[1], chin_bottom_point[0] - nose_point[0])
rotated_mask_img = mask_img.rotate(angle, expand=True)
# calculate mask location
center_x = (nose_point[0] + chin_bottom_point[0]) // 2
center_y = (nose_point[1] + chin_bottom_point[1]) // 2
offset = mask_img.width // 2 - mask_left_img.width
radian = angle * np.pi / 180
box_x = center_x + int(offset * np.cos(radian)) - rotated_mask_img.width // 2
box_y = center_y + int(offset * np.sin(radian)) - rotated_mask_img.height // 2
# add mask
_face_img.paste(mask_img, (box_x, box_y), mask_img)
上述代码主要做了如下内容:
旋转新口罩,角度为中心线相对于 y 轴的旋转角计算口罩应该放置的坐标将新口罩放在原图的计算出的坐标下
最后就是将新图片保存到本地路径,代码不再展示。
看完了这篇文章,相信你对Python实现视觉特效:一行命令给头像自动戴上口罩的案例有了一定的了解,想了解更多相关知识,欢迎关注亿速云行业资讯频道,感谢各位的阅读!
python可以写什么视觉特效_Python实现视觉特效:一行命令给头像自动戴上口罩的案例...相关推荐
- python能写桌面程序吗_python能写桌面程序吗
其实Python/Java/PHP都不适合用来做桌面开发,Java还是有几个比较成熟的产品的,比如大名鼎鼎的Java集成开发环境IntelliJ IDEA.Eclipse就是用Java开发的,不过PH ...
- python抢票12306源码_Python突破12306最后一道防线,实现自动抢票(附源码)
一年一度的春运又来了,今年我自己写了个抢票脚本.使用Python+Splinter自动刷新抢票,可以成功抢到.(依赖自己的网络环境太厉害,还有机器的好坏) Splinter是一个使用Python开发的 ...
- 带口罩了吗 Python教你 一行命令给猎狐 F4 带口罩 检测是否带口罩
在疫情期间,大家出门都是需要带口罩的,因此,口罩对于大家来说再熟悉不过了,本文我们来做两个与口罩相关的事情. 相关文件 小伙伴们可以关注小编的Python源码.问题解答&学习交流群:73308 ...
- python if写在return 后面_python中return如何写
python中return的用法 1.return语句就是把执行结果返回到调用的地方,并把程序的控制权一起返回 程序运行到所遇到的第一个return即返回(退出def块),不会再运行第二个return ...
- python以写模式打开录入_Python的学习(六)—-文件和输入输出处理 | 学步园
Python中的文件和输入输出处理 1. 文件对象的概念 文件对象不仅可以用来访问普通的磁盘文件,还可以访问任何其他类型抽象层面上的文件. 例如实时地"打开一个URL"来读取Web ...
- python怎么写运维脚本_python运维脚本实例
file是一个类,使用file('file_name', 'r+')这种方式打开文件,返回一个file对象,以写模式打开文件不存在则会被创建.但是更推荐使用内置函数open()来打开一个文件 . 首先 ...
- python手写笔记图片初学_Python处理手写笔记
下载W3Cschool手机App,0基础随时随地学编程导语 利用Python实现手写笔记的压缩与增强. 至于起因大概是: 这个内容很有趣... --> 说了等于没说.T_T 相关文件 密码: 4 ...
- python编译器写代码如何换行_python怎么换行写代码
python怎么换行写代码? Windows换行符是'\r\n', Unix/Linux的换行符为'\n', Mac的换行符为'\r', 在python中,对换行符进行了统一处理,定义为'\n. 推荐 ...
- python手写数字识别教学_python实现基于SVM手写数字识别功能
本文实例为大家分享了SVM手写数字识别功能的具体代码,供大家参考,具体内容如下 1.SVM手写数字识别 识别步骤: (1)样本图像的准备. (2)图像尺寸标准化:将图像大小都标准化为8*8大小. (3 ...
最新文章
- Delphi下利用WinIo模拟鼠标键盘详解
- 第8期Datawhale组队学习计划
- R语言caret包构建机器学习回归模型(regression model)、使用DALEX包进行模型解释分析、特征重要度、偏依赖分析等
- ZendStudio导入一个已有的网站
- 揭秘Java网络爬虫程序原理
- .NET Core 3.0 中间件 Middleware
- Linux 2.6.39.1 Hello world 驱动总结
- MYSQL数据库优化的八种方式
- Python黑帽子--黑客与渗透测试编程之道
- 【论文笔记】变化检测1(SAR图像)
- DSPE-PEG-TH(AGYLLGHINLHHLAHL(Aib)HHIL) 磷脂(二硬脂酰基磷脂酰乙醇胺)-聚乙二醇-TH(AGYLLGHINLHHLAHL(Aib)HHIL)
- 首届广西网络安全技术大赛初赛通关攻略
- (Python语法篇)4.序列(3)字典
- 学习记录-- 用 Latex 修改文字/段落颜色 用于回复审稿意见。
- 96.(leaflet之家)leaflet态势标绘-进攻方向修改(燕尾)
- ***学习笔记教程七:密码恢复
- window证书管理
- Linux查看硬件信息以及驱动设备的命令
- 多项式计算(python)
- 配置Python镜像
热门文章
- lua table是否为空的判断
- 第三方短信平台服务提供商是什么?
- android 系统级闹铃,Android 设置系统闹铃和日历
- pada mysql
- 计算机在未来医学中的应用,【-通信传播论文:计算机技术在医学中的应用材料】...
- CSS —— 单行和多行文本实现省略号
- css盒心形的代码过程,如何使用CSS和D3实现用文字组成的心形动画效果(附代码)...
- 我是如何零基础开始能写爬虫的?
- 2022年6月语音合成(TTS)和语音识别(ASR)论文月报
- 二维点集求外轮廓Java_从二维点集重建平面形状-浅议凹包算法