--- title: Форматы медиа поддерживаемые HTML audio и video элементами slug: Web/HTML/Поддерживаемые_медиа_форматы translation_of: Web/Media/Formats ---
{{ HTMLElement("audio") }} и {{ HTMLElement("video") }} элементы предоставляют поддержку для проигрывания аудио и видео медиа без нужды в плагинах. Формат медиафайла состоит из контейнера, содержащего один или несколько потоков данных, закодированных с использованием формата сжатия, называемого кодеком. Контейнер идентифицируется по расширению файла. Потоки внутри контейнера имеют несколько типов, которые могут включать в себя видео, аудио, данные или титры. Один контейнер (т. е. медиафайл) может содержать несколько потоков одного типа. В аудио- и видео- потоках находятся кодеки. Кодек — сокращенние слов "кодера-декодер" — является алгоритмом сжатия данных в файле. Каждый тип контейнера имеет только определенные кодеки, которые он поддерживает.
Важно понять, почему в Интернете нужны разные медиаформаты. По разным причинам, выходящим за рамки данной статьи, различные браузеры поддерживают разные медиаформаты. Кроме того, область медиаформатов в Интернете сильно пострадала от патентного права во многих странах, включая США и страны ЕС. (Примечания к патентам в этой статье предоставляются как есть, так и без каких-либо гарантий.) В этой статье рассматриваются наиболее важные для Интернета форматы, включая поддержку в браузерах как мобильных, так и десктопных .
Ниже краткий обзор того, как медиа-элементы отображаются в HTML. Более подробную информацию смотрите в статьях для каждого элемента.
HTML5 поддерживает несколько элементов мультимедиа. Элементы {{HTMLElement ("video")}} и {{HTMLElement ("audio")}} могут использоваться отдельно или в сочетании с элементом {{HTMLElement ("source")}}. Наш краткий пример отображает это. Хотя элементы <video>
и <audio>
содержат атрибуты src, этот пример использует элемент <source>
для предоставления видеофайлов в нескольких форматах, позволяя каждому браузеру выбирать элемент, который он поддерживает.
<video controls> <source src="somevideo.webm" type="video/webm"> <source src="somevideo.mp4" type="video/mp4"> Сожалею; ваш браузер не поддерживает HTML5 видео в WebM с VP8 или MP4 с H.264. <!-- Ты можешь встроить флеш плеер сюда, для воспроизведения твоего mp4 видео в старых браузерах --> </video>
Формат WebM основан на ограниченной версии формата контейнера Matroska. Формат всегда использует видео кодек VP8 или VP9 и аудио кодек Vorbis или Opus. WebM нативно поддерживается в десктопной и мобильной версиях Gecko (Firefox), Chrome и Opera. Поддержка формата может быть добавлена в Internet Explorer и Safari (но не на iOS) установкой плагина. Нативная поддержка VP9 WebM в Edge сейчас в стадии разработки.
Формат WebM, а точнее видеокодек VP8, подвергся претензиям в нарушениях патентов от ряда компаний, отвечающих на требования, MPEG LA о фомировании списка патентов, но при этом MPEG LA дала согласие на лицензирование этих патентов для Google под лицензией "perpetual, transferable, royalty free license". Это фактически означает, что все известные патенты, относящиеся к формату WebM лицензированы для свободного использования всеми.
Движок Gecko распознаёт следующие типы MIME как файлы WebM:
video/webm
audio/webm
The Ogg container format with the Theora video codec and the Vorbis audio codec is supported in desktop/mobile Gecko (Firefox), Chrome, and Opera, and support for the format can be added to Safari (but not on iOS) by installing an add-on. The format is not supported in Internet Explorer in any way.
WebM is generally preferred over Ogg Theora Vorbis when available, because it provides a better compression to quality ratio and is supported in more browsers. The Ogg format can however be used to support older browser versions (for example Firefox 3.5/3.6 don't support WebM, but do support Ogg.)
The patent situation of Theora is similar to that of WebM.
You can learn more about creating Ogg media by reading the Theora Cookbook.
Gecko recognizes the following MIME types as Ogg files:
audio/ogg
video/ogg
application/ogg
The Ogg container can also contain audio encoded using the Opus codec. Support for this is available in Gecko 15.0 {{ geckoRelease("15.0") }} and later, on desktop and mobile browsers.
The MP4 container format with the H.264 video codec and the AAC audio codec is natively supported by desktop/mobile Internet Explorer, Safari and Chrome, but Chromium and Opera do not support the format. IE and Chrome also support the MP3 audio codec in the MP4 container, but Safari does not. Firefox/Firefox for Android/Firefox OS supports the format in some cases, but only when a third-party decoder is available, and the device hardware can handle the profile used to encode the MP4.
Note: MP4s encoded with a high profile will not run on lower end hardware, such as low end Firefox OS phones.
The MPEG media formats are covered by patents, which are not freely licensed. All the necessary licenses can be bought from MPEG LA. Since H.264 is currently not a royalty free format, it is unfit for the open web platform, according to Mozilla [1, 2], Google [1, 2] and Opera. However, since royalty free formats are not supported by Internet Explorer and Safari, Mozilla has decided to support the format anyway, and Google never fulfilled their promise to remove support for it in Chrome.
MP3 аудио формат (.mp3, audio/mpeg
; в отличии от выше MP3 аудио в случае MP4 контейнера) поддерживается в <audio>
Firefox/Firefox для Android/Firefox OS когда операционая система обеспечивает MP3 декодер, и Internet Explorer, Chrome и Safari.
The WAVE container format, with the PCM audio codec (WAVE codec "1") is supported by desktop/mobile Gecko (Firefox) and Safari. Files in the WAVE container format typically end with the ".wav" extension.
Gecko recognizes the following MIME types as WAVE audio files:
audio/wave
(preferred; does not work in Chrome)audio/wav
audio/x-wav
audio/x-pn-wav
Media Source Extensions is a W3C working draft that plans to extend {{ domxref("HTMLMediaElement") }} to allow JavaScript to generate media streams for playback. Allowing JavaScript to generate streams facilitates a variety of use cases like adaptive streaming and time shifting live streams. This currently has experimental support in Firefox desktop, and other browsers too.
For example, you could implement MPEG-DASH using JavaScript while offloading the decoding to MSE.
Note: Time Shifting is the process of consuming a live stream some time after it happened.
{{ CompatibilityTable() }}
Feature | Chrome | Firefox (Gecko) | Internet Explorer | Opera | Safari |
---|---|---|---|---|---|
Basic support | 3.0 | {{ CompatGeckoDesktop("1.9.1") }} | 9.0 | 10.50 | 3.1 |
<audio> : PCM in WAVE |
{{ CompatVersionUnknown() }} | {{ CompatGeckoDesktop("1.9.1") }} | {{ CompatNo() }} | 10.50 | 3.1 |
<audio> : Vorbis in WebM |
{{ CompatVersionUnknown() }} | {{ CompatGeckoDesktop("2.0") }} | {{ CompatNo() }} | 10.60 | 3.1 (must be installed separately) |
<audio> : Streaming Vorbis in WebM via Media Source Extensions (MSE) |
{{ CompatUnknown() }} | {{ CompatGeckoDesktop("36.0") }} in Nightly/Dev edition only | {{ CompatUnknown() }} | {{ CompatUnknown() }} | {{ CompatUnknown() }} |
<audio> : Vorbis in Ogg |
{{ CompatVersionUnknown() }} | {{ CompatGeckoDesktop("1.9.1") }} | {{ CompatNo() }} | 10.50 | 3.1 (must be installed separately, e.g. XiphQT) |
<audio>: MP3 | {{ CompatVersionUnknown() }} (Not in Chromium) | Partial (see below) | 9.0 | {{ CompatVersionUnknown() }} | 3.1 |
<audio> : MP3 in MP4 |
{{ CompatUnknown() }} |
{{ CompatUnknown() }} | {{ CompatUnknown() }} | {{ CompatUnknown() }} | {{ CompatVersionUnknown() }} |
<audio> : AAC in MP4 |
{{ CompatVersionUnknown() }} (Main only) (Not in Chromium) |
Partial (see below) |
9.0 | {{ CompatVersionUnknown() }} | 3.1 |
<audio> : Opus in Ogg |
27.0 | {{ CompatGeckoDesktop("15.0") }} | {{ CompatUnknown() }} | {{ CompatUnknown() }} | {{ CompatUnknown() }} |
<video> : VP8 and Vorbis in WebM |
6.0 | {{ CompatGeckoDesktop("2.0") }} | 9.0 (must be installed separately, e.g. WebM MF) | 10.60 | 3.1 (must be installed separately, e.g. Perian) |
<video> : VP9 and Opus in WebM |
29.0 | {{ CompatGeckoDesktop("28.0") }} | {{ CompatUnknown() }} | {{ CompatVersionUnknown() }} | {{ CompatUnknown() }} |
<video> : Streaming VP9 and Opus/VP8 and Opus in WebM via Media Source Extensions (MSE) |
{{ CompatUnknown() }} | {{ CompatGeckoDesktop("36.0") }} in Nightly/Dev edition only | {{ CompatUnknown() }} | {{ CompatUnknown() }} | {{ CompatUnknown() }} |
<video> : Theora and Vorbis in Ogg |
{{ CompatVersionUnknown() }} | {{ CompatGeckoDesktop("1.9.1") }} | {{ CompatNo() }} | 10.50 | 3.1 (must be installed separately, e.g. XiphQT) |
<video> : H.264 and MP3 in MP4 |
{{ CompatVersionUnknown() }} (Not in Chromium) |
Partial (see below) | 9.0 | {{ CompatVersionUnknown() }} | {{ CompatVersionUnknown() }} |
<video> : H.264 and AAC in MP4 |
{{ CompatVersionUnknown() }} (Not in Chromium) |
Partial (see below) | 9.0 | {{ CompatVersionUnknown() }} | 3.1 |
any other format | {{ CompatNo() }} | {{ CompatNo() }} | {{ CompatNo() }} | {{ CompatNo() }} | 3.1 (plays all formats available via QuickTime) |
Feature | Android | Firefox Mobile (Gecko) | Firefox OS (Gecko) | IE Mobile | Opera Mobile | Opera Mini | Safari Mobile | Chrome for Android |
---|---|---|---|---|---|---|---|---|
Basic support | 2.3 | 24.0 | 1.0.1 | 10.0 | 11.0 | Partial (see below) | 3.2 | 29.0 |
<audio> : PCM in WAVE |
{{ CompatUnknown() }} | 24.0 | 1.0.1 | {{ CompatNo() }} | {{ CompatNo() }} | Partial (see below) | 3.2 | {{ CompatUnknown() }} |
<audio> : Vorbis in WebM |
{{ CompatUnknown() }} | 24.0 | 1.0.1 | {{ CompatNo() }} | 11.0 | Partial (see below) | {{ CompatNo() }} | {{ CompatUnknown() }} |
<audio> : Streaming Vorbis in WebM via Media Source Extensions (MSE) |
{{ CompatUnknown() }} | {{ CompatUnknown() }} | {{ CompatUnknown() }} | {{ CompatUnknown() }} | {{ CompatUnknown() }} | {{ CompatUnknown() }} | {{ CompatUnknown() }} | {{ CompatUnknown() }} |
<audio> : Vorbis in Ogg |
{{ CompatUnknown() }} | 24.0 | 1.0.1 | {{ CompatNo() }} | 11.0 | Partial (see below) | {{ CompatNo() }} | {{ CompatUnknown() }} |
<audio> : MP3 |
{{ CompatUnknown() }} | Partial (see below) | Partial (see below) | 10.0 | {{ CompatUnknown() }} | Partial (see below) | 3.2 | {{ CompatUnknown() }} |
<audio> : MP3 in MP4 |
{{ CompatUnknown() }} | {{ CompatUnknown() }} | {{ CompatUnknown() }} | {{ CompatUnknown() }} | {{ CompatUnknown() }} | {{ CompatUnknown() }} | {{ CompatVersionUnknown() }} | {{ CompatUnknown() }} |
<audio> : AAC in MP4 |
{{ CompatUnknown() }} | Partial (see below) | Partial (see below) | 10.0 | {{ CompatUnknown() }} | Partial (see below) | {{ CompatVersionUnknown() }} | {{ CompatUnknown() }} |
<audio> : Opus in Ogg |
{{ CompatNo() }} | 24.0 | {{ CompatNo() }} | {{ CompatNo() }} | {{ CompatNo() }} | Partial (see below) | {{ CompatNo() }} | {{ CompatNo() }} |
<video> : VP8 and Vorbis in WebM |
2.3 | 24.0 | 1.0.1 | {{ CompatNo() }} | 16.0 | Partial (see below) | {{ CompatNo() }} | 29.0 |
<video> : VP9 and Opus in WebM |
{{ CompatUnknown() }} | {{ CompatUnknown() }} | {{ CompatUnknown() }} | {{ CompatUnknown() }} | {{ CompatUnknown() }} | {{ CompatUnknown() }} | {{ CompatUnknown() }} | {{ CompatUnknown() }} |
<video> : Streaming VP9 and Opus/VP8 and Opus in WebM via Media Source Extensions (MSE) |
{{ CompatUnknown() }} | {{ CompatUnknown() }} | {{ CompatUnknown() }} | {{ CompatUnknown() }} | {{ CompatUnknown() }} | {{ CompatUnknown() }} | {{ CompatUnknown() }} | {{ CompatUnknown() }} |
<video> : Theora and Vorbis in Ogg |
{{ CompatNo() }} | 24.0 | 1.0.1 | {{ CompatNo() }} | {{ CompatNo() }} | Partial (see below) | {{ CompatNo() }} | {{ CompatNo() }} |
<video> : H.264 and MP3 in MP4 |
Partial (see below) | 24.0 | Partial (see below) | 10.0 | Partial since 11.0, full since 16.0 | Partial (see below) | {{ CompatVersionUnknown() }} | 29.0 |
<video> : H.264 and AAC in MP4 |
Partial (see below) | 24.0 | Partial (see below) | 10.0 | Partial since 11.0, full since 16.0 | Partial (see below) | 3.2 | 29.0 |
any other format | {{ CompatUnknown() }} | {{ CompatUnknown() }} | {{ CompatUnknown() }} | {{ CompatUnknown() }} | {{ CompatUnknown() }} | {{ CompatUnknown() }} | {{ CompatUnknown() }} | {{ CompatUnknown() }} |
Notes:
<video>
support for different formats, HTMLMediaElement.prototype.canPlayType
incorrectly reports true
for h.264 video whereas in actual fact h.264 is not supported. In Firefox OS 1.1 this problem has been fixed.Platform | Firefox version |
---|---|
Windows Vista+ | 22.0+ |
Android | 20.0+ |
Firefox OS | 15.0+ |
Linux |
26.0+ (relies on GStreamer codecs) |
OS X 10.7+ | 35.0+ |
video
audio