前言
MP4文件由若干称为Atom(或称为box)的数据对象组成,每个Atom的起首为四个字节的数据长度(Big Endian)和四个字节的类型标识,数据长度和类型标志都可以扩展。Atom可以嵌套,即其数据域可以由若干其它Atom组成,从而实现结构化的数据。
MP4文件需要有ftyp、moov、mdat,它们都是顶级Atom,不能被其他Atom嵌套。
ftyp
标示了MP4文件,必须出现在第一个;moov
保存了视频的基本信息mdat
保存视频和音频数据。这两个Atom顺序不固定。
若要在视频文件未能被完整下载前即开始播放,并能跳转到指定位置,肯定要首先获知其 moov atom 信息。这也是 moov atom 存在的意义。
判断
通过FFmpeg
工具可以查看:
ffmpeg -v trace -i input.mp4 NUL 2>&1 | grep -m 1 -o -e type:\'mdat\' -e type:\'moov\'
Python代码判断如下:
import subprocess
def is_moov_ahead(video_path):
"""判断视频文件的 moov atom 是否在文件头部。检查成功返回 bool,否则返回 None"""
command = f'ffmpeg -v trace -i {video_path} NUL 2>&1 | grep -m 1 -o -e "type:\'mdat\'" -e "type:\'moov\'"'
try:
child = subprocess.Popen(command, shell=True, stdout=subprocess.PIPE, stderr=subprocess.PIPE)
stdout, stderr = child.communicate()
if child.returncode == 0:
return (b'moov' in stdout)
except Exception:
pass
return False
调整 moov 位置
ffmpeg.exe -i input.mp4 -c copy -map 0 -movflags faststart output.mp4