You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

1.6 KiB

Media Source Extensions Notes

A collection of findings experimenting with Media Source Extensions on Chrome 36.

  • Specifying an audio and video codec when creating a source buffer but passing in an initialization segment with only a video track results in a decode error

ISO Base Media File Format (BMFF)

Init Segment

A working initialization segment is outlined below. It may be possible to trim this structure down further.

  • ftyp
  • moov
    • mvhd
    • trak
      • tkhd
      • mdia
        • mdhd
        • hdlr
        • minf
    • mvex

Media Segment

The structure of a minimal media segment that actually encapsulates movie data is outlined below:

  • moof
    • mfhd
    • traf
      • tfhd
      • tfdt
      • trun containing samples
  • mdat

Structure

sample: time {number}, data {array} chunk: samples {array} track: samples {array} segment: moov {box}, mdats {array} | moof {box}, mdats {array}, data {array}

track chunk sample

movie fragment -> track fragment -> [samples]

Sample Data Offsets

Movie-fragment Relative Addressing: all trun data offsets are relative to the containing moof (?).

Without default-base-is-moof, the base data offset for each trun in trafs after the first is the end of the previous traf.

iso5/DASH Style

moof |- traf (default-base-is-moof) | |- trun_0 + 0 | - trun_1 <size of moof> + 100 - traf (default-base-is-moof) - trun_2 <size of moof> + 300 mdat |- samples_for_trun_0 (100 bytes) |- samples_for_trun_1 (200 bytes) - samples_for_trun_2

Single Track Style

moof - traf - trun_0 + 0 mdat `- samples_for_trun_0