当webview遇到了Slidingmenu,webView出现卡白,解决方案

Sliding Menu的是一种比较新的设置界面或配置界面效果,在主界面左滑或者右滑出现设置界面,能方便的进行各类操做。如 Evernote、Google+、Foursquare等诸多优秀应用都采用了这种界面方案。效果见下图:
   
webView你们都认识,就像村头的王二狗,村上屌丝,人人都知。

如此白富美的SlidingMenu人见人爱,而屌丝WebView扮演着村头二狗的角色,当WebView遇到了SlidingMenu 的的时候,WebView就走不动路了,SlidingMenu如此elegant的滑动也被WebView拖的不那么优雅,每次划开SlidingMenu,WebView有文本的地方都会出现大片的卡顿,严重的影响了SlidingMenu的美观和使用。 android

通常不多有人想到将SlidingMenu和WebView结合,觉得大部分应用使用SlidingMenu的时候都是在左抽屉里面放应用的栏目分类,主页面放一个个listView,像印象笔记这样 web

可是少数的怪才会想到这样的布局,左边的抽屉里面就已经将各个分类和下面的子项目列出来,因此中间的主页面就放一个webview来显示具体的文本内容,好比我: 布局


这时候webview出现了卡白的问题,真心纠结死我了,查了各大论坛贴吧,最后问了SlidingMenu的做者,也没有获得回复,虽然这个bug不影响性能,可是这么优雅的SlidingMenu被卡白搞的若是掉价,太不舒服了,通过了俩天的苦思冥想和查找,最后发先在Android2.2上面没有这个问题,可是Android4.0上面却出现这样的问题,高版本居然不如低版本兼容性好?通过研究发现了,原来是  Android从3.0(API Level 11)开始,在绘制View的时候支持硬件加速,充分利用GPU的特性,使得绘制更加平滑,可是会多消耗一些内存。这样问题就被锁定在了硬件加速上,解决方法也应运而生:关闭硬件加速。 性能

在这个Activity中加入 android:hardwareAccelerated="false" spa

在webview的布局中加入 android:layerType="software" code

 

 

<WebView
                android:id="@+id/article_context"
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                android:layout_marginTop="5dip"
                android:textIsSelectable="true"
                android:layerType="software"
                android:background="@null"
                android:textSize="@dimen/context_size" />
相关文章
相关标签/搜索