在上一篇博文中,http://blog.csdn.net/enchanted_zhouh/article/details/74289333 ,我们讲了怎样从一个视频中读取每一帧图像,在本文中,当我们对一个视频中的每一帧图像都进行了分析之后,想拼装成一个处理之后的视频以供展示分析成果,此时我们需要用到视频写入流VideoWriter这个方法。
VideoWriter写入图像到视频时, 需要提供视频名, 格式, 码率, 帧的尺寸等参数,参数如下:
1 | VideoWriter(...) |
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 | import cv2 |
最后记得videoWriter.release()释放写入流,否则在IDE打开的情况下视频打不开,因为流没有关闭,此时只能关闭IDE才能打开视频文件。release之后视频文件可以直接打开,不用关闭IDE那么繁琐。