HTML5资讯

当前位置: HTML5技术网 > HTML5资讯 > 让Chrome的HTML5 video/audio tag支持更多种音视频格式

让Chrome的HTML5 video/audio tag支持更多种音视频格式

       随着HTML5的发展,今后会有越来越多的应用程序基于HTML5开发,多媒体应用程序也不例外,HTML5新增加的video/audio tag提供了在网页中直接播放音视频的能力而无需借助任何插件,因此可以用HTML5开发一个媒体播放器,网上也已经出现了不少HTML5播放器例如jPlayer。但目前各家浏览器支持的HTML5音视频格式种类很有限,比如IE9只支持H.264,Firefox只支持VP8和Theora。Google Chrome算是支持格式最全的,支持的视频格式包括H.264、VP8、Theora,音频包括Vorbis、MP3、AAC、WAV。这些格式对于播放网络在线音视频(不算flash)基本上足够了,但如果我们想播放本地音视频就会遇到很多不支持的格式,比如在中国很流行的rmvb视频,高清影片最常见的mkv、avi格式,这些格式目前所有浏览器都不支持,仅仅从这一点来看,目前基于HTML5的播放器还不可能代替象QQ影音、射手播放器这样的传统播放器。
       有没有可能自己给浏览器增加支持更多的音视频格式?分析Google开源浏览器Chromium后得知它的音视频解码是由FFmpeg提供的(代码在third_party\ffmpeg\),Chrome也是这样,所以完全可以给Chrome增加支持更多种类的音视频格式。
       Chrome中的媒体播放架构如下图所示:


       其中Pipeline是Google给Chrome开发的媒体框架引擎,HTML5 video/audio tag就是由这个引擎实现媒体播放的,FFmpeg在其中提供demuxer和decoder,因此要增加支持音视频格式主要修改FFmpeg就可以了。
       从Chromium的源码third_party\ffmpeg\chromium\config\Chrome\linux\ia32\config.h可以得知Chrome采用的FFmpeg的配置选项,在原有的配置选项后面添加如下选项:
--enable-decoder='rv10,rv20,rv30,rv40,cook,h263,h263i,mpeg4,msmpeg4v1,msmpeg4v2,msmpeg4v3,amrnb,amrwb,ac3,flv' --enable-demuxer='rm,mpegvideo,avi,avisynth,h263,aac,amr,ac3,flv,mpegts,mpegtsraw' --enable-parser='mpegvideo,rv30,rv40,h263,mpeg4video,ac3'
       用新的配置选项重新配置和编译FFmpeg,用生成的3个动态链接库avcodec-54.dll、avformat-54.dll、avutil-51.dll替换掉Chrome里面原来的,要注意用来编译FFmpeg的Chromium源码的版本要跟Chrome差不多,相差太大的话替换库后可能会造成Chrome无法正常运行。在Windows上编译FFmpeg的方法参见本人的另一篇文档《在Windows上编译Chromium中的FFmpeg》。
       这样修改FFmpeg后在Chrome中用HTML5 video/audio tag就可以播放更多格式的音视频了,大部分常见的mkv、avi、flv、mov、amr都可以播放了。但是rmvb仍然无法播放,用Visual Studio 2010跟踪后找到了原因,原来常见的rmvb电影视频编码是RV40,音频编码是COOK,这两种codec类型在Chrome中都未被定义,在解析rmvb的时候会认为是未知的codec类型(kUnknownVideoCodec和kUnknownAudioCodec),为此需要修改media\base\video_decoder_config.h和media\base\audio_decoder_config.h分别在里面的枚举类型VideoCodec和AudioCodec中增添这两种格式,然后还要修改media\ffmpeg\ffmpeg_common.cc,具体修改方法就不赘述了,一看代码就知道。这样修改以后Chrome的媒体引擎就可以识别RV40和COOK这两种格式了,常见的rmvb电影也可以播放了。
       可见要让Chrome能播放更多格式的音视频其实不难,当然目前只是第一步,还有不少问题,比如播放rmvb电影时一拖动进度条屏幕显示就乱了,要想把兼容性和稳定性做好就要下更多功夫了。

【让Chrome的HTML5 video/audio tag支持更多种音视频格式】相关文章

1. 让Chrome的HTML5 video/audio tag支持更多种音视频格式

2. IE10不支持WebGL,Chrome的HTML5游戏性能是其22倍

3. HTML5的视频格式之争

4. ITU 批准下一代高清视频格式 - H.265

5. 新技术再次提升了Chrome的JavaScript载入效率

6. Firefox实现HTML5音视频播放GStreamer后端支持

7. 神奇的HTML5:现在Chrome浏览器支持直接通过Gmail打开邮件链接

8. Chrome OS即将迎来扩展形式的HTML5屏保

9. Adobe证实新版chrome只支持HTML5技术

10. 谷歌推Chrome API支持HTML5实现本地离线数据存储与同步

本文来源:https://www.51html5.com/a2814.html

点击展开全部

﹝让Chrome的HTML5 video/audio tag支持更多种音视频格式﹞相关内容

「让Chrome的HTML5 video/audio tag支持更多种音视频格式」相关专题

其它栏目

也许您还喜欢