MediaPlayerFactory
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,也就是具体的播放器来处理。
上一篇: Webkit中HTML5 Video的实现分析 (一) - 基本结构及HTMLMediaElement & MediaPlayer
下一篇:Webkit中HTML5 Video的实现分析 (三) - MediaPlayer & MediaPlayerPrivate的生命周期
转载请注明出处:http://blog.csdn.net/horkychen
分享到:
相关推荐
文章分析了WebKit中HTML Video的实现,配有类关系图和代码,有助于理解HTML5 Video的实现原理。
原创 kali2020安装w3af时,无法定位软件包python-pip python-webkit的解决办法 配套软件包
Qtwebkit安装库适用于QT5.14版本。 包含了MinGw730 、VS2017 编译器的的32和64位库。 qtwebkit-Windows-Windows_7-Mingw73-Windows-Windows_7-X86.7z qtwebkit-Windows-Windows_10-Mingw73-Windows-Windows_10-X86_...
web 打包工具32 位node-webkit - nwjs-v0.34.5-win-ia32 32位系统
C# webkit为内核的浏览器打开网页源码--值得下载 C# webkit为内核的浏览器打开网页源码--值得下载
官方离线安装包,测试可用。使用rpm -ivh [rpm完整包名] 进行安装
基于Star-CCM+&AMEsim联合仿真的液冷电池包热管理[下] 硬件工程师电路分析物联网模电单片机嵌入式技术
浏览器内核开发,WebKit.net是对WebKit的.Net封装,使用.net程序可以非常方便的集成和使用webkit作为加载网页的容器。
ios-webkit-debug-proxy-1.9.0-win64-bin
资源分类:Python库 所属语言:Python 资源全名:PyQtWebKit-5.13.1-cp37-none-win_amd64.whl 资源来源:官方 安装方法:https://lanzao.blog.csdn.net/article/details/101784059
一、起因 需求要求展示两行,多余的文字用三个点替代,于是用了这几个不太规范的属性 display: -webkit-box;...二、解决办法 网上找了一个可行的解决方案,把autoprefixer关掉,有一种写法: /*! autoprefixe
成功安装Teamviewer的关键,解决:缺少libQt5WebKitWidgets.so的关键包... 需要:libQt5WebKit.so.5()(64bit) >= 5.5 您可以尝试添加 --skip-broken 选项来解决该问题 您可以尝试执行:rpm -Va --nofiles --nodigest
android webkit HTML5 video研究
CentOS / RHEL 安装 Teamviewer ,解决缺少依赖包 报 “libQt5WebKitWidgets” 的错误信息。 qt5-qtwebkit-5.9.1-2.el7.x86_64.rpm,...qt5-qtwebkit-5.212.0-0.36.alpha2.el8.x86_64.rpm,适用于 CentOS / RHEL 7.*。
包含很多webkit的知识讲解;WebKit网页布局实现之主要架构篇之二_files、webkit源码分析系列--css样式解析、webkit研究报告、webkit源码分析系列--WebKit裁剪与改造 等相关文章。
官方离线安装包,测试可用。使用rpm -ivh [rpm完整包名] 进行安装
(lightdm-webkit-theme-aether) 受到对空间的终生热爱的启发。 一个光滑,简单的Archlinux主题登录屏幕,写在lightdm和lightdm-webkit2-greeter上。 目录 使用自己的墙纸 修改日期和时间格式 故障排除 我的...
html5-webkit-cube-slider.zip
Linux7安装teamviewer_13或teamviewer_14版本缺少qt5-qtwebkit包,可使用rpm -ivh qt5-qtwebkit-5.6.2-1.el7.x86_64.rpm --nodeps安装qt5包,在安装teamviewer即可。 error: Failed dependencies: libQt5WebKit.so....