读取视屏文件的原理和读取图片的原理是一样的。在到达视屏末尾之前,通过VideoCapture类来调用read()函数来获取新的帧,每一帧是一幅基于BGR格式的图形。。
然后将一幅图传递给VideoWriter类的write()函数,write()函数会将这幅图加到VideoWriter类所指向的文件中。 下面是一个例子:
import cv2
videoCapture = cv2.VideoCapture('video.avi')#获得视屏得格式
fps = videoCapture.get(cv2.CAP_PROP_FPS)
size = (int(videoCapture.get(cv2.CAP_PROP_FRAME_WIDTH)),
int(videoCapture.get(cv2.CAP_PROP_FRAME_COUNT)))#获得码率及尺寸
videoWrite = cv2.VideoWriter('video2.avi',cv2.VideoWriter_fourcc('I','4','2','0'),fps,size)
#指定写视屏得格式:YUV颜色编码
#读第一帧
success,frame = videoCapture.read()
while success:#在到达视屏末尾之前
cv2.imshow('video2.avi',frame)#显示
cv2.waitKey(0)#延迟
videoWrite.write(frame)#写视屏
success,frame = videoCapture.read()#读取下一帧
要注意:
1.要为VideoWriter类的构造函数指定视屏文件名
2.必须视屏编码器
常用的视屏编码器:
cv2.VideoWriter_fourcc(‘I’,’4’,’2’,’0’):未压缩的YUV颜色变,这种编码有很好的兼容性,文件拓展名.avi
cv2.VideoWriter_fourcc(‘P’,’I’,’M’,’1’):MPEG-1编码类型,文件拓展名.avi
cv2.VideoWriter_fourcc(‘X’,’V’,’I’,’D’):MPEG-4编码类型,如果希望得到的视频大小为平均值,推荐此选项,文件拓展名.avi
cv2.VideoWriter_fourcc(‘T’,’H’,’E’,’O’):该选项是Ogg Vorbis,文件拓展名.ogv
cv2.VideoWriter_fourcc(‘F’,’L’,’V’,’1’):该选项是一个Flash视频,文件拓展名.flv