随着app的迭代,嵌入的html5界面越来越多了,Webview这个强大组件引起的问题越发的多起来,例如:

1、WebView导致的oom问题

2、Android版本不同,采用了不同的内核,兼容性crash

3、不同版本实现不同,甚至URI不规范也会引起不同程度的问题

为了解决以上问题,我们把WebView模块做成独立进程

WebView独立进程

Android允许一个app同时存在多个进程,可以根据需要把不同的模块放到不同进程中处理。

比如微信v2.X+版本的时候把Network部分做轻重进程分离,独立到一个单独的进程(:push)中,而上面两个层级依然跑在微信的主进程(:workder)中。而对于有内存泄露问题的webview或者其他不频繁使用的功能,再把其分离到独立的工具进程(:tools)中。通过分离进程,微信第一次重构解决了系统因为微信资源消耗,主动干掉微信服务的困境。

WebView独立进程的好处

有效增大App的运存,减少由webview引起的内存泄露对主进程内存的占用。

避免WebView的Crash影响App主进程的运行。

拥有对WebView独立进程操控权。

WebView进程与其他进程通讯的方式

把webview独立进程之后会发现,埋点功能和接收主进程数据都不正常了,这里就涉及到进程间通讯的问题了;

进程通讯无非就是那几种,aidl,messager,content provider,广播;

在这里就不再复述了,我是采用广播的方式来做的。

WebView硬件加速导致页面渲染闪烁

4.0以上的系统我们开启硬件加速后,WebView渲染页面更加快速,拖动也更加顺滑。但有个副作用就是,当WebView视图被整体遮住一块,然后突然恢复时(比如使用SlideMenu将WebView从侧边滑出来时),这个过渡期会出现白块同时界面闪烁。解决这个问题的方法是在过渡期前将WebView的硬件加速临时关闭,过渡期后再开启,代码如下:

if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB) {

webview.setLayerType(View.LAYER_TYPE_SOFTWARE, null);

}

webview的配置

下面贴上我自己的配置代码:

WebSettings settings = webview.getSettings();

settings.setJavaScriptEnabled(true);//启用js

settings.setJavaScriptCanOpenWindowsAutomatically(true);//js和android交互

String cacheDirPath = PathCommonDefines.WEBVIEW_CACHE;

settings.setAppCachePath(cacheDirPath); //设置缓存的指定路径

settings.setAllowFileAccess(true); // 允许访问文件

settings.setAppCacheEnabled(true); //设置H5的缓存打开,默认关闭

settings.setUseWideViewPort(true);//设置webview自适应屏幕大小

settings.setLayoutAlgorithm(WebSettings.LayoutAlgorithm.NARROW_COLUMNS);//设置,可能的话使所有列的宽度不超过屏幕宽度

settings.setLoadWithOverviewMode(true);//设置webview自适应屏幕大小

settings.setDomStorageEnabled(true);//设置可以使用localStorage

settings.setSupportZoom(false);//关闭zoom按钮

settings.setBuiltInZoomControls(false);//关闭zoom

if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB) {

webview.setLayerType(View.LAYER_TYPE_SOFTWARE, null);

}

webview.setWebViewClient(new WebViewClient() { @Override public boolean shouldOverrideUrlLoading(WebView view, String url) { view.loadUrl(url); return false; } @Override public void onLoadResource(WebView view, String url) { } @Override public void onPageFinished(WebView view, String url) { } });

html5跳原生界面

网页跳原生界面的方法有很多种,比如js调java方法,或者是通过uri scheme啦,也可以通过自己解析url来做。

在这儿,考虑到兼容性,拦截的是url,并且在清单文件中自定义了scheme~

webview.setWebViewClient(new WebViewClient() {

@Override

public boolean shouldOverrideUrlLoading(WebView view, String url) {

parserURL(url); //解析url,如果存在有跳转原生界面的url规则,则跳转原生。

return super.shouldOverrideUrlLoading(view, url);

}

@Override

public void onPageFinished(WebView view, String url) {

super.onPageFinished(view, url);

}

@Override

public void onLoadResource(WebView view, String url) {

super.onLoadResource(view, url);

}

});

清单文件中,声明一下 就可以在自带浏览器通过uri scheme跳到本app页面了,这个activity作为各个页面的分发页面,通过这个界面解析数据决定接下来要跳转哪个页面:

android:name=".ui.webview.CommWebviewActivity"

android:configChanges="orientation|keyboardHidden|screenSize"

android:process=":webview"

android:screenOrientation="portrait"

android:windowSoftInputMode="stateHidden">

android:host="xxxx.com"

android:scheme="kingp2p" />

android ui渲染webview,Android WebView 优化之路相关推荐

  1. 腾讯 android ui,腾讯开源的Android UI框架——QMUI Android

    各位同学,早上好,我是你们的老朋友D_clock爱吃葱花,前些天忙着发版本,最近也在看各种各样的新知识,有好多东西想写啊啊啊啊啊.嗯,先冷静捋一下,卖个关子.扯回正题,今天继续为大家推荐一个Githu ...

  2. android webview关闭后资源不释放,【Android】 WebView内存泄漏优化之路

    这几年H5的快速发展,使得Hybrid混合开发越来越流行,而webview也成为了开发中必备的元素.但是我们知道WebView在加载页面时,会占用非常大的内存,无论是iOS还是Android系统上,加 ...

  3. android UI进阶之布局的优化

    好久没更新博客了,趁着清明来写点什么. 今天来讲下如何使用android中提供的工具优化我们的布局.首先我们写一个最简单的框架布局. <?xml version="1.0"  ...

  4. Android UI 渲染机制的演进,你需要了解什么?

    前言 如今UI 渲染可能是诸多性能问题中最容易被察觉到的,Android 开发既要面对各式各样的手机屏幕尺寸和分辨率,还要与"凶残"的产品和 UI 设计师过招. 在正确实现复杂.炫 ...

  5. android UI进阶之布局的优化(二)

    上一篇博客中介绍了布局优化的工具,层级观察器Hierarchy Viewer和布局优化分析工具layoutopt.如果看过上篇博客的会注意到,layoutopt工具提示可以将<FrameLayo ...

  6. android ui布局适配,Android适配全面总结(一)----屏幕适配

    前言 Android适配是一个老生常谈的问题,很多程序员觉得很恶心,不愿意做适配,但是又不得不做.然后老板说,这位兄弟,做好了,今天晚饭给你加个鸡腿,然后程序员开始找各种资料,忙活起来了,最终在苦逼的 ...

  7. GitHub标星5.6K,2020腾讯又一力作开源的Android UI框架——QMUI Android

    各位同学,早上好,我是你们的老朋友D_clock爱吃葱花,前些天忙着发版本,最近也在看各种各样的新知识,有好多东西想写啊啊啊啊啊.嗯,先冷静捋一下,卖个关子.扯回正题,今天继续为大家推荐一个Githu ...

  8. 腾讯开源android项目管理,腾讯开源的Android UI框架——QMUI Android

    各位同学,早上好,我是你们的老朋友D_clock爱吃葱花,前些天忙着发版本,最近也在看各种各样的新知识,有好多东西想写啊啊啊啊啊.嗯,先冷静捋一下,卖个关子.扯回正题,今天继续为大家推荐一个Githu ...

  9. android ui fundamentals pdf,Android UI Fundamentals

    摘要: Author Jason Ostrander walks developers through the different choices available on their way to ...

最新文章

  1. 环境搭建 - 奥比中光3D摄像头(Astra Mini)
  2. 有什么事是你当了程序员才知道的? | 每日趣闻
  3. let 和 var 区别
  4. IPv6 — 地址配置方式
  5. 单击CheckBox,全选GridView中所有CheckBox
  6. php 错误提示,php怎么显示错误
  7. 876. 链表的中间结点
  8. php扩展调用php函数,是否可以在PHP字符串中扩展函数调用?
  9. 记录——《C Primer Plus (第五版)》第十一章编程练习第5-12题
  10. linux 内核与分析 -- 内存管理(下)
  11. Android 使用反射调用StorageManager中 Hide方法getVolumeList、getVolumeState
  12. 一套ThinkPHP微信小程序商城源码带后台管理
  13. 主数据系统的设计与实现
  14. Edit Control响应全选(Ctrl+A)
  15. Android Library的创建及使用详解
  16. 诺基亚WP7手机或10月发布 搭载新版系统
  17. 【BZOJ3172】[TJOI2013] 单词(AC自动机的小应用)
  18. Java中用Apache POI生成excel和word文档
  19. 浅谈getaddrinfo
  20. Java跨年祝福语代码_春节语音祝福短信java也疯狂

热门文章

  1. 看完这个视频,你的“信任问题”能得到解决
  2. 【OpenCv】c++ 入门认识 Mat 类,单通道 Mat 的基本操作
  3. Nexus 5X手机在支付宝的蚂蚁森林自动收能量的过程
  4. PAT题集2019.5.3排名变动
  5. 非常神奇的Linux技术:BPF
  6. python高并发对比java_Java和Python哪个前景更好点呢?
  7. 图片怎么在线识别转文字?常见渠道一览
  8. python--520爱心发射源码
  9. 解决把QQ截图或者QQ聊天的图片复制到wps文档中无法完全显示的简单方法
  10. 机器学习——方差与偏差