html5中video解码原理,HTML5 Video 实现浅析

HTML5 Video实现浅析

——基于android4.1browser

1.     基本结构

43892195_4

先上一张基本结构图,图中展示了webkit中与HTML5 Video实现相关的一些类。

1.1  DOM Tree

Video标签在webkit内部对应于HTMLVideoElement类,该类的功能并不多,大多数的功能都在其父类HTMLMediaElement中。

1.2  Render Tree

HTMLVideoElement和HTMLMediaElement分别对应的Render节点是RenderVideo和

RenderMedia。它们也一般的Render节点不同,它们只负责layout来确定位置信息,而并不需要绘制(虽然有paint函数,但实际并没

有调用到)。

1.3  Bridge

MediaPlayer类指的是WebKit中定义的MediaPlayer类(而不是系统定义的),它只是一个桥接类,相关功能交由MediaPlayerPrivateInterface类实现,并将某些反馈信息回调给HTMLMediaElement。

1.4  Player

按照webkit的一贯风格,MediaPlayerPrivateInterface只是一个基类,具体需要不同的平台来提供具体实现。

Android平台下为MediaPlayerPrivate类,它也是一个基类,分别由MediaPlayerVideoPrivate和

MediaPlayerAudioPrivate来实现。很显然,它们分别对应Video和Audio的实现。

上述是webkit内的类,下面再看看webkitporting之后外部的类结构:

43892195_5

可以看到,这些类大多数都是轻量级类,它们主要负责功能转发。最终实现类是android中的MediaPlayer类(请与前述

MediaPlayer区别开来)。至于该MediaPlayer再怎么实现

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值