MPEG-4 File Source
The MPEG-4 file source parses MP4 and 3GPP files. For more information about the MP4 file format, refer to the following standards documents:
- ISO/IEC 14496-12: Information technology -- Coding of audio-visual objects -- Part 12: ISO Base Media File Format
- ISO/IEC 14496-14: Information technology -- Coding of audio-visual objects -- Part 14: MP4 File Format
Note (These resources may not be available in some languages and countries.)
The MPEG-4 file source does not decode the audio/video data in the file.
This topic contains the following sections:
The MPEG-4 file source is the default media source for the following file name extensions.
|.mov||Apple QuickTime Movie|
|.mp4||MPEG-4 audio or video|
It is also the default media source for the following MIME types.
MP4 is an extensible container format. The MP4 specification does not define a fixed structure for describing media types in an MP4 container. Instead, it defines an object hierarchy that allows custom structures to be defined for each format. The format description is stored in the sample description ('stsd') box for that stream. The sample description box contains a list of sample entries. For each sample entry, a 4-byte code, similar to a FOURCC, defines the format structure.
This extensibility means the MPEG-4 file source cannot recognize every possible format description. Instead, it takes a two-tiered approach when creating media types for the streams. At a minimum, every media type contains the following attributes.
|MF_MT_MAJOR_TYPE||Equal to MFMediaType_Audio or MFMediaType_Video.|
|MF_MT_SUBTYPE||Specifies the stream subtype.|
|MF_MT_MPEG4_SAMPLE_DESCRIPTION||Contains the complete sample description box as a binary blob.|
|MF_MT_MPEG4_CURRENT_SAMPLE_ENTRY||Specifies the current entry in the sample description box.|
The MPEG-4 file source recognizes some sample entry types. For these entries, it can parse the format structure and create a complete media type, with additional attributes that describe the format details. See Media Type Attributes.
The MPEG-4 file source can parse the following sample entries.
|Sample entry code||Major type||Subtype||Description||Notes|
|'jpeg'||Video||MFVideoFormat_MJPG||Photo-JPEG stream||The QuickTime container format also supports motion JPEG streams with 'mjpa' or 'mjpb' entries, but the MPEG-4 file source does not provide a complete media type for those types.|
|AAC or MP3||The 'mp4a' entry can describe other MPEG audio formats, but the MPEG-4 file source does not parse the format structure.|
|MPEG-4 part 2||
MFVideoFormat_M4S2 is used for MPEG-4 part 2 Simple Profile.
MFVideoFormat_MP4V is used for all other MPEG-4 part 2 profiles, including Advanced Simple Profile.
|'raw '||Audio||MFAudioFormat_PCM||8-bit PCM audio|
|'sowt'||Audio||MFAudioFormat_PCM||16-bit little-endian PCM audio|
|'twos'||Audio||MFAudioFormat_PCM||16-bit big-endian PCM audio||The MPEG-4 file source converts the audio data to little-endian format.|
|'NONE'||Audio||MFAudioFormat_PCM||8-bit or 16-bit big-endian PCM audio||The MPEG-4 file source converts the audio data to little-endian format.|
|0x00000000||Audio||MFAudioFormat_PCM||8-bit or 16-bit big-endian PCM audio||The MPEG-4 file source converts the audio data to little-endian format.|
|0x6d730002||Audio||WAVE_FORMAT_ADPCM||Adaptive Differential Pulse Code Modulation (ADPCM)|
For any other codes not shown in the previous table, the MPEG-4 file source sets the subtype as follows:
- subtype = MFMPEG4Format_Base
- subtype.Data1 = sample entry code
For codes not shown in the table, a decoder must use the MF_MT_MPEG4_SAMPLE_DESCRIPTION attribute to parse the sample description box.
For a list of sample entry codes and links to relevant specifications, see the 'MP4' Registration Authority website.
The MPEG-4 file source does not support the following features of MP4 files:
- External tracks.
- Movie fragments ('moof' or 'mfra' boxes). 'moof' is supported in Windows 8.
- Streamed presentations. The MPEG-4 file source silently ignores hint tracks.
- Seeking by SMPTE time code.
- Compressed ('cmov') atoms.
Only video and audio streams are supported. Any tracks that contain other stream types are silently ignored. Media data must be placed inside 'mdat' atoms.
If Platform Update Supplement for Windows Vista is installed, the MPEG-4 file source is available on Windows Vista, but is accessible on Windows Vista only by using the Source Reader.
Rotation read and write support added in Windows 8 MPEG-4 source and sink. This is not supported in the Windows 7 MPEG-4 source and sink.
MPEG-4 source reads the rotation angle for an active video track as the sum of the rotation angle from ‘mvhd’ and from ‘tkhd’.
Microsoft MPEG-4 sink writes the rotation angle in ‘tkhd’ but writes 0 degree (identity) matrix in ‘mvhd’. Note, Microsoft MPEG-4 sink only supports single video track.
IPropertyStore reads the rotation angle for only the first video track as the sum of the rotation angle from ‘mvhd’ and from ‘tkhd’.
IPropertyStore writes the rotation angle for only the first video track in ‘tkhd’ after the rotation angle is adjusted according to the rotation angle in ‘mvhd’, if it exists.
- Movie fragments ('moof') is supported in Windows 8 MPEG-4 source and sink, but 'mfra' is not.
H.263 is supported in Windows 8 MPEG-4 source.
MPEG-4 source now maps two fourcc’s of ‘h263’ and ‘s263’ in MPEG-4 file format to the media type of MFVideoFormat_H263.
More fourcc support added for MJPEG in Windows 8 MPEG-4 source.
MPEG-4 source maps foucc of ‘dmb1’ to the media type of MFVideoFormat_MJPG.
Furigana metadata support added in Windows 8 MPEG-4 source.
MPEG-4 source reads Furigana metadata from ’soal’, ‘soar’, ‘soaa’, ‘sonm’, and ‘soco’. IPropertyStore reads Furignana metadata through the set of corresponding PKEYs.
The following table shows the mapping between the shell canonical name, the property key, and the box/tag ID in MPEG-4 file format.
Field Property Key Tag/Box ID System.Music.AlbumTitleSortOverride PKEY_Music_AlbumTitleSortOverride soal System.Music.ArtistSortOverride PKEY_Music_ArtistSortOverride soar System.Music.AlbumArtistSortOverride PKEY_Music_AlbumArtistSortOverride soaa System.TitleSortOverride PKEY _TitleSortOverride sonm System.Music.ComposerSortOverride PKEY_Music_ComposerSortOverride soco
Stereo 3D atom support added in Windows 8 MPEG-4 source.
- AC3 and DD+ support added in Windows 8 MPEG-4 source and sink.
- Files larger than 4 gigabytes (GB) are supported in Windows 8 MPEG-4 sink for non-fragmental MP4.
Scrubbing has been optimized in Windows 8 MPEG-4 source.
To reduce latency, information for the two nearest key frames for a particular seek position are exposed through IMFSeekInfo::GetNearestKeyFrames. Since the key frame does not have dependent frames, it presents the frame after decoding only one frame. Use IMFGetService::GetService to obtain this interface through the media source, pipeline, or application.
Set rate to zero in MPEG-4 source. When the pipeline is in scrubbing mode, the rate is zero.
SPS and PPS can be stored in sample data in MPEG-4 sink.
MF_MPEG4SINK_SPSPPS_PASSTHROUGH attribute on MPEG-4 sink is defined to allow SPS’s and PPS’s to be saved together with input samples (H.264 video data). The produced mp4 clips are play-able by Windows 7 MPEG-4 source and others.
SPS and PPS can be extracted from input samples in MPEG-4 sink.
When SPS and PPS are not set through MF_MT_MPEG_SEQUENCE_HEADER on input media type of the MPEG-4 sink, MPEG-4 sink will try to extract SPS and PPS from input samples. MPEG-4 sink ignores any input samples until it finds the first SPS and PPS, because all input samples without SPS and PPS are not decode-able.
- 3D information in AVC configuration record is supported for non-fragmental MP4.
NALU length is exposed for H.264 compressed samples to optimize H.264 VLD DXVA decoding.
MPEG-4 source sets MF_NALU_LENGTH_SET on the output media type of MFVideoFormat_H264 or MFVideoFormat_h264. It sets the blob of MF_NALU_LENGTH_INFORMATION on each output sample, with four-byte NALU length for different NALU’s in one compressed sample.
- Support added for MPEG2 ADTS audio in MP4 source.