HTML5 video

From HandWiki
Short description: HTML element

The HTML5 specification introduced the video element for the purpose of playing videos,[1] partially replacing the object element. HTML5 video is intended by its creators to become the new standard way to show video on the web, instead of the previous de facto standard of using the proprietary Adobe Flash plugin, though early adoption was hampered by lack of agreement as to which video coding formats and audio coding formats should be supported in web browsers. As of 2020, HTML5 video is the only widely supported video playback technology in modern browsers, with the Flash plugin being phased out.

History of <video> element

The <video> element started being discussed by the WHATWG in October 2006.[2] The <video> element was proposed by Opera Software in February 2007.[3] Opera also released a preview build that was showcased the same day,[4][5] and a manifesto that called for video to become a first-class citizen of the web.[6]

<video> element examples

The following HTML5 code fragment will embed a WebM video into a web page.

<video src="movie.webm" poster="movie.jpg" controls>
	This is fallback content to display for user agents that do not support the video tag.
</video>

The "controls" attribute enables the browser's own user interface for controlling playback. Alternatively, playback can be controlled with JavaScript, which the web designer can use to create a custom user interface. The optional "poster" attribute specifies an image to show in the video's place before playback is started. Its purpose is to be representative of the video.

Multiple sources

Video format support varies among browsers (see below), so a web page can provide video in multiple formats. For other features, browser sniffing is used sometimes, which may be error-prone: any web developer's knowledge of browsers will inevitably be incomplete or not up-to-date. The browser in question "knows best" what formats it can use. The "video" element supports fallback through specification of multiple sources. Using any number of <source> elements, as shown below, the browser will choose automatically which file to download. Alternatively, the JavaScript canPlayType() function can be used to achieve the same. The "type" attribute specifies the MIME type and possibly a list of codecs, which helps the browser to determine whether it can decode the file without beginning to download it. The MIME type denotes the container format of the file, and the container format defines the interpretation of the codec string.[7]

<video poster="poster.jpg" controls>
	<source src="av1.mp4" type='video/mp4; codecs="av01.0.00M.08, opus"'>
	<source src="avc.mp4" type='video/mp4; codecs="avc1.4D401E, mp4a.40.2"'>
	<source src="vp9.webm" type='video/webm; codecs="vp9.0, opus"'>
	<source src="theora.ogv" type='video/ogg; codecs="theora, vorbis"'>
	<p>This is fallback content to display for user agents that do not support the video tag.</p>
</video>

Supported video and audio formats

The HTML5 specification does not specify which video and audio formats browsers should support. User agents are free to support any video formats they feel are appropriate, but content authors cannot assume that any video will be accessible by all complying user agents, since user agents have no minimal set of video and audio formats to support.

The HTML5 Working Group considered it desirable to specify at least one video format which all user agents (browsers) should support. The ideal format in this regard would:

  • Have good compression, good image quality, and low decode processor use.
  • Be royalty-free.
  • In addition to software decoders, a hardware video decoder should exist for the format, as many embedded processors do not have the performance to decode video.

Initially, Ogg Theora was the recommended standard video format in HTML5, because it was not affected by any known patents. But on 10 December 2007, the HTML5 specification was updated,[8] replacing the reference to concrete formats:

User agents should support Theora video and Vorbis audio, as well as the Ogg container format.

with a placeholder:[9]

It would be helpful for interoperability if all browsers could support the same codecs. However, there are no known codecs that satisfy all the current players: we need a codec that is known to not require per-unit or per-distributor licensing, that is compatible with the open source development model, that is of sufficient quality as to be usable, and that is not an additional submarine patent risk for large companies. This is an ongoing issue and this section will be updated once more information is available.[10]

The result was a polarisation of HTML5 video between industry-standard, ISO-defined but patent-encumbered formats, and open formats. The new AV1 format by Alliance for Open Media aims to be both industry standard, royalty-free, and open, and has wide industry support.

Free formats

Although Theora is not affected by known non-free patents, Apple[11] has expressed concern about unknown patents that might affect it, whose owners might be waiting for a corporation with extensive financial resources to use the format before suing.[12][13] Formats like H.264 might also be subject to unknown patents in principle, but they have been deployed much more widely and so it is presumed that any patent-holders would have already made themselves known. Apple has also opposed requiring Ogg format support in the HTML standard (even as a "should" requirement) on the grounds that some devices might support other formats much more easily, and that HTML has historically not required particular formats for anything.[13]

Some web developers criticized the removal of the Ogg formats from the specification.[14] A follow-up discussion also occurred on the W3C questions and answers blog.[15]

Mozilla and Opera support only the open formats of Theora and WebM. Google stated its intention to remove support for H.264 in 2011, specifically for the HTML5 video tag.[16] Although it has been removed from Chromium, (As of January 2021) it has yet to be removed from Google Chrome ten years later.[17][18]

MPEG-DASH Support via the HTML5 Media Source Extensions (MSE)

The adaptive bitrate streaming standard MPEG-DASH can be used in Web browsers via the HTML5 Media Source Extensions (MSE)[19] and JavaScript-based DASH players. Such players are, e.g., the open-source project dash.js[19] of the DASH Industry Forum, but there are also products such as the HTML5 Video Player of Bitmovin[20] (using HTML5 with JavaScript, but also a Flash-based DASH players for legacy Web browsers not supporting the HTML5 MSE).

Google's purchase of On2

Google's acquisition of On2 in 2010 resulted in its acquisition of the VP8 video format. Google has provided a royalty-free license to use VP8.[21] Google also started WebM, which combines the standardized open source VP8 video codec with Vorbis audio in a Matroska based container. The opening of VP8 was welcomed by the Free Software Foundation.[22]

When Google announced in January 2011 that it would end native support of H.264 in Chrome,[23] criticism came from many quarters including Peter Bright of Ars Technica[24] and Microsoft web evangelist Tim Sneath, who compared Google's move to declaring Esperanto the official language of the United States.[25] However, Haavard Moen of Opera Software strongly criticized the Ars Technica article[26] and Google responded to the reaction by clarifying its intent to promote WebM in its products on the basis of openness.[16]

After the launch of WebM, Mozilla and Opera have called for the inclusion of VP8 in HTML.[27]

On 7 March 2013, Google Inc. and MPEG LA, LLC announced agreements covering techniques that "may be essential" to VP8, with Google receiving a license from MPEG LA and 11 patent holders, and MPEG LA ending its efforts to form a VP8 patent pool.[28][29][30][31]

In 2012, VP9 was released by Google as a successor to VP8, also open and royalty free.

At the end of 2017 the new AV1 format developed by the Alliance for Open Media (AOMedia) as the evolution of VP9 has reached the feature freeze, and the bitstream freeze is expected for January 2018. Firefox nightly builds already include support for AV1.[32]

Non-free formats

H.264/MPEG-4 AVC is widely used, and has good speed, compression, hardware decoders, and video quality, but is patent-encumbered.[33] Users of H.264 need licenses either from the individual patent holders, or from the MPEG LA, a group of patent holders including Microsoft and Apple, except for some Internet broadcast video uses.[34] H.264 is usually used in the MP4 container format, together with Advanced Audio Coding (AAC) audio. AAC is also covered by patents in itself, so users of MP4 will have to license both H.264 and AAC.

In June 2009, the WHATWG concluded that no existing format was suitable as a specified requirement.[35]

Apple still only supports H.264, but Microsoft now supports VP9 and WebM, and has pledged support for AV1.

Cisco makes a licensed H.264 binary module available for free

Main page: Software:OpenH264

On 30 October 2013, Cisco announced that it was making a binary H.264 module available for download. Cisco will pay the costs of patent licensing for those binary modules when downloaded by the using software while it is being installed, making H.264 free to use in that specific case.[36]

In the announcement, Cisco cited its desire of furthering the use of the WebRTC project as the reason, since WebRTC's video chat feature will benefit from having a video format supported in all browsers.[37] The H.264 module will be available on "all popular or feasibly supportable platforms, which can be loaded into any application".[38]

Cisco is also planning to publish source code for those modules under BSD license, but without paying the royalties,[36] so the code will practically be free software only in countries without H.264 software patents, which has already been true about other existing implementations.

Also on 30 October 2013, Mozilla's Brendan Eich announced that Firefox would automatically download Cisco's H.264 module when needed by default. He also noted that the binary module is not a perfect solution, since users do not have full free software rights to "modify, recompile, and redistribute without license agreements or fees". Thus Xiph and Mozilla continue the development of Daala.[38][39]

OpenH264 only supports the baseline profile of H.264, and does not by itself address the need for an AAC decoder. Therefore, it is not considered sufficient for typical MP4 web video, which is typically in the high profile with AAC audio.[40][41][42] However, for use in WebRTC, the omission of AAC was justified in the release announcement: "the standards bodies have aligned on Opus and G.711 as the common audio codecs for WebRTC".[37] There is doubt as to whether a capped global licensing of AAC, like Cisco's for H.264, is feasible after AAC's licensing bureau removed the price cap shortly after the release of OpenH264.[43]

Browser support

This table shows which video formats are likely to be supported by a given user agent. Most of the browsers listed here use a multimedia framework for decoding and display of video, instead of incorporating such software components. It is not generally possible to tell the set of formats supported by a multimedia framework without querying it, because that depends on the operating system and third party codecs.[44] In these cases, video format support is an attribute of the framework, not the browser (or its layout engine), assuming the browser properly queries its multimedia framework before rejecting unknown video formats. In some cases, the support listed here is not a function of either codecs available within the operating system's underlying media framework, or of codec capabilities built into the browser, but rather could be by a browser add-on that might, for example, bypass the browser's normal HTML parsing of the <video> tag to embed a plug-in based video player.

Note that a video file normally contains both video and audio content, each encoded in its own format. The browser has to support both the video and audio formats. See HTML5 audio for a table of which audio formats are supported by each browser.

The video format can be specified by MIME type in HTML (see example). MIME types are used for querying multimedia frameworks for supported formats.[45]

Of these browsers, only Firefox and Opera employ libraries for built-in decoding. In practice, Internet Explorer and Safari can also guarantee certain format support, because their manufacturers also make their multimedia frameworks. At the other end of the scale, Konqueror has identical format support to Internet Explorer when run on Windows, and Safari when run on Mac, but the selected support here for Konqueror is the typical for Linux, where Konqueror has most of its users. In general, the format support of browsers is much dictated by conflicting interests of vendors, specifically that Media Foundation and QuickTime support commercial standards, whereas GStreamer and Phonon cannot legally support other than free formats by default on the free operating systems that they are intended for.[46]

Status of video format support in each web browser
Browser Operating System Theora (Ogg) H.264 (MP4) HEVC (MP4) VP8 (WebM) VP9 (WebM) AV1 (WebM)
Android browser Android Since 2.3[47] Since 3.0[47] Since 5.0[47] Since 2.3[47] Since 4.4[47] Since 10
Chromium Unix-like and Windows Since r18297[48] Via FFmpeg[49][50] No[51] Since r47759[52] Since r172738[53] Yes
Google Chrome Unix-like, Android, macOS, and Windows Since 3.0[54][55] Since 3.0[55][lower-alpha 1] Since 105 (software decoding; needs OS-level codecs)

Since 107 (hardware decoding; needs hardware decoder)

[57][58]
Since 6.0[59][60] Since 29.0[lower-alpha 2] Since 70[63]
Internet Explorer Windows Via OpenCodecs Since 9.0[64] No[65] Via OpenCodecs No No
Windows Phone No Since 9.0[66] No
Windows RT Since 10.0[66]
Microsoft Edge Unix-like, macOS and Windows

(Chromium)

Since v79[67][68] Since v79 (only browser to support DRM PlayReady)[67][69] No[65] Since v79[67][70] Since v79[67][70] Since v79[67]
Windows 10 (Legacy EdgeHTML) Since 17.0 (with Web Media Extensions)[71][72][73] Since 12.0[74] Needs hardware decoder[lower-alpha 3] Since 17.0 (supports <video> tag with Web Media Extensions and VP9 Video Extensions)[72] Only enabled by default if hardware decoder present[77]

Since 17.0 (supports <video> tag with Web Media Extensions and VP9 Video Extensions)[71][72][73]

Since 18.0 (with AV1 Video Extension)[78]
Windows 10 Mobile No Since 13.0[79] Since 15.0 (only via MSE)[80] Since 14.0 (only via MSE)[81] No
Konqueror Unix-like and Windows Needs OS-level codecs[lower-alpha 4]
Mozilla Firefox Windows 7+ Since 3.5[82] Since 21.0[lower-alpha 5] No[65] Since 4.0[85] Since 28.0[86][87] Since 65.0 (64-bit)[88]
Since 66.0 (32-bit)[89]
Windows Vista Since 22.0[90]
Windows XP and N editions Since 46.0[91]
Linux 26.0 (via GStreamer)[lower-alpha 6]
43.0 (via FFmpeg)[94]
Android Since 17.0[95]
macOS Since 34.0[96] Since 66.0[89]
Firefox OS Since 1.1[97] No
Opera Mobile Android, iOS, Symbian, and Windows Mobile Since 13.0 Since 11.50 No[98] Since 15.0 Since 16.0 since 57.0[63]
Opera macOS, Windows, Linux Since 10.50[99] Since 24.0[100] Since 10.60[101][102] Yes since 57.0[63]
Safari iOS No Since 3.1[103] Since 11[104] Since 12.1 (only supports WebRTC)[105] Since 14 (only supports WebRTC)[106] No
macOS Via Xiph QuickTime Components (macOS 10.11 and earlier)
GNOME Web Linux and BSD Needs OS-level codecs[lower-alpha 7]

Values

These indicate the level of support for the given item in each engine. By default, the most recent version of the engine is implied. However, a specific version number can be listed; when this indicates full support, it's the initial version of the engine fully supporting the item.

Value Meaning
Yes Fully supported
No Has never been supported
Partial Only some values are supported
Incorrect Not implemented correctly in all cases
Experimental May be incomplete or buggy
Nightly build Currently in development; full support is expected
Depends Only supported for the specified conditions
Dropped No longer supported
Notes
  1. On 11 January 2011 the removal of support for H.264 was announced on Chromium Blog.[56] (As of November 2016) neither actual support was removed, nor the change to this plan was announced.
  2. VP9 support in 25, turned off by default.[61] Enabled by default in version 29.[62]
  3. Available if the device has hardware support for HEVC.[75] No software decoding support was included because "HEVC is very computationally complex, this will provide a more consistent experience."[76]
  4. Any format supported by Phonon backend. Available Phonon backends include DirectShow, QuickTime, GStreamer and xine; backends using MPlayer and VLC are in development.
  5. As of version 20, prefed off by default.[83] Enabled by default beginning in version 21.[84]
  6. Disabled by default until version 26.[92] Also, depends on the codec on the system.[93]
  7. Any format supported by GStreamer on Webkit/GTK+.[107] The support for Ogg Theora, WebM and h.264 formats is included with base, good, and bad plugins respectively.[108]

Transparent video

Transparent video, that is video with an alpha channel, has multiple design advantages:[109]

  • As it has no burnt-in background color / pattern / motif, you can change the background and/or neighboring objects in a web page any time later without the need to re-generate the video to fit into its surroundings properly, which was the far less flexible technique so far.
  • You can very flexibly combine transparent videos with other elements (text, graphics, other videos or dynamically rendered content such as SVG or canvas) to achieve very dynamic layering effects.
  • It opens a whole lot of possibilities also in terms of responsive web design.

Web browser support for videos with alpha channel

Earlier solutions

  • Before the HTML5 era the only way to play back transparent video was by the help of Adobe Flash Player[112] and using the transparent [113] flag in its embedding code.

Digital rights management (Encrypted Media Extensions)

Main page: Encrypted Media Extensions

HTML has support for digital rights management (DRM, restricting how content can be used) via the HTML5 Encrypted Media Extensions (EME). The addition of DRM is controversial because it allows restricting users' freedom to use media restricted by DRM, even where fair use gives users the legal right to do so.[114] A main argument in W3C's approval of EME was that the video content would otherwise be delivered in plugins and apps, and not in the web browser.[115]

In 2013 Netflix added support for HTML5 video using EME, beside their old delivery method using a Silverlight plugin (also with DRM).[116]

Usage

In 2010, in the wake of Apple iPad launch and after Steve Jobs announced that Apple mobile devices would not support Flash, a number of high-profile sites began to serve H.264 HTML5 video instead of Adobe Flash for user-agents identifying as iPad.[117] HTML5 video was not as widespread as Flash videos, though there were rollouts of experimental HTML5-based video players from DailyMotion (using Ogg Theora and Vorbis format),[118] YouTube (using the H.264 and WebM formats),[119] and Vimeo (using the H.264 format).[120]

Support for HTML5 video has been steadily increasing. In June 2013, Netflix added support for HTML5 video.[121] In January 2015, YouTube switched to using HTML5 video instead of Flash by default.[122] In December 2015, Facebook switched from Flash to HTML5 for all video content.[123]

As of 2016, Flash is still widely installed on desktops, while generally not being supported on mobile devices such as smartphones.[124] The Flash plugin is widely assumed, including by Adobe,[124][125] to be destined to be phased out,[126][127] which will leave HTML5 video as the only widely supported method to play video on the World Wide Web. Chrome,[128][129] Firefox,[130] Safari,[131] and Edge,[132] have plans to make almost all flash content click to play in 2017. The only major browser which does not have announced plans to deprecate Flash is Internet Explorer.[133] Adobe announced on 25 July 2017 that they would be permanently ending development of Flash in 2020.[134]

See also

References

  1. "The video element". HTML5: A vocabulary and associated APIs for HTML and XHTML. World Wide Web Consortium. 24 June 2010. http://www.w3.org/TR/html5/video.html#video. "A video element is used for playing videos or movies." 
  2. "[whatwg How not to fix HTML from Charles Iliya Krempeaux on 2006-10-30 (whatwg@whatwg.org from October 2006)"]. https://lists.w3.org/Archives/Public/public-whatwg-archive/2006Oct/0189.html. 
  3. van Kesteren, Anne (28 February 2007). "[whatwg] <video> element proposal". What Working Group (Mailing list). Retrieved 10 April 2010.
  4. "Browser War: Episode II – Attack of the DOMs". http://browserwarii.eventbrite.com/. 
  5. "SV Web Builders Event – World Premier of Opera with builtin video support". March 1, 2007. http://coolastory.blogspot.com/2007/03/sv-web-builders-event-world-premier-of.html. 
  6. "A Call for Video on the Web". http://people.opera.com/howcome/2007/video/. 
  7. "The "codecs" parameter in common media types". https://developer.mozilla.org/en-US/docs/Web/Media/Formats/codecs_parameter. 
  8. Hickson, Ian (10 December 2007). "Video codec requirements changed". What WG (Mailing list). Archived from the original on 19 February 2012. Retrieved 25 February 2008.
  9. "(X)HTML5 Tracking". HTML5. http://html5.org/tools/web-apps-tracker?from=1142&to=1143. 
  10. Amador, Manuel (11 December 2011). "Removal of Ogg is *preposterous*". WHATWG (Mailing list). Archived from the original on 21 August 2008. Retrieved 25 August 2009.
  11. Metz, Cade (April 30, 2010). "Steve Jobs: mystery patent pool to attack Ogg Theora". The Register. https://www.theregister.co.uk/2010/04/30/steve_jobs_claims_ogg_theora_attack/. 
  12. Hickson, Ian (11 December 2007). "Re: Removal of Ogg is *preposterous*". WHATWG (Mailing list). Archived from the original on 21 August 2008. Retrieved 25 February 2008.
  13. 13.0 13.1 Stachowiak, Maciej (21 March 2007). "Codecs (was Re: Apple Proposal for Timed Media Elements)". WHATWG (Mailing list).
  14. "[whatwg] Removal of Ogg is *preposterous*". WHATWG (Mailing list). 11 December 2007. Archived from the original on 21 August 2008. Retrieved 25 August 2009.
  15. Connolly, Dan (18 December 2007). "When will HTML 5 support <video>? Sooner if you help". W3C. http://www.w3.org/QA/2007/12/when_will_html_5_support_soone.html. 
  16. 16.0 16.1 Jazayeri, Michael 'Mike' (14 January 2011). "More about the Chrome HTML Video Codec Change". Chromium blog. https://blog.chromium.org/2011/01/more-about-chrome-html-video-codec.html. 
  17. Shankland, Stephen (14 March 2012). "Mozilla execs capitulate in H.264 Web-video war". CNET. http://news.cnet.com/8301-30685_3-57397031-264/mozilla-execs-capitulate-in-h.264-web-video-war/. 
  18. Hoffman, Chris (9 September 2015). "Why YouTube in Chrome (and Firefox) is Draining Your Laptop's Battery and How to Fix It". Howtogeek. http://www.howtogeek.com/227940/why-youtube-in-chrome-and-firefox-is-draining-your-laptop%E2%80%99s-battery-and-how-to-fix-it/. 
  19. 19.0 19.1 "Media Source Extensions". July 26, 2022. https://dvcs.w3.org/hg/html-media/raw-file/tip/media-source/media-source.html. 
  20. "Adaptive Streaming HTML5 Player from Bitmovin". 20 April 2022. https://bitmovin.com/video-player. 
  21. "Additional IP Rights Grant (Patents)". http://www.webmproject.org/license/additional/. 
  22. Lee, Matt (19 May 2010). "Free Software Foundation statement on WebM and VP8". FSF. http://www.fsf.org/news/free-software-foundation-statement-on-webm-and-vp8. 
  23. Jazayeri, Michael 'Mike' (January 11, 2011). "HTML Video Codec Support in Chrome". The Chromium Blog. https://blog.chromium.org/2011/01/html-video-codec-support-in-chrome.html. 
  24. Bright, Peter (12 January 2011). "Google's dropping H.264 from Chrome a step backward for openness". Ars Technica. https://arstechnica.com/web/news/2011/01/googles-dropping-h264-from-chrome-a-step-backward-for-openness.ars/. 
  25. Sneath, Tim (11 January 2011). "An Open Letter from the President of the United States of Google". MSDN blogs. http://blogs.msdn.com/b/tims/archive/2011/01/11/an-open-letter-from-the-president-of-the-united-states-of-google.aspx. 
  26. Moen, Haavard K (13 January 2011). "Is the removal of H.264 from Chrome a step backward for openness?". My Opera. http://my.opera.com/haavard/blog/2011/01/13/openness. 
  27. Metz, Cade (28 May 2010). "Mozilla and Opera call for Google open codec in HTML5 spec". The Register. https://www.theregister.co.uk/2010/05/28/mozilla_and_opera_want_vp8_in_html5/. 
  28. djwm (7 March 2013). "Google and MPEG LA make a deal over VP8 codec – Update". The H Open. Heise Media UK. http://www.h-online.com/open/news/item/Google-and-MPEG-LA-make-a-deal-over-VP8-codec-Update-1818785.html. 
  29. "Archived copy". http://www.mpegla.com/Lists/MPEG%20LA%20News%20List/Attachments/88/n-13-03-07.pdf. 
  30. "VP8 and MPEG LA". WebM Project blog. 7 March 2013. http://blog.webmproject.org/2013/03/vp8-and-mpeg-la.html. 
  31. "Patent clouds remain over VP8: Google points to FRAND option, Nokia alleges infringement in court". March 8, 2013. http://www.fosspatents.com/2013/03/patent-clouds-remain-over-vp8-google.html. 
  32. Shankland, Stephen (28 November 2017). "Firefox now lets you try streaming-video tech that could be better than Apple's" (in en). CNET. https://www.cnet.com/news/firefox-av1-challenges-apple-hevc-for-4k-friendly-video/. 
  33. "AVC/H.264 Patent List". MPEG LA. 1 February 2010. http://www.mpegla.com/main/programs/avc/Documents/avc-att1.pdf. 
  34. AVC/H.264 Licensors, MPEG LA, http://www.mpegla.com/main/programs/AVC/Pages/Licensors.aspx, retrieved 13 April 2010 
  35. Hickson, Ian (29 June 2009). "Codecs for <audio> and <video>". WHATWG (Mailing list).
  36. 36.0 36.1 "OpenH264". http://www.openh264.org/faq.html. 
  37. 37.0 37.1 "Open-Sourced H.264 Removes Barriers to WebRTC". Cisco. 30 October 2013. http://blogs.cisco.com/collaboration/open-source-h-264-removes-barriers-webrtc. 
  38. 38.0 38.1 Brendan Eich (30 October 2013). "Cisco's H.264 Good News". Brendan Eich's blog. https://brendaneich.com/2013/10/ciscos-h-264-good-news/. 
  39. Monty Montgomery. "Comments on Cisco, Mozilla, and H.264". Monty Montgomery blog. http://xiphmont.livejournal.com/61927.html. 
  40. Gal, Andreas (14 October 2014). "OpenH264 now in Firefox". https://andreasgal.com/2014/10/14/openh264-now-in-firefox/. 
  41. "MediaSourceExtensions (mozilla wiki)". mozilla. https://wiki.mozilla.org/Platform/MediaSourceExtensions. 
  42. "Support H.264/AAC/MP3 video/audio playback on desktop Firefox". mozilla. https://bugzilla.mozilla.org/show_bug.cgi?id=799318#c57. 
  43. xiphmont. "It's not a strawman after it comes true". http://xiphmont.livejournal.com/63152.html. 
  44. "Phonon documentation of backends", Qt, Nokia, http://doc.qt.nokia.com/latest/phonon-overview.html#backends, retrieved 3 June 2011 
  45. "Phonon documentation of querying", Qt, Nokia, http://doc.qt.nokia.com/latest/phonon-overview.html#querying-backends-for-support, retrieved 3 June 2011 
  46. GNU General Public License Version 3, Free Software Foundation, 29 June 2007, https://www.gnu.org/licenses/gpl.html, retrieved 27 April 2013 
  47. 47.0 47.1 47.2 47.3 47.4 "Android Core media format and codec support.". http://developer.android.com/guide/appendix/media-formats.html. 
  48. Issue 4363: [HTML5-Video Enable HTML5 video/audio elements], https://code.google.com/p/chromium/issues/detail?id=4363, retrieved 10 September 2010 
  49. enable proprietary_codecs h.264, https://groups.google.com/a/chromium.org/forum/#!topic/chromium-dev/44tOScNK9Lc, retrieved 30 April 2016 
  50. Chromium does not support H.264, 9 June 2015, http://blog.ruofeidu.com/chromium-does-not-support-h-264/, retrieved 30 April 2016 
  51. Audio/Video – The Chromium Projects, https://www.chromium.org/audio-video, retrieved 21 March 2016 
  52. "Issue 2093007: Chromium side changes for enabling VP8 and WebM support", Code review, https://codereview.chromium.org/2093007, retrieved 10 September 2010 
  53. "[chrome Revision 172738"]. https://src.chromium.org/viewvc/chrome?view=rev&revision=172738. 
  54. "Google Chrome support Theora and Vorbis", Code, 20 May 2010, https://code.google.com/p/chromium/wiki/ChromiumBrowserVsGoogleChrome 
  55. 55.0 55.1 "Chrome 3.0 supportera la balise vidéo du HTML 5" (in fr). http://www.cnetfrance.fr/news/google-chrome-3-39503164.htm. 
  56. Mike, Jazayeri (11 January 2011). "Chromium Blog: HTML Video Code Support in Chrome". The Chromium Blog. https://blog.chromium.org/2011/01/html-video-codec-support-in-chrome.html. 
  57. "Google Chrome Plays HEVC: What Does it Mean? - Streaming Media". https://www.streamingmedia.com/Articles/Editorial/Featured-Articles/Google-Chrome-Plays-HEVC-What-Does-it-Mean-155572.aspx. 
  58. "Google Quietly Added HEVC Support in Chrome - Bitmovin". https://bitmovin.com/google-adds-hevc-support-chrome/. 
  59. Bankoski, Jim (19 May 2010). "WebM and VP8 land in Chromium". https://blog.chromium.org/2010/05/webm-and-vp8-land-in-chromium.html. 
  60. Kersey, Jason (3 June 2010), "Dev Channel Update", Chrome Releases, http://googlechromereleases.blogspot.com/2010/06/dev-channel-update.html, retrieved 1 July 2010 
  61. Lucian Parfeni (28 December 2012). "Chrome Adds Support for the Next-Generation VP9 Video Codec and Mozilla's Opus Audio". http://webscripts.softpedia.com/blog/Chrome-Adds-Support-for-the-Next-Generation-VP9-Video-Codec-and-Mozilla-s-Opus-Audio-317728.shtml. 
  62. Lucian Parfeni (17 June 2013). "Chrome Now Supports Google's Next-Gen VP9 Video Codec by Default". http://webscripts.softpedia.com/blog/Chrome-Now-Supports-Google-Next-Gen-VP9-Video-Codec-by-Default-361550.shtml. 
  63. 63.0 63.1 63.2 "AV1 Decode". https://www.chromestatus.com/feature/5729898442260480. 
  64. McCracken, Harry (16 March 2010), Microsoft Previews the Revamped Internet Explorer 9 Platform, Technologizer, http://technologizer.com/2010/03/16/ie9-platform-preview/ 
  65. 65.0 65.1 65.2 Jan Ozer (5 November 2014). "Apple Supports H.265, But So Far Only in FaceTime on an iPhone 6". http://www.streamingmedia.com/Articles/News/Online-Video-News/Apple-Supports-H.265-But-So-Far-Only-in-FaceTime-on-an-iPhone-6-100392.aspx. 
  66. 66.0 66.1 HTML5 Video Support in IE9 Mobile, Microsoft, 13 October 2011, http://blogs.windows.com/windows_phone/b/wpdev/archive/2011/10/13/html5-video-support-in-ie9-mobile.aspx, retrieved 11 March 2014 
  67. 67.0 67.1 67.2 67.3 67.4 Blog, Microsoft Edge (2020-01-15). "Upgrading to the new Microsoft Edge" (in en-US). https://blogs.windows.com/msedgedev/2020/01/15/upgrading-new-microsoft-edge-79-chromium/. 
  68. "Can I use... Support tables for HTML5, CSS3, etc". https://caniuse.com/ogv. 
  69. "Can I use... Support tables for HTML5, CSS3, etc". https://caniuse.com/mpeg4. 
  70. 70.0 70.1 "Can I use... Support tables for HTML5, CSS3, etc". https://caniuse.com/webm. 
  71. 71.0 71.1 "Introducing the Web Media Extension Package with OGG Vorbis and Theora support for Microsoft Edge". Microsoft. 5 December 2017. https://blogs.windows.com/msedgedev/2017/12/05/introducing-web-media-extension-package-ogg-vorbis-theora-support/. 
  72. 72.0 72.1 72.2 "HTML5test - How well does your browser support HTML5?". http://html5test.com/compare/browser/edge-17.html. 
  73. 73.0 73.1 "Redstone 4 Brings Better WebM Support in Edge". 11 April 2018. https://www.petri.com/redstone-4-brings-better-webm-support-in-edge. 
  74. "HTML5test – How well does your browser support HTML5?". http://html5test.com/compare/browser/edge-12.html. 
  75. "HEVC Support". https://wpdev.uservoice.com/forums/257854-microsoft-edge-developer/suggestions/10311075-hevc-support. 
  76. "Windows 10 HEVC playback – Yes or No?". https://answers.microsoft.com/en-us/insider/forum/insider_apps-insider_wmp/windows-10-hevc-playback-yes-or-no/3c1ab780-a6b2-4b77-ac0f-9faeefd4680d. 
  77. "The status of VP9 Video Playback in Microsoft Edge is Shipped - Microsoft Edge Development". https://developer.microsoft.com/en-us/microsoft-edge/platform/status/vp9videoplayback/. 
  78. "Add AV1 Codec Support to Windows 10 – Tutorials". https://www.tenforums.com/tutorials/121440-add-av1-codec-support-windows-10-a.html. 
  79. "HTML5test – How well does your browser support HTML5?". http://html5test.com/compare/browser/edge.mobile-13.html. 
  80. "Introducing WebRTC 1.0 and interoperable real-time communications in Microsoft Edge". February 2017. https://blogs.windows.com/msedgedev/2017/01/31/introducing-webrtc-microsoft-edge/. 
  81. "WebM, VP9 and Opus Support in Microsoft Edge". Microsoft Edge Dev Blog. Microsoft. 18 April 2016. https://blogs.windows.com/msedgedev/2016/04/18/webm-vp9-and-opus-support-in-microsoft-edge. 
  82. "Mozilla Firefox 3.5 Release Notes". Mozilla. 30 June 2009. https://website-archive.mozilla.org/www.mozilla.org/firefox_releasenotes/en-US/firefox/3.5/releasenotes/. 
  83. Bug 799315 – Windows Media Foundation backend for media playback, Mozilla, https://bugzilla.mozilla.org/show_bug.cgi?id=799315, retrieved 21 December 2012 
  84. Bug 837859 – Enable WMF backend, Mozilla, https://bugzilla.mozilla.org/show_bug.cgi?id=837859, retrieved 5 April 2013 
  85. "Mozilla Firefox 4.0 Release Notes". Mozilla. 22 March 2011. https://website-archive.mozilla.org/www.mozilla.org/firefox_releasenotes/en-US/firefox/4.0/releasenotes/. 
  86. [Phoronix Mozilla Firefox Enables VP9 Video Codec By Default], Phoronix, https://www.phoronix.com/scan.php?page=news_item&px=MTUzODA, retrieved 8 December 2013 
  87. "Firefox – Notes (28.0)". https://www.mozilla.org/en-US/firefox/28.0/releasenotes/. 
  88. "Firefox 65.0, See All New Features, Updates and Fixes". Mozilla Foundation. 29 January 2019. https://www.mozilla.org/en-US/firefox/65.0/releasenotes/. 
  89. 89.0 89.1 "Firefox 66.0, See All New Features, Updates and Fixes". Mozilla Foundation. 19 March 2019. https://www.mozilla.org/en-US/firefox/66.0/releasenotes/. 
  90. Bug 825153 – Add support for Windows Vista WMF and prepend the system32 directory path to dll names, Mozilla, https://bugzilla.mozilla.org/show_bug.cgi?id=825153, retrieved 28 March 2013 
  91. Bug 1250766 – Re-enable using Adobe GMP for decoding when system H.264/AAC codecs not available, Mozilla, https://bugzilla.mozilla.org/show_bug.cgi?id=1250766, retrieved 30 April 2016 
  92. Bug 886181 – Pref on gstreamer backend, Mozilla, https://bugzilla.mozilla.org/show_bug.cgi?id=886181, retrieved 21 September 2013 
  93. Bug 794282 – Enable GStreamer in official builds, Mozilla, https://bugzilla.mozilla.org/show_bug.cgi?id=794282, retrieved 23 June 2013 
  94. Bug 1207429 – Enable FFMpeg by default, Mozilla, https://bugzilla.mozilla.org/show_bug.cgi?id=1207429, retrieved 30 October 2015 
  95. "Mozilla ships Firefox with H.264 support on Android". Ars Technica. 30 November 2012. https://arstechnica.com/information-technology/2012/11/mozilla-ships-firefox-with-h-264-support-on-android/. 
  96. Bug 1070703 – Add mp4 support in 10.6 and 10.7 on Aurora, Mozilla, https://bugzilla.mozilla.org/show_bug.cgi?id=1070703, retrieved 2 October 2014 
  97. "H.264 support in Firefox". https://developer.mozilla.org/en-US/Apps/Build/Audio_and_video_delivery/H.264_support_in_Firefox. 
  98. Ozer, Jan (26 November 2014). "The Case for VP9 – Streaming Media Magazine". http://www.streamingmedia.com/Articles/Editorial/Featured-Articles/The-Case-for-VP9-100833.aspx. 
  99. Jägenstedt, Philip (31 December 2009), "(re-)Introducing <video>" (official blog), Core developers (Opera), http://my.opera.com/core/blog/2009/12/31/re-introducing-video, retrieved 6 February 2010 
  100. "Changelog for 24 – Opera Desktop". http://blogs.opera.com/desktop/changelog-24/. 
  101. Lie, Håkon Wium (19 May 2010), Welcome, WebM <video>!, Opera, http://labs.opera.com/news/2010/05/19/ 
  102. Mills, Chris (19 May 2010), Opera supports the WebM video format, Opera, http://dev.opera.com/articles/view/opera-supports-webm-video/ 
  103. "Media formats supported by the HTML audio and video elements". Mozilla. https://developer.mozilla.org/en-US/docs/Web/HTML/Supported_media_formats. 
  104. Martin Smole (6 June 2017). "WWDC17 – HEVC with HLS – Apple just announced a feature that we support out of the box". https://bitmovin.com/wwdc17-hevc-hls-apple-just-announced-feature-support-box/. 
  105. "Safari 12.1 Release Notes | Apple Developer Documentation". https://developer.apple.com/documentation/safari_release_notes/safari_12_1_release_notes. 
  106. " "Release Notes for Safari Technology Preview 110". 16 July 2020. https://webkit.org/blog/10929/release-notes-for-safari-technology-preview-110/". 
  107. Persch, Christian (1 April 2008), "The Future of Epiphany" (announcement), epiphany mailing list-list, http://mail.gnome.org/archives/epiphany-list/2008-April/msg00000.html 
  108. "Overview of available plug-ins", GStreamer, http://gstreamer.freedesktop.org/documentation/plugins.html, retrieved 4 July 2012 
  109. "How to use transparent videos on the web in 2022 - Rotato" (in en). https://rotato.app/blog/transparent-videos-for-the-web. "This blog showcases various use cases of transparent videos in web design, besides advertising their own software product, Rotato." 
  110. "Alpha transparency in Chrome video" (in en). July 2013. https://developer.chrome.com/blog/alpha-transparency-in-chrome-video/. "Chrome 31 now supports video alpha transparency in WebM. In other words, Chrome takes the alpha channel into account when playing green screen videos encoded to WebM (VP8 and VP9) with an alpha channel. This means you can play videos with transparent backgrounds: over web pages, images or even other videos." 
  111. "HEVC Video with Alpha - WWDC19 - Videos" (in en). https://developer.apple.com/videos/play/wwdc2019/506/. 
  112. "Create transparent backgrounds in a SWF file". https://helpx.adobe.com/animate/kb/transparent-background-swf-file.html. "The background color (Stage color) of a SWF file can be set to transparent. The background color or image of the HTML page that contains the SWF file shows through. This technique allows layering of SWF content with DHTML (Dynamic HTML) content. Not every web browser handles transparency in the same way. Be sure to test your SWF file in all browsers that you want to enable your audience to use. Most Linux browsers do not support Animate transparency." 
  113. "Apply OBJECT and EMBED tag attributes in Adobe Flash Professional". https://helpx.adobe.com/flash/kb/flash-object-embed-tag-attributes.html. "transparent — The SWF content is layered together with other HTML elements on the page. The SWF file background color (Stage color) is transparent. HTML elements beneath the SWF file are visible through any transparent areas of the SWF, with alpha blending. This option reduces playback performance compared to wmode=window or wmode=direct." 
  114. "Keep DRM out of Web standards – Reject the Encrypted Media Extensions (EME) proposal – Defective by Design". http://www.defectivebydesign.org/sign-on-against-drm-in-html. 
  115. Yegulalp, Serdar (4 October 2013). "Berners-Lee and W3C approve HTML5 video DRM additions". http://www.infoworld.com/article/2612478/html5/berners-lee-and-w3c-approve-html5-video-drm-additions.html?page=2. 
  116. "HTML5 Video at Netflix". Medium (Netflix Technology Blog). April 15, 2013. https://netflixtechblog.com/html5-video-at-netflix-721d1f143979. 
  117. "iPad-ready websites". Apple. https://www.apple.com/ipad/ready-for-ipad/. 
  118. "Watch Video...without Flash". Dailymotion. 27 May 2009. https://blog.dailymotion.com/en/watch-videowithout-flash/. 
  119. Carle, Kevin; Zacharias, Chris (20 January 2010). "Introducing YouTube HTML5 Supported Videos". Youtube. https://blog.youtube/news-and-events/introducing-youtube-html5-supported/. 
  120. Dougherty, Brad (21 January 2010). "Try our new HTML5 player!". Vimeo. http://vimeo.com/blog:268. 
  121. Anthony, Sebastian (28 June 2013). "Netflix switches from Silverlight to HTML5 in Windows 8.1, reduces CPU usage dramatically – ExtremeTech". http://www.extremetech.com/computing/159960-netflix-switches-from-silverlight-to-html5-in-windows-8-1-reduces-cpu-usage-dramatically. 
  122. McCormick, Rich (27 January 2015). "YouTube drops Flash for HTML5 video as default". https://www.theverge.com/2015/1/27/7926001/youtube-drops-flash-for-html5-video-default. 
  123. Welch, Chris (18 December 2015). "Facebook's website now uses HTML5 instead of Flash for all videos". https://www.theverge.com/2015/12/18/10623738/facebook-now-using-html5-all-videos. 
  124. 124.0 124.1 Paul, Ryan (16 August 2012). "Availability of Adobe's Flash browser plugin discontinued on Android". https://arstechnica.com/information-technology/2012/08/availability-of-adobes-flash-browser-plugin-discontinued-on-android/. 
  125. Tittel, Chris Minnick and Ed (30 April 2014). "How Adobe Is Moving on From Flash to Embrace HTML5". http://www.cio.com/article/2376661/internet/how-adobe-is-moving-on-from-flash-to-embrace-html5.html. 
  126. Williams, Owen (1 September 2015). "Adobe Flash is finally dead". TNW | Apps. https://thenextweb.com/apps/2015/09/01/adobe-flash-just-took-another-step-towards-death-thanks-to-google/. 
  127. Barrett, Brian (15 July 2015). "Flash. Must. Die.". Wired. https://www.wired.com/2015/07/adobe-flash-player-die/. 
  128. "Intent to implement: HTML5 by Default". May 9, 2016. https://groups.google.com/a/chromium.org/forum/#!searchin/chromium-dev/HTML5$20by$20default/chromium-dev/0wWoRRhTA_E/__E3jf40OAAJ. 
  129. "So long, and thanks for all the Flash". https://blog.chromium.org/2017/07/so-long-and-thanks-for-all-flash.html. 
  130. Smedberg, Benjamin (July 20, 2016). "Reducing Adobe Flash Usage in Firefox". https://blog.mozilla.org/futurereleases/2016/07/20/reducing-adobe-flash-usage-in-firefox/. 
  131. Mondello, Ricky (14 June 2016). "Next Steps for Legacy Plug-ins". Apple Inc. https://webkit.org/blog/6589/next-steps-for-legacy-plug-ins/. 
  132. Cowan, Crispin (14 December 2016). "Extending User Control of Flash with Click-to-Run". Microsoft. https://blogs.windows.com/msedgedev/2016/12/14/edge-flash-click-run/. 
  133. eross-msft. "Microsoft Edge and Internet Explorer 11 (Microsoft Edge for IT Pros)". https://technet.microsoft.com/en-us/itpro/microsoft-edge/enterprise-guidance-using-microsoft-edge-and-ie11. 
  134. "Flash & The Future of Interactive Content". https://blogs.adobe.com/conversations/2017/07/adobe-flash-update.html. 

External links