我需要从视频文件中读取帧并根据这些帧创建新视频。然后,我从新视频中读取帧,我需要这些帧与从原始视频中读取的帧相同。
这就是我所做的(例如,我只用一帧就完成了)-
从视频中读取框架:
vidcap = cv2.VideoCapture('video_name.mp4')
success,orig_frame = vidcap.read()
从此框架中写入新视频:
size = (1920,1080)
vidWriter = cv2.VideoWriter('new_video.mp4', cv2.VideoWriter_fourcc(*'MP4V'), 25, size)
vidWriter.write(orig_frame)
vidWriter.release()
从new_video中读取框架:
vidcap = cv2.VideoCapture('new_video.mp4')
success,new_frame = vidcap.read()
将orig_frame与new_frame进行比较表明它们并不相同。
orig_frame:
新框架:
如何从原始视频和新视频中获得相同的帧?
答案 0 :(得分:1)
由于MP4使用有损编码来写入视频数据,因此这是不可能的。您将无法在两个视频之间获得精确的逐像素匹配。
但是,如果要获得完全匹配的内容,则需要使用无损编解码器。
这取决于您所使用的系统来确定支持哪些编解码器,但是长远的目的是使用PNG编码将视频帧写入文件。
尝试:
size = (1920,1080)
vidWriter = cv2.VideoWriter('new_video.avi', cv2.VideoWriter_fourcc(*'png '), 25, size)
vidWriter.write(orig_frame)
vidWriter.release()
如果上述方法不令人满意,请尝试咨询:Lossless compression for video in opencv
如果我可以提出建议,我将不使用OpenCV进行此操作,因为您无法控制输出比特率,颜色分布等。使用FFMPEG可以更好地控制它。请在此处查看有关如何使用无损压缩复制视频的信息:Lossless ffmpeg conversion/encoding