基于Python实现视频的人脸融合功能


Posted in Python onJune 12, 2020

基于Python实现视频的人脸融合功能

图片提取

为了方便技术展示,我们选取素材为演员杨紫的一段演讲视频,用例仅为技术交流演示使用,不针对任何指定人。

为达到我们AI换脸的目的,我们首先需要将这段视频逐帧提取成照片

def vedio_2_pic(self,file,save_path):
 """
 逐帧取照片
 file:视频的位置
 save_path:保存路径
 """
 # 读取视频
 video = cv2.VideoCapture(file)
 # 获取视频帧率
 fps = video.get(cv2.CAP_PROP_FPS)
 # 获取画面大小
 width = int(video.get(cv2.CAP_PROP_FRAME_WIDTH))
 height = int(video.get(cv2.CAP_PROP_FRAME_HEIGHT))
 size = (width, height)
 frame_num = str(video.get(7))
 ret, frame = video.read()
 num =1
 while True:
  ret, frame = video.read()
  if ret !=True:
  break
  cv2.imwrite(save_path + str(num) + '.jpg', frame)
  num +=1
 video.release()
 return fps, size,frame_num

脸部融合

上一环节我们已对视频进行了图片提取,我希望演员杨紫可以有杨幂一样的眼睛,长得更像杨幂一点。那么"目标选定人"就是杨幂了。

因为视频可能会有镜头切换,对焦目标可能是观众或者其他人,所以在脸部融合前,需要判断要转换的图片中是否有杨紫,如果有大于0.85的概率确定是杨紫,我们进行脸部融合,如果小于等于0.85概率我们就不进行脸部融合,下面进行脸部融合。

基于Python实现视频的人脸融合功能

核心代码

for i in range(frame_num):
 image2="""/Users/***/face_ztl/picture/%d.jpg"""%(i)
 content = video_make.img_compare(image1,image2)
 try:
 if content >0.85:
  print('-----%d-----'%(i))
  video_make.merge_face(image2,object_image,merge_rate=100)
 else:
  print(0)
  img = cv2.imread(image2)
  img_path = image2.replace('picture','picture_new')
  cv2.imwrite(img_path, img)
 except:
 pass
 print('第%d张出现了问题'%(i))

提取音频

为了合成后的视频有声音,我们将视频中的音频进行提取并保存下来,代码如下:

def getMusic(self,video_name,save_path):
 """
 获取指定视频的音频
 video_name:视频路径
 save_path:音频保存路径
 举例
 save_path='/Users/***/vedio/1.wav' 
 """
 # 读取视频文件
 video = VideoFileClip(video_name)
 # 返回音频
 audio = video.audio
 audio.write_audiofile(save_path)

合成视频

至此我们得到了音频、融合后的图片,接下来就是最后一步合成视频了,代码如下:

"""
 图片转视频
 save_path:视频保存路径
 """
 # 写入视频
 fourcc = cv2.VideoWriter_fourcc(*'mp4v')
 video = cv2.VideoWriter(save_path, fourcc, fps, size)

 # 排序目的
 for item in range(int(frame_num)):
  path = pic_path +str(item) + '.jpg'
  if os.path.exists(path):
  # 读取原图像
  img = cv2.imread(path)
  # 写入视频
  video.write(img)
 video.release()

总结

到此这篇关于基于Python实现视频的人脸融合功能的文章就介绍到这了,更多相关Python实现视频的人脸融合内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
python使用ctypes模块调用windowsapi获取系统版本示例
Apr 17 Python
python中的列表推导浅析
Apr 26 Python
win7 下搭建sublime的python开发环境的配置方法
Jun 18 Python
Python虚拟环境Virtualenv使用教程
May 18 Python
Python读写/追加excel文件Demo分享
May 03 Python
树莓派与PC端在局域网内运用python实现即时通讯
Jun 22 Python
Python TCP通信客户端服务端代码实例
Nov 21 Python
Python使用gluon/mxnet模块实现的mnist手写数字识别功能完整示例
Dec 18 Python
Python requests模块cookie实例解析
Apr 14 Python
基于python实现操作redis及消息队列
Aug 27 Python
Python测试框架pytest高阶用法全面详解
Jun 01 Python
Django框架中模型的用法
Jun 10 Python
使用Keras实现简单线性回归模型操作
Jun 12 #Python
Python实现Keras搭建神经网络训练分类模型教程
Jun 12 #Python
简单了解Python变量作用域正确使用方法
Jun 12 #Python
keras 读取多标签图像数据方式
Jun 12 #Python
Python数据可视化图实现过程详解
Jun 12 #Python
浅谈cv2.imread()和keras.preprocessing中的image.load_img()区别
Jun 12 #Python
升级keras解决load_weights()中的未定义skip_mismatch关键字问题
Jun 12 #Python
You might like
虚拟主机中对PHP的特殊设置
2006/10/09 PHP
php+mysql实现用户注册登陆的方法
2015/01/03 PHP
php文件上传 你真的掌握了吗
2016/11/28 PHP
PHP实现浏览器中直接输出图片的方法示例
2018/03/14 PHP
线路分流自动跳转代码;希望对大家有用!
2006/12/02 Javascript
RGB颜色值转HTML十六进制(HEX)代码的JS函数
2009/04/25 Javascript
jquery动画2.元素坐标动画效果(创建一个图片走廊)
2012/08/24 Javascript
关于Javascript作用域链的八点总结
2013/12/06 Javascript
VS2008中使用JavaScript调用WebServices
2014/12/18 Javascript
深入浅出分析javaScript中this用法
2015/05/09 Javascript
基于jQuery实现的菜单切换效果
2015/10/16 Javascript
基于JavaScript实现添加到购物车效果附源码下载
2016/08/22 Javascript
jq实现左滑显示删除按钮,点击删除实现删除数据功能(推荐)
2016/08/23 Javascript
jQuery实现鼠标滑过图片移动特效
2016/12/08 Javascript
js获取元素的偏移量offset简单方法(必看)
2017/07/05 Javascript
es6+angular1.X+webpack 实现按路由功能打包项目的示例
2017/08/16 Javascript
纯JavaScript实现实时反馈系统时间
2017/10/26 Javascript
vue项目实现设置根据路由高亮对应的菜单项操作
2020/08/06 Javascript
[51:17]Mski vs VGJ.S Supermajor小组赛C组 BO3 第三场 6.3
2018/06/04 DOTA
python比较两个列表大小的方法
2015/07/11 Python
详解python中xlrd包的安装与处理Excel表格
2016/12/16 Python
Atom的python插件和常用插件说明
2018/07/08 Python
Python编程图形库之Pillow使用方法讲解
2018/12/28 Python
让你Python到很爽的加速递归函数的装饰器
2019/05/26 Python
Django组件content-type使用方法详解
2019/07/19 Python
python扫描线填充算法详解
2020/02/19 Python
使用 prometheus python 库编写自定义指标的方法(完整代码)
2020/06/29 Python
html5.2 dialog简介详解
2018/02/27 HTML / CSS
材料成型专业个人求职信范文
2013/09/25 职场文书
迎国庆演讲稿
2014/09/15 职场文书
党的群众路线教育实践活动个人整改方案
2014/09/21 职场文书
学生抄作业检讨书(2篇)
2014/10/17 职场文书
先进单位事迹材料
2014/12/25 职场文书
学习计划是什么
2019/04/30 职场文书
只用20行Python代码实现屏幕录制功能
2021/06/02 Python
改造DE1103三步曲
2022/04/07 无线电