OpenCV之将图像拼装成视频

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

       VideoWriter写入图像到视频时, 需要提供视频名, 格式, 码率, 帧的尺寸等参数,参数如下:

1
2
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,代码如下;

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
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那么繁琐。