OpenCV之将图像拼装成视频

       在上一篇博文中,http://blog.csdn.net/enchanted_zhouh/article/details/74289333 ,我们讲了怎样从一个视频中读取每一帧图像,在本文中,当我们对一个视频中的每一帧图像都进行了分析之后,想拼装成一个处理之后的视频以供展示分析成果,此时我们需要用到视频写入流VideoWriter这个方法。
       VideoWriter写入图像到视频时, 需要提供视频名, 格式, 码率, 帧的尺寸等参数,参数如下:

VideoWriter(...)
    VideoWriter([filename, fourcc, fps, frameSize[, isColor]]) -> <VideoWriter object>

       filename:视频文件名和路径,在这里必须要为VideoWriter类的构造函数指定视频文件名,这个文件名对应的文件若不存在,则会新建视频文件;若存在,则原同名文件会被覆盖。
       fourcc:视频编解码类型,由四个字节组成,编解码器的可用性根据系统不同而不同,下面是一些常用选项:
                     cv2.VideoWriter_force(‘I’, ‘4’, ‘2’, ‘0’):一个未压缩的YUV颜色编码,是4:2:0色度子采样。这种编码有很好的兼容性,但会产生较大文件,文件扩展名为.avi。
                     cv2.VideoWriter_force(‘P’, ‘I’, ‘M’, ‘1’):MPEG-1编码类型,文件扩展名为.avi。
                     cv2.VideoWriter_force(‘X’, ‘V’, ‘I’, ‘D’):MPEG-4编码类型,如果希望得到的视频大小为平均值,推荐使用此选项,文件扩展名为.avi。
                     cv2.VideoWriter_force(‘T’, ‘H’, ‘E’, ‘O’):Ogg Vorbis,文件扩展名为.ogv。
                     cv2.VideoWriter_force(‘F’, ‘L’, ‘V’, ‘1’):Flash视频,文件扩展名应为.flv。
       fps:帧率。
       frameSize:每一帧的宽和高,帧的宽和高必须和原图像大小一致。
       isColor:是否为彩色视频。

       OpenCV版本为3.2.0,代码如下;

import cv2
import glob

#根据自己的实际情况更改目录。
#要转换的图片的保存地址,按顺序排好,后面会一张一张按顺序读取。
convert_image_path = 'E:/project/pictures'

#帧率(fps),尺寸(size),此处设置的fps为24,size为图片的大小,本文转换的图片大小为400×1080,
#即宽为400,高为1080,要根据自己的情况修改图片大小。
fps = 24
size = (400,1080)

videoWriter = cv2.VideoWriter('E:/project/videos/TestVideo.avi',cv2.VideoWriter_fourcc('I','4','2','0'),
                              fps,size)

for img in glob.glob(convert_image_path + "/*.jpg") :
    read_img = cv2.imread(img)
    videoWriter.write(read_img)
videoWriter.release()

       最后记得videoWriter.release()释放写入流,否则在IDE打开的情况下视频打不开,因为流没有关闭,此时只能关闭IDE才能打开视频文件。release之后视频文件可以直接打开,不用关闭IDE那么繁琐。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值