FLV文件(H264 + AAC)格式超详细分析

最近自己动手将H264视频流和AAC音频流合成flv文件,但是没有采用开源的ffmpeg的api来处理音视频流。方法就是模仿ffmpeg中libavformat/flvenc.c 文件写代码来完成音视频的flv格式封装。在这个封装过程中,需要非常清楚flv文件格式。网上有关flv文件格式的资料非常多,不过大部分资料是互相转载或者缺乏足够详细的信息(例如:AVDecoderConfigurationRecord和 AudioSpecificConfig的生成)。
因此我就以ffmpeglibavformat/flvenc.c为基础分析flv文件的构成,详细分析flv文件中每个字节的含义。以下每个方格代表一个字节。其中的数字都是16进制表示(省略0x),格中的字符也可以用相应的16进制数字替代,用字符表示有时候更为直观。假定flv文件同时含有视频和音频。

FLV文件(H264 + AAC)格式超详细分析 - nkwavelet - 小波的世界
 

接下来就是Metadata的具体数据,由两个AMF包组成。

FLV文件(H264 + AAC)格式超详细分析 - nkwavelet - 小波的世界

 

Metadata元素个数暂定为12个 音频5个 视频5个 + 2(durationfilesize)。 后面还可能会加入其它元素,因此会返回来修改此值。metadata元素的顺序不固定,此处采用ffmpeg中的顺序。

第二个AMF包中各数组元素封装形式为:前两个字节是元素名称的长度;后面跟着长度为L的字符串;第L+3个字节表示元素值的类型;后面跟着是对应值,占用的字节数取决于值的类型。


FLV文件(H264 + AAC)格式超详细分析 - nkwavelet - 小波的世界

 

FLV文件(H264 + AAC)格式超详细分析 - nkwavelet - 小波的世界

 FLV文件(H264 + AAC)格式超详细分析 - nkwavelet - 小波的世界


  FLV文件(H264 + AAC)格式超详细分析 - nkwavelet - 小波的世界

以下的(tag->keytag->value)不一定在所有flv文件中出现,依据不同版本有所不同。

FLV文件(H264 + AAC)格式超详细分析 - nkwavelet - 小波的世界

FLV文件(H264 + AAC)格式超详细分析 - nkwavelet - 小波的世界
 
  FLV文件(H264 + AAC)格式超详细分析 - nkwavelet - 小波的世界
 
  Remark 以上将flv官方文档的metadata信息写入了Script Tag中。但是在做flv文件合成的时候,发现网上有的flv文件将keyframes信息隐藏在Script Tag中。后来通过网络查一些资料,发现keyframes几乎是一个非官方的标准,也就是民间标准。 
两个常用的操作 metadata 的工具是 flvtool2 FLVMDI  都是把 keyframes 作为一个默认的元信息项目。在 FLVMDI 的主 (http://www.buraks.com/flvmdi/) 上有描述:

keyframes: (Object) This object is added only if you specify the /k switch. 'keyframes' is known to FLVMDI and if /k switch is not specified, 'keyframes' object will be deleted.
'keyframes' object has 2 arrays: 'filepositions' and 'times'. Both arrays have the same number of elements, which is equal to the number of key frames in the FLV. Values in times array are in 'seconds'. Each correspond to the timestamp of the n'th key frame. Values in filepositions array are in 'bytes'. Each correspond to the fileposition of the nth key frame video tag (which starts with byte tag type 9).

也就是说keyframes中包含着2个内容 'filepositions' and 'times'分别指的是关键帧的文件位置和关键帧的PTS。通过keyframes可以建立起自己的Index,然后再seek和快进快退的操作中,快速有效的跳转到你想要找的关键帧位置进行处理。


FLV文件(H264 + AAC)格式超详细分析 - nkwavelet - 小波的世界


FLV文件(H264 + AAC)格式超详细分析 - nkwavelet - 小波的世界

  
FLV文件(H264 + AAC)格式超详细分析 - nkwavelet - 小波的世界
 
FLV文件(H264 + AAC)格式超详细分析 - nkwavelet - 小波的世界
 
FLV文件(H264 + AAC)格式超详细分析 - nkwavelet - 小波的世界
 
FLV文件(H264 + AAC)格式超详细分析 - nkwavelet - 小波的世界


FLV文件(H264 + AAC)格式超详细分析 - nkwavelet - 小波的世界

 

FLV文件(H264 + AAC)格式超详细分析 - nkwavelet - 小波的世界

 

到此为止已经介绍完flv文件格式,flv格式还是比较简单的,header部分很简洁,body部分都是由一个个tag组成,tag的话也就三种,脚本tag一般只有一个。最后用一个简单的图来概括flv文件格式,以结束本文档。

FLV文件(H264 + AAC)格式超详细分析 - nkwavelet - 小波的世界
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值