为了方便,我们全都使用pip安装:

pip install pillow

pip install opencv-python

pip install moviepy

# 安装paddlepaddle

python -m pip install paddlepaddle -i https://mirror.baidu.com/pypi/simple

# 安装paddlehub

pip install -i https://mirror.baidu.com/pypi/simple paddlehub

代码实现

我们先看看导入外汇返佣的一些模块:

import cv2

import math

import numpy as np

from PIL import Image

import paddlehub as hub

from moviepy.editor import *

我们按照上面的步骤,一步一步来。

逐帧提取图像

这就需要使用到我们的opencv了,具体代码如下:

def getFrame(video_name, save_path):

"""

传入视频名称,将图像帧保存到save_path下

"""

# 读取视频

video = cv2.VideoCapture(video_name)

# 获取视频帧率

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))

name = int(math.pow(10, len(frame_num)))

ret, frame = video.read()

while ret:

cv2.imwrite(save_path + str(name) + '.jpg', frame)

ret, frame = video.read()

name += 1

video.release()

return fps, size

批量抠图

批量抠图需要使用到我们的paddhub模型库,而抠图的实现也只需要几行代码:

def getHumanseg(frames):

"""

对frames路径下所以图片进行抠图

"""

# 加载模型库

humanseg = hub.Module(name='deeplabv3p_xception65_humanseg')

# 遍历路径下文件

files = [frames + i for i in os.listdir(frames)]

# 抠图

humanseg.segmentation(data={'image': files})

我们调用该方法后会在目录下生成humanseg_output目录,抠好的图像就在里面。

合成图像(影分身)

这里需要使用到我们的Pillow模块,该模块中提供了图像粘贴的函数:

def setImageBg(humanseg, bg_im):

"""

将抠好的图和背景图片合并

:param humanseg:

:param bg_im:

:return:

"""

# 读取透明图片

im = Image.open(humanseg)

# 分离色道

r, g, b, a = im.split()

# 在图片右边粘贴一个人物分身

bg_im.paste(im, (bg_im.size[0]//3, 0), mask=a)

# 在图片左边粘贴一个人物分身

bg_im.paste(im, (-bg_im.size[0]//3, 0), mask=a)

# 将图形转换成opencv能正常读取的类型,并返回

return np.array(bg_im.convert('RGB'))[:, :, ::-1]

写入视频

写入视频的操作同样是OpenCV来实现的:

def writeVideo(humanseg_path, frames, fps, size):

"""

传入抠好的人像,和原图像,以及原视频帧率,大小,写入新视频

"""

# 写入视频

fourcc = cv2.VideoWriter_fourcc(*'mp4v')

out = cv2.VideoWriter('green.mp4', fourcc, fps, size)

# 将每一帧设置背景

humanseg = [humanseg_path + i for i in os.listdir(humanseg_path)]

frames = [frames + i for i in os.listdir(frames)]

for i in range(humanseg.__len__()):

# 读取原图像

bg_im = Image.open(frames[i])

# 设置分身

im_array = setImageBg(humanseg[i], bg_im)

# 写入视频

out.write(im_array)

out.release()

混流

我们混流的操作就是先获取音频,然后再混流,而音频我们只需要读取原视频的音频即可:

def getMusic(video_name):

"""

获取指定视频的音频

"""

# 读取视频文件

video = VideoFileClip(video_name)

# 返回音频

return video.audio

其中VideoFileClip是moviepy中的一个视频处理的类。下面我们来添加音乐:

def addMusic(video_name, audio):

"""实现混流,给video_name添加音频"""

# 读取视频

video = VideoFileClip(video_name)

# 设置视频的音频

video = video.set_audio(audio)

# 保存新的视频文件

video.write_videofile(output_video)

output_video是我们自己定义的一个存放文件保存路径的变量,需要注意,该全路径(路径+名称)不能和原视频相同。

实现特效

也就是将整个流程整合到一起:

def changeVideoScene(video_name):

"""

:param video_name: 视频的文件

:param bgname: 背景图片

:return:

"""

# 读取视频中每一帧画面

fps, size = getFrame(video_name, frames)

# 批量抠图

getHumanseg(frames)

# 将画面一帧帧写入视频

writeVideo(humanseg_path, frames, fps, size)

# 混流

addMusic('green.mp4', getMusic(video_name))

在上面有些变量我们还没有定义,我们在main函数中定义一下:

if __name__ == '__main__':

# 当前项目根目录

BASE_DIR = os.path.abspath(os.path.join(os.path.dirname(__file__), "."))

# 每一帧画面保存的地址

frames = BASE_DIR + '\\frames\\'

# 抠好的图片位置

humanseg_path = BASE_DIR + '\\humanseg_output\\'

# 最终视频的保存路径

output_video = BASE_DIR + '\\result.mp4'

# 创建文件夹

if not os.path.exists(frames):

os.makedirs(frames)

if not os.path.exists(background_path):

os.makedirs(background_path)

# 给视频添加特效

changeVideoScene('jntm.mp4')

标签:特效,name,Python,im,电影,video,frames,path,humanseg

来源: https://www.cnblogs.com/benming/p/12760394.html

python 视频 特效,Python实现高级电影特效相关推荐

  1. 初识python 视频_#python day02 初识python 学习视频来源于 太白金星

    #python day02 初识python 学习视频来源于 太白金星 ''' 知识点:安装PyCharm''' # 设置鼠标条件字体大小:file ->settings # 搜索mouse E ...

  2. python视频下载-python动态视频下载器的实现方法

    这里向大家分享一下python爬虫的一些应用,主要是用爬虫配合简单的GUI界面实现视频,音乐和小说的下载器.今天就先介绍如何实现一个动态视频下载器. 爬取电影天堂视频 首先介绍的是python爬取电影 ...

  3. python视频下载-Python实现视频下载功能

    最近一两年短视频业务风生水起,各个视频网站都有各自特色的短视频内容.如果有这样一个程序,可以把各大视频网站的热门用户最新发布的视频都下载下来,不仅方便自己观看,还可以将没有版权的视频发布在个人社交网站 ...

  4. python视频操作——python实现读取和保存视频

    python读取和保存视频 内容来自博客+博客~ 读取视频 用cv2库的好处是返回的就是arrary,不用转换,但这种方法是从头读到尾 利用cv2库读取视频,代码实现如下: import cv2cap ...

  5. python视频操作——python实现将图片合成为视频

    python 将图片合成视频 内容来自博客~ 代码如下: import os import cv2# 要被合成的多张图片所在文件夹 # 路径分隔符最好使用"/",而不是" ...

  6. python视频操作——python实现将视频分解为图片序列

    python将视频分解为图片序列 内容参考自博客~ 详细实现代码如下: import cv2# 读取视频,方法是来自cv2库的VideoCapture cap = cv2.VideoCapture(& ...

  7. 笔记本电脑下载python视频-学Python买什么笔记本电脑?

    学习Python一定要使用类Unix环境,因为Python是开源生态,很多库在类Unix环境下运行很好,如果在Windows上,有时候安装就很麻烦,特别是带c/c++编译的原生库(动态链接库)的,有时 ...

  8. 中谷教育python视频_3.Python 中谷教育python视频教程零基础自学百度云资源下载

    01-走进python 02-开始编程吧 03-变量 04-运算符表达式 05-数据类型数字-字符串 06-元组 07列表 08-字典 09-流程控制-if-else 10-流程控制-逻辑符 11-流 ...

  9. python 制作影视动画、电影特效工具

    一直觉得电影特效,动画制作这些都很什么,在google上搜索了下python开发电影特效的内容,发现了几个不错的软件,都支持python脚本开发. Houdini  Houdini (电影特效魔术师) ...

  10. python 视频滤镜_Python实现PS滤镜功能之波浪特效示例

    本文实例讲述了Python实现PS滤镜功能之波浪特效.分享给大家供大家参考,具体如下: 这里用 Python 实现 PS 滤镜的波浪特效,具体效果可以参考附录说明 import numpy as np ...

最新文章

  1. 如何在CentOS 7中禁止IPv6
  2. java 取出集合前两个数据库_【Java】获取两个List中不同的数据(效率非常不错)-Go语言中文社区...
  3. 22.类对象和类指针
  4. ubuntu-10.04硬盘安装挫折略记
  5. 清华90后博士后26岁已在《科学》发文6篇
  6. 或许是因为本科不是学cs的HTML5原因
  7. 机器学习实战3-sklearn使用下载MNIST数据集进行分类项目
  8. 计算机组成原理4(程序查询方式、程序中断方式、DMA方式及其I/O接口电路)
  9. 关于performSelector调用和直接调用区别
  10. 整合Solr到Tomcat服务器,并配置IK分词
  11. 西门子S7-1200PLC脉冲控制伺服程序案例 此程序是关于西门子1200PLC以PTO脉冲方式控制伺服电机,步进电机的功能块程序
  12. 电商数据应用体系建设总结(二)—— 数据应用层架构介绍和规范总结
  13. (转载)html在浏览器中的差异
  14. vue框架对接手机app
  15. 一部手机最长能用几年?
  16. 2022年信息安全从业者书单推荐(2022.2.20更新)
  17. 布丰投针实验 MATLAB仿真 以及报告
  18. 地网导通测试仪_江西地网接地导通测试仪特点
  19. Android 9.0 flash播放器播放swf源码讲解
  20. 移动端vConsole查看控制台信息

热门文章

  1. 链表:头插法与尾插法(简易图解和代码)
  2. 单片机定时器程序c语言,单片机定时器程序
  3. matlab高通滤波器除噪声,基于MATLAB的FIR滤波器的设计及应用(信号去噪).doc
  4. 为什么华为a1路由器网速变慢_华为a1路由器wifi经常掉线怎么办
  5. 华为路由器接学校校园网,LOS一直亮红灯解决办法。
  6. python--基本操作
  7. Windows提示:您的许可证即将过期
  8. 如何从Excel中的另一个单元格引用格式和值?
  9. excel中单元格的引用方法
  10. 陀螺仪传感器的简单了解