经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 移动开发 » Android » 查看文章
Android Webview滑进出屏幕闪烁的解决方法
来源:jb51  时间:2019/3/14 11:21:33  对本文有异议

前言

在使用Webview进行滑动操作时,从屏幕可见区域外向内滑动时,会出现webview区域闪烁的问题(反之也是),本文将提供一种解决方案。

问题图示

xml布局:

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <android.support.v4.widget.NestedScrollView xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:layout_width="match_parent"
  4. android:layout_height="wrap_content"
  5. android:fillViewport="true"
  6. android:overScrollMode="never"
  7. android:scrollbars="none">
  8.  
  9. <LinearLayout
  10. android:layout_width="match_parent"
  11. android:layout_height="match_parent"
  12. android:orientation="vertical">
  13. <View
  14. android:id="@+id/contentView"
  15. android:layout_width="match_parent"
  16. android:layout_height="600dp"
  17. android:background="@color/colorPrimary" />
  18. <WebView
  19. android:id="@+id/webView"
  20. android:layout_width="match_parent"
  21. android:layout_height="wrap_content"
  22. android:background="@color/contract_font"></WebView>
  23. </LinearLayout>
  24. </android.support.v4.widget.NestedScrollView>

可以看到,NestedScrollView嵌套webview,且webview初始未在一屏内时,滑进出屏幕时会有短暂的白色块。

解决问题

方案对比

方案 考虑点
android:hardwareAccelerated="false" 5.0 开始Android系统为了充分利用GPU的特性,使得界面渲染更加平滑而默认开启的,如果关掉的话,那么整个网页不流畅了,岂不是得不偿失——>放弃
setBackgroundColor(Color.parseColor(“#00000000”)); setBackgroundResource(R.drawable.white); 设置底色背景,但是webview本身是加载的H5页面,使用的是H5页面的底色背景,而且通过上面的gif可以看出,没有效果——>放弃
==通过样式布局,让webview保持在第一屏内初始化== 本文尝试的方案

方案探索

1.xml布局

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <android.support.v4.widget.NestedScrollView xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:layout_width="match_parent"
  4. android:layout_height="wrap_content"
  5. android:fillViewport="true"
  6. android:overScrollMode="never"
  7. android:scrollbars="none">
  8.  
  9. <FrameLayout
  10. android:layout_width="match_parent"
  11. android:layout_height="match_parent">
  12.  
  13. <WebView
  14. android:id="@+id/webView"
  15. android:layout_width="match_parent"
  16. android:layout_height="wrap_content"
  17. android:background="@color/contract_font"></WebView>
  18.  
  19. <View
  20. android:id="@+id/contentView"
  21. android:layout_width="match_parent"
  22. android:layout_height="600dp"
  23. android:background="@color/colorPrimary" />
  24. </FrameLayout>
  25. </android.support.v4.widget.NestedScrollView>

通过FrameLayout来叠加使得webview保持在第一屏内初始化,然后设置webview的padding,这样使得完整的H5内容是在ContentView下方显示。

但是——>webview设置padding根本无效!!!

怎么办呢?无论怎样也想不到为什么会如此,毕竟本身api的实现上是有些缺陷的(https://stackoverflow.com/questions/9170042/how-to-add-padding-around-a-webview )

2.解决问题

最终的解决方案则是通过注入js代码来控制H5的padding来解决。

  1. webView.setWebViewClient(new WebViewClient() {
  2. @Override
  3. public void onPageFinished(WebView view, String url) {
  4. contentView.post(new Runnable() {
  5. @Override
  6. public void run() {
  7. contentViewHeight = px2dp(getApplicationContext(), contentView.getMeasuredHeight());
  8. if (contentViewHeight > 0) {
  9. webView.loadUrl("javascript:document.body.style.marginTop=\"" + contentViewHeight + "px\"; void 0");
  10. }
  11. }
  12. });
  13. }
  14. });

看下猜想运行的结果:

H5的显示缺少了顶部,这样看来padding是没有效果的。但是,为什么会没有效果呢,难道设置padding有问题?
之后查看了上面嵌入的网页的源码查看了下(网页是网络上随便找的一个url):

https://36kr.com/

打开网页编辑模式,查看body这块的样式:

可以看到要注入的js控制的样式这块是没有设置的。因此可以将padding-top的参数通过这里设置进去。

但是发现设置的该参数无效,是什么原因呢?接着往下翻:

原来是body中控制了padding-top的最高级样式显示,所以element-style中设置无效。所以要么把这段注释掉,重新写入至element-style中,要么尝试设置margin-top的方法。这里采用后者的做法:

可以看到,网页顶部出现了设置好的marin-top空白的高度。

只需要将这部分操作转换为对应的代码即可:

将上面的

  1. webView.loadUrl("javascript:document.body.style.paddingTop="" + contentViewHeight + "px"; void 0");

替换为:

  1. webView.loadUrl("javascript:document.body.style.marginTop=\"" + contentViewHeight + "px\"; void 0");

3.运行效果

可以看到已经没有闪烁了。

总结

整个方案的实现其实就两块:

1.布局,让webview在一屏内初始;

2.设置H5网页的margin-top或者padding-top;

好了,以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对w3xue的支持。

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号