理解WebKit和Chromium: Chromium WebView和Chrome浏览器渲染机制
转载请注明原文地址:http://blog.csdn.net/milado_nju
## 数据对比
前面介绍过Chromium WebView的时候,说过有关ChromiumWebView同Chrome浏览器有很多不同之处,下面以Chromium Content Shell来对比来描述Chromium WebView,这是因为Chrome浏览器的渲染机制等同Content Shell是类似的,不过Chrome浏览器上层代码是源的,所以笔者使用自己编译的Content Shell来分析。
在仔细介绍Chromium WebView之前,先看一组性能方面的数据,是有关于Chromium WebView和Chromium Content Shell的对比。虽然版本有些旧,并且现在的变化很快,但是这一版本依旧能够说明一些问题。
下面的性能数据是在Android4.4系统上测试基于Chromium30的WebView和ChromiumContent Shell。所使用的测试的两个Benchmark一个是测试CSS3D性能,另外一个是测试Canvas 2D性能。性能指标主要是包括FPS和内存两个方面,如下图所示。
性能方面,目前Content Shell较ChromiumWebView有不错的表现,在CSS3D和Canvas 2D上都有出色的表现,其中FishIETank出现的特别大的差异主要是因为Chromium 30上硬件加速的Canvas2D技术还没有支持。在内存方面,Chromium WebView使用更少的内存,这个主要源于它的进程模型,它没有使用多进程架构。
## Content Shell的渲染方式
下面详细描述Content Shell的渲染方式。图中有多个线程,其中标注橙色的是在Browser进程中,标注另外颜色的是Renderer进程。在Renderer线程中,主要是渲染树和合成树,同时有个合成器线程,根据之前章节的描述,它负责合成网页的各个层。在Android系统上,Chromium中的GPU工作变成一个线程,工作在Browser进程中,具体功能之前介绍过。
在Browser进程中,还有一个浏览器测的合成器线程,它的主要工作是将Renderer进程中合成结果和浏览器界面的一些内容合成起来,输出到SurfaceView对象。因为Android上SurfaceView的特性,所以可以为它创建单独的EGLContext,合成器线程可以结果绘制到该SurfaceView对象中显示出来。
在这一过程中,Chromium并不需要UI线程的参与,所有的工作都是在其它线程来完成的,所以UI线程不会被阻塞。不过,因为Android系统上的动画、变换等并能作用于SurfaceView对象,所以浏览器没有关系,但是用来嵌入其它UI界面,可能不能满足开发者的需求。具体的过程如下图所示。
这种情况下,就需要能够嵌入用户界面的一种机制,那就是Chromium WebView。
## Chromium WebView
Chromium WebView同之前的基于AndroidWebKit的所提供的功能类似,那就是它也能够提供一个View,并嵌入到其它UI界面中,跟其它没有view没有什么不同,只不过是用来渲染网页,下图描述Chromium WebView如何将网页内容绘制到用户UI界面中。
因为Chromium WebView没有多进程架构,所以图中所有线程都工作在主进程中。首先看渲染线程,它也不再工作在Renderer进程。同Content Shell类似,它也是包括渲染树和合成树。GPU线程也是类似的功能。不同之处在于同步的合成器,将网页的合成器放在主线程中来工作,这里主要的问题在于,需要绘制网页内容到UI中的时候需要在UI线程。
在Android系统中,如果用户界面设置的渲染方式硬件加速渲染方式,那么Android会使用内部HwUI机制。该机制会为每个Activity的内部View(ViewRootImpl类)构建一个HardwareRenderer,该对象能够创建EGLSurface和EGLContext,并将绘图动作转变成OpenGLES的操作。当绘制界面内容的时候,会充值当前EGLContext为自己创建的,逐次调用每个View的绘图操作。当绘制到WebView对象的时候,它会调用同步合成器将网页的结果绘制到当前的FBO中。下图是Android系统如何调用WebView的绘图网页内容的过程。
上图中上面三个阶段是Android绘图系统中的调用,下面两个是WebView的调用过程。在绘制界面的过程,会出现多个阶段,每个阶段的操作可能还不一样,所以读者能够看到图中Functor::operator函数出现state参数。
如果是软件渲染模式,那么问题变得更简单一些。在Renderer线程中,只需要渲染树,当调用WebView::onDraw(Canvas canvas)的时候,将网页的内容直接绘制在该Canvas对象上。在新版本上,因为使用UberCompositor等机制,所以合成器也能够直接输出到一个Bitmap对象上。
## PictureLayer层等处理
除了总体上的绘制机制存在明显的不同之外,两者还存在对某些层的绘制方法不一致的地方。这里的主要原因在于Chromium WebView能够使用系统内部的函数,而作为App的Content Shell缺不行。主要针对于那些常见的层,也就是基本文字图片等层PictureLayer,如下图所示。
左侧是Content Shell所使用的机制,右侧是Chromium WebView所使用的机制。因为跨进程的原因,Chromium使用共享内存将SkPicture绘制的内容(CPU内存中保存)通过共享内存传到Browser进程,并上传到GPU的纹理对象。右侧则是使用“gralloc”函数来分配”graphic buffer”,SkPicture直接将网页的一层绘制到该缓冲区对象上。
相信随着时间的推移,ChromiumWebView会越来越接近Content Shell,不过如果Android图形系统不改变,那么在某些方面Chromium WebView仍然不会赶上Content Shell的性能,特别是将网页的结果合成部分必须在UI线程来进行,必然会阻碍UI线程对用户事件等的响应。
理解WebKit和Chromium: Chromium WebView和Chrome浏览器渲染机制的更多相关文章
- chrome浏览器渲染白屏问题剖析
刚截图十几次,终于捕捉到了这个白屏现象,hiahia~~ 大家可以很清晰地看到下边还木有渲染完毕的透明层,这是一个十分普遍的问题,经常遇到.我的浏览器版本是 到目前为止应该是最新版(release版本 ...
- http://src.chromium.org/svn/ 定制chrome浏览器教程及源码
chromium 官网登不进去,最近在学习chrome插件制作,网上教程很多大多没有源码 其实作为开源软件 官方提供了全部源码地址:http://src.chromium.org/svn/ PRESU ...
- 理解WebKit和Chromium: 调试Android系统上的Chromium
转载请注明原文地址:http://blog.csdn.net/milado_nju 1. Android上的调试技术 在Android系统上,开发人员能够使用两种不同的语言来开发应用程序,一种是Jav ...
- CentOS 安装 chrome 浏览器
安装 google-chrome 浏览器,由于众所周知的原因,一直安装不了,下面介绍一种新方法. cd 到 /etc/yum.repos.d 创建一个yum新源 vi chromium-el6.rep ...
- 爬虫 Http请求,urllib2获取数据,第三方库requests获取数据,BeautifulSoup处理数据,使用Chrome浏览器开发者工具显示检查网页源代码,json模块的dumps,loads,dump,load方法介绍
爬虫 Http请求,urllib2获取数据,第三方库requests获取数据,BeautifulSoup处理数据,使用Chrome浏览器开发者工具显示检查网页源代码,json模块的dumps,load ...
- chrome浏览器爬虫WebDriverException解决采用python + selenium + chrome + headless模式
WebDriverException: Message: unknown error: Chrome failed to start: crashed 第一种:如果出现下面情况: chrome浏览器有 ...
- 理解WebKit和Chromium: Android 4.4 上的Chromium WebView
转载请注明原文地址:http://blog.csdn.net/milado_nju ## 概述 相信读者已经注意到了,在最新的Android 4.4 Kitkat版本中,原本基于Android Web ...
- 理解WebKit和Chromium: 硬件加速之RenderLayer树到合成树
转载请注明原文地址:http://blog.csdn.net/milado_nju ## 概述 在前面的章节中,笔者介绍了WebKit渲染引擎是如何有HTML网页构建DOM树.RenderObject ...
- 理解WebKit和Chromium: Chromium插件和扩展基础
转载请注明原文地址:http://blog.csdn.net/milado_nju ##概述 插件和扩展是一种扩充浏览器功能的技术,在之前我们介绍过NPAPI插件技术,在Chromium中,远远不只是 ...
随机推荐
- 勤拂拭软件系列教程 之 Android开发之旅
勤拂拭软件工作室持续推出Android开发系列教程与案例,供广大朋友分享交流技术经验,帮助喜欢Android的朋友们学习进步: 1. 勤拂拭软件Android开发之旅(1) 之 Android 开发环 ...
- IPQ4028开启I2C功能
0 概述 IPQ4028是一款集约式4核心ARM7 SOC芯片,内嵌独立双频WiFi子系统,offload式,支持MU-MIMO,最高支持1.2Gbps.标准的官方Demo方案中,IPQ4019开启了 ...
- python flask 基础入门
1. Flask 中的Hello World! 在使用pycharm创建一个Flask项目后,将会默认创建一个flask的app,这里来讲下每行代码表示的意义,代码入下 from flask impo ...
- 初体验GCP,【福利300$试用金】
1.https://cloud.google.com/free/ ,填写相应信息.需要信用卡,预扣1美元. 2.一波信息填写,成功. 3.激活终端 4.创建一个Python项目,选择部署地点. 5.部 ...
- java.lang.UnsatisfiedLinkError: D:\Tomcat\apache-tomcat-7.0.67\bin\tcnative-1.dll:
Can't load IA 32-bit .dll on a AMD 64-bit platform 错误原因 由错误提示可知,tcnative-1.dll是一个32位文件,但是运行在64位系统上 解 ...
- numpy的初探
# data = numpy.genfromtxt("C:\\Users\\Admin\Desktop\\111.txt", delimiter='\t', dtype='str' ...
- Web API对application/json内容类型的CORS支持
假设有一简单架构分为前后两部分,其一是Angular构成的前端页面站点,另一个则是通过ASP.NET Web API搭建的后端服务站点.两个站点因为分别布署,所有会有CORS(Cross-Origin ...
- 再见,segmentfault
再见,segmentfault 太多的Bug,对segmentfault已经爱不起了. 重回博客园~
- Docker容器的运用
Docker 利用容器来运行应用. 容器是从镜像创建的运行实例.它可以被启动.开始.停止.删除.每个容器都是相互隔离的.保证安全的平台. 可以把容器看做是一个简易版的 Linux 环境(包括root用 ...
- Redis从入门到精通:中级篇
原文链接:http://www.cnblogs.com/xrq730/p/8944539.html,转载请注明出处,谢谢 本文目录 上一篇文章以认识Redis为主,写了Redis系列的第一篇,现在开启 ...