解决webview闪屏,加载html富文本,设置字体view自动恢复

这是一篇我个人在EOE发的blog《解决webview闪屏,加载html富文本,设置字体view自动恢复》,由于eoe的blog系统实在是无言以对,我就把eoe上面的帖子以及blog是都转到csdn上来,原帖地址:http://www.eoeandroid.com/blog-781265-40789.html


项目中遇到,webview加载一段富文本,然后上下都有其他布局,然后加载数据后,webview会一直闪烁个不停 WebView 闪屏的解决方法

1、保证webview在布局没有其他view遮挡(解决方法:复杂布局中,将webview的weight设置为1)

2、设置 setBackgroundColor(0);

3、manifest文件注册Activity的时候关闭硬件加速 ******(粗大内容为后面添加的,请仔细看

换了个手机依然会闪烁啊,又想了一种实现方案,看网上说就是加载数据的时候,然后和其他view冲突神马的,就想到让webview的数据延后300毫秒加载,不让他们一起加载,可以了,换了3部手机,应该没问题,

 private void fillwv() {

mHandler.sendEmptyMessageDelayed(0, 300);

}

Handler mHandler = new Handler(){

@Override

public void handleMessage(Message msg) {

super.handleMessage(msg);

wv_nitification_content.clearView();

wv_nitification_content.loadDataWithBaseURL(null,notifyDetail.getContent().replaceAll("font-size:.*pt;", "font-size:0pt;").replaceAll("font-family:.*;", "font-family:;"), "text/html", "UTF-8", null);

}

};

 另附加:

1、html富文本替换其中的font-size: 或者font-family: 的方法:

content.replaceAll("font-size:.\*pt;", "font-size:0pt;").replaceAll("font-family:.\*;", "font-family:;")

2、webview加载html富文本的方法

 wv_nitification_content.loadDataWithBaseURL(null, notifyDetail.getContent().replaceAll("font-size:.\*pt;", "font-size:0pt;").replaceAll("font-family:.\*;", "font-family:;"), "text/html", "UTF-8", null);

3、解决webview通过设置字体之后webview的宽高不会自动恢复的问题:

1):先将webview clearview初始化,textsizewv\_nitification\_content.clearView();

2):然后再重新加载数据 wv_nitification_content.loadDataWithBaseURL(null, notifyDetail.getContent().replaceAll("font-size:.\*pt;", "font-size:0pt;").replaceAll("font-family:.\*;", "font-family:;"), "text/html", "UTF-8", null);

3):再去设置webview的WebSetting的settings.setTextSize(WebSettings.TextSize.LARGER);

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值