基于Python和opencv实现抖音上墨镜和烟卷效果

基于Python和opencv实现抖音上墨镜和烟卷效果 一,项目简介 现今较火的抖音上有一个十分有趣的特效,其可以自动检测出人脸并且放置墨镜和烟卷,鉴于此

本文包含相关资料包-----> 点击直达获取<-------

基于Python和opencv实现抖音上墨镜和烟卷效果

一、项目简介

现今较火的抖音上有一个十分有趣的特效,其可以自动检测出人脸并且放置墨镜和烟卷,鉴于此,想自己实现动手实现以下该特效的制作。

二、工作环境

Python 3.6,opencv+Dlib,Windows操作系统,pycharm

三、流程

  • 从摄像头获取视频流,并转换为一帧一帧的图像,然后将图像信息传递给opencv这个工具库处理,返回灰度图像。

  • 程序启动后,根据监听器信息,使用一个while循环,不断的加载视频图像,然后返回给opencv工具呈现图像信息。

  • 创建一个键盘事件监听,按下"d"键,则开始执行面部匹配,并进行面具加载(这个过程是动态的,你可以随时移动)。

  • 面部匹配使用Dlib中的人脸检测算法来查看是否有人脸存在。如果有,它将为每个人脸创建一个结束位置,眼镜和烟卷会移动到那里结束。

  • 然后我们需要缩放和旋转我们的眼镜以适合每个人的脸。我们将使用从Dlib的68点模型返回的点集来找到眼睛和嘴巴的中心,并为它们之间的空间旋转。

  • 在我们实时获取眼镜和烟卷的最终位置后,眼镜和烟卷从屏幕顶部进入,开始匹配你的眼镜和嘴巴

  • 假如没有人脸,程序会直接返回你的视频信息,不会有面具移动的效果。默认一个周期是4秒钟。然后你可以通过"d"键再次检测。

  • 退出程序按下q键。

四、关键代码

  • 创建面具加载服务类DynamicStreamMaskService及其对应的初始化属性:

  • 读取摄像头视频流并转化为图象:

  • 实现人脸定位函数,及眼镜和烟卷的定位:

  • 接下来实现画图函数:

  • 创建启动函数start:

五、运行结果

运行后,首先会打开摄像头,然后按下键盘d键,就会看到墨镜和烟卷从屏幕上方出来,自动定位到眼睛和嘴巴。参考结果如下: 图片经过马赛克处理了。

注意

代码中需要调用 shape_predictor_68_face_landmarks.dat人脸库,需要下载,然后在代码调用处中指定路径即可。

参考文献

  • 基于Spring技术的大型视频网站后台上传系统的设计与实现(南京大学·徐悦轩)
  • 基于抖音兴趣点的推荐系统的设计与实现(南京大学·冯浩)
  • 移动视频中重点人物识别系统的设计与实现(西安电子科技大学·孙毅)
  • 基于J2EE的Web应用研究(河海大学·朱春江)
  • 基于安卓的图片社交应用的设计与实现(北京交通大学·高豆豆)
  • 基于Web的插件式可扩展视频直播系统的设计与实现(北京邮电大学·葛文博)
  • 基于安卓的图片社交应用的设计与实现(北京交通大学·高豆豆)
  • VSAR时尚电商平台商业计划书(华南理工大学·邓茂华)
  • 基于安卓的图片社交应用的设计与实现(北京交通大学·高豆豆)
  • 中视频创作服务平台的设计与实现(北京交通大学·王璐)
  • 基于安卓的图片社交应用的设计与实现(北京交通大学·高豆豆)
  • 基于React Native的英语视听应用的设计与实现(福州大学·刘草)
  • 基于Hadoop视频处理与检索系统(复旦大学·温建娇)
  • 基于Vue.js的可编程视频平台的设计和实现(华中科技大学·施璇)
  • 基于内容推荐的视频服务平台的设计与实现(北京交通大学·张雨萌)

本文内容包括但不限于文字、数据、图表及超链接等)均来源于该信息及资料的相关主题。发布者:毕业设计工坊 ,原文地址:https://bishedaima.com/yuanma/35159.html

相关推荐

发表回复

登录后才能评论