Origem do arquivo MPEG-4
A origem do arquivo MPEG-4 analisa arquivos MP4 e 3GPP. Para obter mais informações sobre o formato de arquivo MP4, consulte os seguintes documentos padrões:
- ISO/IEC 14496-12: tecnologia de informações -- codificação de objetos audiovisuais -- Parte 12: formato de arquivo de mídia base iso
- ISO/IEC 14496-14: Tecnologia da informação -- Codificação de objetos audiovisuais -- Parte 14: formato de arquivo MP4
Nota
(Esses recursos podem não estar disponíveis em alguns idiomas e países.)
A origem do arquivo MPEG-4 não decodifica os dados de áudio/vídeo no arquivo.
Este tópico contém as seguintes seções:
Extensões de arquivo e tipos MIME
A origem do arquivo MPEG-4 é a fonte de mídia padrão para as extensões de nome de arquivo a seguir.
Extensão | Descrição |
---|---|
.3g2 | 3GPP2 |
.3gp | 3GPP |
.3gp2 | 3GPP2 |
.3gpp | 3GPP |
.m4a | Áudio MPEG-4 |
.m4v | Vídeo mpeg-4 |
.Mov | Apple QuickTime Movie |
.mp4 | Áudio ou vídeo MPEG-4 |
.mp4v | Vídeo mpeg-4 |
Também é a fonte de mídia padrão para os seguintes tipos MIME.
Tipo MIME | Descrição |
---|---|
áudio/3gpp | Áudio 3GPP |
áudio/3gpp2 | Áudio 3GPP2 |
áudio/mp4 | Áudio MPEG-4 |
vídeo/3gpp | Vídeo 3GPP |
vídeo/3gpp2 | Vídeo 3GPP2 |
vídeo/mp4 | Vídeo mpeg-4 |
Tipos de mídia
MP4 é um formato de contêiner extensível. A especificação MP4 não define uma estrutura fixa para descrever tipos de mídia em um contêiner MP4. Em vez disso, define uma hierarquia de objetos que permite que estruturas personalizadas sejam definidas para cada formato. A descrição do formato é armazenada na caixa de descrição de exemplo ('stsd') desse fluxo. A caixa de descrição de exemplo contém uma lista de entradas de exemplo. Para cada entrada de exemplo, um código de 4 bytes, semelhante a um FOURCC, define a estrutura de formato.
Essa extensibilidade significa que a origem do arquivo MPEG-4 não pode reconhecer todas as descrições de formato possíveis. Em vez disso, ele usa uma abordagem de duas camadas ao criar tipos de mídia para os fluxos. No mínimo, cada tipo de mídia contém os atributos a seguir.
Atributo | Descrição |
---|---|
MF_MT_MAJOR_TYPE | Igual a MFMediaType_Audio ou MFMediaType_Video. |
MF_MT_SUBTYPE | Especifica o subtipo de fluxo. |
MF_MT_MPEG4_SAMPLE_DESCRIPTION | Contém a caixa de descrição de exemplo completa como um blob binário. |
MF_MT_MPEG4_CURRENT_SAMPLE_ENTRY | Especifica a entrada atual na caixa de descrição de exemplo. |
A origem do arquivo MPEG-4 reconhece alguns tipos de entrada de exemplo. Para essas entradas, ele pode analisar a estrutura de formato e criar um tipo de mídia completo, com atributos adicionais que descrevem os detalhes do formato. Consulte atributos de tipo de mídia.
A origem do arquivo MPEG-4 pode analisar as seguintes entradas de exemplo.
Código de entrada de exemplo | Tipo principal | Subtipo | Descrição | Anotações |
---|---|---|---|---|
'alaw' | Áudio | WAVE_FORMAT_ALAW | Codificação de lei | |
'jpeg' | Vídeo | MFVideoFormat_MJPG | fluxo de Photo-JPEG | O formato de contêiner QuickTime também dá suporte a fluxos JPEG de movimento com entradas 'mjpa' ou 'mjpb', mas a fonte de arquivo MPEG-4 não fornece um tipo de mídia completo para esses tipos. |
'avc1' | Vídeo | MFVideoFormat_H264 | Vídeo do H.264 | |
'mp4a' | Áudio |
MFAudioFormat_AAC MFAudioFormat_MP3 |
AAC ou MP3 | A entrada 'mp4a' pode descrever outros formatos de áudio MPEG, mas a origem do arquivo MPEG-4 não analisa a estrutura de formato. |
'mp4v' | Vídeo |
MFVideoFormat_M4S2 MFVideoFormat_MP4V |
MPEG-4 parte 2 |
MFVideoFormat_M4S2 é usado para o Perfil Simples mpeg-4 parte 2. MFVideoFormat_MP4V é usado para todos os outros perfis mpeg-4 parte 2, incluindo Perfil Simples Avançado. |
'raw' | Áudio | MFAudioFormat_PCM | Áudio pcm de 8 bits | |
'sowt' | Áudio | MFAudioFormat_PCM | Áudio pcm little-endian de 16 bits | |
'twos' | Áudio | MFAudioFormat_PCM | Áudio pcm big-endian de 16 bits | A fonte de arquivo MPEG-4 converte os dados de áudio em formato little-endian. |
'ulaw' | Áudio | WAVE_FORMAT_MULAW | codificação de lei de μ | |
'vc-1' | Vídeo | MFVideoFormat_WVC1 | Vídeo vc-1 | |
'NONE' | Áudio | MFAudioFormat_PCM | Áudio PCM big-endian de 8 bits ou 16 bits | A fonte de arquivo MPEG-4 converte os dados de áudio em formato little-endian. |
0x00000000 | Áudio | MFAudioFormat_PCM | Áudio PCM big-endian de 8 bits ou 16 bits | A fonte de arquivo MPEG-4 converte os dados de áudio em formato little-endian. |
0x6d730002 | Áudio | WAVE_FORMAT_ADPCM | Modulação de código de pulso diferencial adaptável (ADPCM) | |
0x6d730011 | Áudio | WAVE_FORMAT_IMA_ADPCM | ADPCM |
Para quaisquer outros códigos não mostrados na tabela anterior, a origem do arquivo MPEG-4 define o subtipo da seguinte maneira:
- subtipo = MFMPEG4Format_Base
- subtipo. Data1 = código de entrada de exemplo
Para códigos não mostrados na tabela, um decodificador deve usar o atributo MF_MT_MPEG4_SAMPLE_DESCRIPTION para analisar a caixa de descrição de exemplo.
Para obter uma lista de códigos de entrada de exemplo e links para especificações relevantes, consulte o site autoridade de registro 'MP4' site.
Limitações
A origem do arquivo MPEG-4 não dá suporte aos seguintes recursos de arquivos MP4:
- Faixas externas.
- Fragmentos de filme (caixas 'moof' ou 'mfra'). Há suporte para 'moof' no Windows 8.
- Apresentações transmitidas. A origem do arquivo MPEG-4 ignora silenciosamente as faixas de dica.
- Buscando por código de hora SMPTE.
- Átomos compactados ('cmov').
Há suporte apenas para fluxos de áudio e vídeo. Todas as faixas que contêm outros tipos de fluxo são silenciosamente ignoradas. Os dados de mídia devem ser colocados dentro de átomos 'mdat'.
Se o Suplemento de Atualização de Plataforma para Windows Vista estiver instalado, a fonte de arquivo MPEG-4 estará disponível no Windows Vista, mas só poderá ser acessada no Windows Vista usando o leitor de origem do.
Atualizações do Windows 8 para origem e coletor MPEG-4
Suporte de leitura e gravação de rotação adicionado no coletor e na origem do Windows 8 MPEG-4. Não há suporte para isso na origem e no coletor do Windows 7 MPEG-4.
A origem MPEG-4 lê o ângulo de rotação de uma faixa de vídeo ativa como a soma do ângulo de rotação de 'mvhd' e de 'tkhd'.
O coletor do Microsoft MPEG-4 grava o ângulo de rotação em 'tkhd', mas grava a matriz de 0 grau (identidade) em 'mvhd'. Observe que o coletor do Microsoft MPEG-4 dá suporte apenas a uma única faixa de vídeo.
IPropertyStore lê o ângulo de rotação apenas para a primeira faixa de vídeo como a soma do ângulo de rotação de 'mvhd' e de 'tkhd'.
O IPropertyStore grava o ângulo de rotação apenas para a primeira faixa de vídeo em 'tkhd' depois que o ângulo de rotação é ajustado de acordo com o ângulo de rotação em 'mvhd', se existir.
Os fragmentos de filme ('moof') têm suporte na origem e no coletor do Windows 8 MPEG-4, mas 'mfra' não é.
O H.263 tem suporte na origem do Windows 8 MPEG-4.
A origem MPEG-4 agora mapeia dois fourcc's de 'h263' e 's263' no formato de arquivo MPEG-4 para o tipo de mídia de MFVideoFormat_H263.
Mais suporte fourcc adicionado para MJPEG na origem do Windows 8 MPEG-4.
A origem MPEG-4 mapeia foucc de 'dmb1' para o tipo de mídia de MFVideoFormat_MJPG.
Suporte a metadados furigana adicionados na origem do Windows 8 MPEG-4.
A fonte MPEG-4 lê metadados de Furigana de 'soal', 'soar', 'soaa', 'sonm' e 'soco'. O IPropertyStore lê metadados de Furignana por meio do conjunto de PKEYs correspondentes.
A tabela a seguir mostra o mapeamento entre o nome canônico do shell, a chave de propriedade e a ID de caixa/marca no formato de arquivo MPEG-4.
Campo Chave de propriedade ID de marca/caixa System.Music.AlbumTitleSortOverride PKEY_Music_AlbumTitleSortOverride soal System.Music.ArtistSortOverride PKEY_Music_ArtistSortOverride subir System.Music.AlbumArtistSortOverride PKEY_Music_AlbumArtistSortOverride soaa System.TitleSortOverride PKEY _TitleSortOverride sonm System.Music.ComposerSortOverride PKEY_Music_ComposerSortOverride soco Suporte a atom 3D estéreo adicionado na origem do Windows 8 MPEG-4.
Suporte a AC3 e DD+ adicionados na origem e no coletor do Windows 8 MPEG-4.
Há suporte para arquivos maiores que 4 GB (gigabytes) no coletor MPEG-4 do Windows 8 para MP4 não fragmental.
A limpeza foi otimizada na origem do Windows 8 MPEG-4.
Para reduzir a latência, as informações dos dois quadros-chave mais próximos para uma posição de busca específica são expostas por meio de IMFSeekInfo::GetNearestKeyFrames. Como o quadro-chave não tem quadros dependentes, ele apresenta o quadro após a decodificação de apenas um quadro. Use IMFGetService::GetService para obter essa interface por meio da fonte de mídia, pipeline ou aplicativo.
Defina a taxa como zero na origem MPEG-4. Quando o pipeline está no modo de limpeza, a taxa é zero.
O SPS e o PPS podem ser armazenados em dados de exemplo no coletor MPEG-4.
MF_MPEG4SINK_SPSPPS_PASSTHROUGH atributo no coletor MPEG-4 é definido para permitir que SPS e PPS sejam salvos junto com amostras de entrada (dados de vídeo H.264). Os clipes mp4 produzidos são reproduzidos pela origem do Windows 7 MPEG-4 e outros.
SPS e PPS podem ser extraídos de exemplos de entrada no coletor MPEG-4.
Quando sps e PPS não são definidos por meio de MF_MT_MPEG_SEQUENCE_HEADER no tipo de mídia de entrada do coletor MPEG-4, o coletor MPEG-4 tentará extrair SPS e PPS de amostras de entrada. O coletor MPEG-4 ignora os exemplos de entrada até encontrar o primeiro SPS e PPS, pois todos os exemplos de entrada sem SPS e PPS não podem ser decodificados.
Há suporte para informações 3D no registro de configuração do AVC para MP4 não fragmental.
O comprimento da NALU é exposto para amostras compactadas H.264 para otimizar a decodificação de DXVA VLD H.264.
Conjuntos de origem MPEG-4 MF_NALU_LENGTH_SET no tipo de mídia de saída de MFVideoFormat_H264 ou MFVideoFormat_h264. Ele define o blob de MF_NALU_LENGTH_INFORMATION em cada exemplo de saída, com comprimento NALU de quatro bytes para DIFERENTES NALUs em uma amostra compactada.
Suporte adicionado para áudio do MPEG2 ADTS na fonte MP4.
Tópicos relacionados