movコンテナに格納されている次のデータのH.264 NALUヘッダーの周りに頭を浮かべています。ファイルからH.264 NALUバイトアライメント
例:
0x00 0x00 0x00 0x02 -> 00000000 00000000 00000000 00000010
:これまでのところ私は、ビットストリームが原因1ビット左にオフセットスタートコード・シーケンスにバイト整列されていないことを想定している
00 00 00 02 09 30 00 00 00 0E 06 01 09 00 02 08
24 68 00 00 03 00 01 80 00 00 2B 08 21 9A 01 01
64 47 D4 B2 5C 45 76 DA 72 E4 3B F3 AE A9 56 91
B2 3F FE CE 87 1A 48 13 14 A9 E0 12 C8 AD E9 22
...
したがって、これらのバイトと次のバイトを右の1ビットにシフトして、次の開始シーケンスコードとヘッダービットが最初のヘッダーになるようにします。
私は一例で、次のバイトシーケンスに到達したときしかし、私は剥がれ来ています:
0x00 0x00 0x00 0x0E
私はそれが別の起動シーケンスコードであると仮定すると、異なるバイトアライメントとしています。
00000000 00000000 00000000 00001110 00000110 00000001 00001001 00000000
バイトアライメントの後、私は、次のヘッダバイト取得しています:ヘッダ(forbidden_zero_bit)の最初のビットは、それがゼロ
なければならない規則に違反ゼロで00000 00000000 00000000 00000001 [1 10 00000]
を
ここで私は立ち上がっていますか?
私はここで間違った仮定をしていますか?
ありがとうございますnobody555、この余分な情報は、多くの助けになり、今より意味をなさない。私は自分のベニフィットのサンプルサイズの原子データでこれを確認する必要がありますが、今はこれが明確であり、今は意味があります。乾杯。 – Pobbel
これは、実際、これが記述されているように原子サイズに適合することを確認しました。 MOV開発者リファレンスhttps://developer.apple.com/library/mac/documentation/QuickTime/QTFF/QTFFPreface/qtffPreface.htmlでこのエンコーディングへの参照を見つけることができません。このエンコーディングは、ITU-T H.264の一部ですまたは多分ISO/IEC 14496-15? – Pobbel
ITU-T H.264仕様の一部ではありません。おそらくISO/IEC 14496-15に関してはそうですが、私はそれにアクセスすることはできません(無料ではありません)ので、確かにそれを確認することはできません。 – nobody555