Webkit中HTML5 Video的实现分析 (二) - MediaPlayerFactory & RenderVideo的绘制操作
来源:互联网 发布:眼睛是心灵的窗户知乎 编辑:程序博客网 时间:2024/05/16 09:36
MediaPlayerFactory像是一个解码库一样,初始化时,各个可用的播放器(MediaPlayerPrivate)向它注册。当需要解码时,由它给出一个合适的播放器(呼叫MediaPlayerPrivate::constructor, 即MediaPlayerPrivate::create)创建一个实例[由MediaPlayer:: loadWithNextMediaEngine执行])。所以MediaPlayer与MediaPlayerPrivate应当是一对一的关系。
在installedMediaEngines()会有一个静态的installed engines向量(Vector<MediaPlayerFactory*>),依据不同的OS,调用不同的MediaPlayerPrivateXXX的registerMediaEngine来注册新的Media Engine以支持不同的编码。如下图所示。
bestMediaEngineForTypeAndCodecs()在当视频的MIME type指定后,在MediaPlayer::loadWithNextMediaEngine中会调用它来获取合适的engine进行播放,否则直接使用nextMediaEngine()来获得播放有的engine.
详细的代码在MediaPlayer.cpp中。
以下是MediaPlayerPrivateQt的supportsType的代码片段:
- MediaPlayer::SupportsType MediaPlayerPrivateQt::supportsType(const String& mime, const String& codec)
- {
- if (!mime.startsWith("audio/") && !mime.startsWith("video/"))
- return MediaPlayer::IsNotSupported;
- ……
- if (QMediaPlayer::hasSupport(mime, codecListTrimmed) >= QtMultimediaKit::ProbablySupported)
- return MediaPlayer::IsSupported;
- return MediaPlayer::MayBeSupported;
- }
RenderVideo的绘制操作
RenderVideo在绘制时重点是得出正确的大小。主要函数包括calculateInstrinicSize来得出大小,updatePlayer依据当前缩放比例计算出新的大小尺寸,paintReplaced则依据metric进行绘制操作(得出一个rect,再传给player)。
下面是可能会涉及元素更新的流程:
其核心函数是calculateIntrinsicSize(): (所谓Intrinsic Size来自于CSS规范).
当paintReplaced函数(因为RenderVideo继承自RenderReplaced)拿到Instrinic Size后会着手计算绘制区域以便进行绘制:
实际的绘制都会交由Media Player处理,而Media Player则交由它的m_private,也就是具体的播放器来处理。
原文链接:http://blog.csdn.net/horkychen/article/details/7862440
- Webkit中HTML5 Video的实现分析 (二) - MediaPlayerFactory & RenderVideo的绘制操作
- Webkit中HTML5 Video的实现分析 (二) - MediaPlayerFactory & RenderVideo的绘制操作
- Webkit中HTML5 Video的实现分析 (二) - MediaPlayerFactory & RenderVideo的绘制操作
- Webkit中HTML5 Video的实现分析
- Webkit中HTML5 Video的实现分析
- Webkit中HTML5 Video的实现分析
- Webkit中HTML5 Video的实现分析-HTMLMediaElement & MediaPlayer
- Webkit中HTML5 Video的实现分析(五) - WebKit中视频事件的传递
- Webkit中HTML5 Video的实现分析(六) - Safari视频机制分析
- Webkit中HTML5 Video的实现分析 (三) - MediaPlayer & MediaPlayerPrivate的生命周期
- Webkit中HTML5 Video的实现分析 (四) - 视频加载及播放的时序图
- Webkit中HTML5 Video的实现分析 (三) - MediaPlayer & MediaPlayerPrivate的生命周期
- Webkit中HTML5 Video的实现分析 (四) - 视频加载及播放的时序图
- Webkit中HTML5 Video的实现分析 (一) - 基本结构及HTMLMediaElement & MediaPlayer
- Webkit中HTML5 Video的实现分析 (一) - 基本结构及HTMLMediaElement & MediaPlayer
- Webkit中HTML5 Video的实现分析 (一) - 基本结构及HTMLMediaElement & MediaPlayer
- html5中video的使用
- HTML5 学习(二 CANVAS 的基本操作 【JavaScript绘制】)
- 还要奋斗多少年?这是一位职业院校大专生给《南风窗》写的3500多字长文的摘录
- style中display属性值
- Webkit中HTML5 Video的实现分析 (一) - 基本结构及HTMLMediaElement & MediaPlayer
- 新人报道
- hdu 4360 As long as Binbin loves Sangsang
- Webkit中HTML5 Video的实现分析 (二) - MediaPlayerFactory & RenderVideo的绘制操作
- VC进行宏展开的命令
- 【Error】Caused by: java.lang.NullPointerException
- SQl 语句(常见) 新建,删除,修改表结构
- Java 异常: try...catch...finally
- 用python写的处理PDB的文件
- 改变网络世界的WebRTC要来了?!
- 当Linux用尽内存
- smartupload实现上传下载