Android WebView shouldInterceptRequest 异步加载 - 屠龙宝刀,点击就送,极品装备,一秒刷爆

WebView 的 shouldInterceptRequest 可以让我们监听WebView发出的请求并做相应的处理,但有个严重的问题:浏览器的渲染以及资源加载都是在一个线程中,如果在shouldInterceptRequest 处理时间过长,WebView界面就会阻塞,这是非常非常不好的。

    本人最近遇到个问题,用WebView做显示,里面有个别特定url的图片需要做特殊的加载处理。所以就在shouldInterceptRequest 判断url,然后用java加载,处理,最后返回给 WebView。

    一开始用shouldInterceptRequest做了如下处理:

@Override public WebResourceResponse shouldInterceptRequest(WebView view, String url) { Log.i(TAG, "shouldInterceptRequest url=" + url + ";threadInfo" + Thread.currentThread()); WebResourceResponse response = null; if(url.contains("avatar.php?")){ Bitmap bitmap = ImageLoader.getInstance().loadImageSync(url); if (bitmap != null) { InputStream in = IOUtils.bitmap2InputStream(bitmap, 100); response = new WebResourceResponse("image/png", "UTF-8", in); } } return response; }



    开始感觉没有什么大问题,一段时间后发现在网络环境差的情况下非常慢,要好半天加载动画才会消失(WebView加载完成时取消加载动画的), http://xiamf.weebly.com/,经调试发现所有 shouldInterceptRequest的执行都在同一个线程内,如果此方法内处理时间长,不能及时返回结果,就会造成界面长时间无响应的情况, 真是万万没想到。。。

改成异步加载即可:

@Override public WebResourceResponse shouldInterceptRequest(WebView view, String url) { Log.i(TAG, "shouldInterceptRequest url=" + url + ";threadInfo" + Thread.currentThread()); WebResourceResponse response = null; if(url.contains("avatar.php?")){ try { final PipedOutputStream out = new PipedOutputStream(); PipedInputStream in = new PipedInputStream(out); ImageLoader.getInstance().loadImage(url, new ImageLoadingListener() { @Override public void onLoadingStarted(String s,http://ninbf.weebly.com/, View view) {} @Override public void onLoadingFailed(String s, View view,http://jnanf.weebly.com/, FailReason failReason) {} @Override public void onLoadingCancelled(String s, View view) {} @Override public void onLoadingComplete(String s, View view, Bitmap bitmap) { if (bitmap != null) { try { out.write(IOUtils.Bitmap2Bytes(bitmap)); out.close(); }catch (Exception e){ e.printStackTrace(); } } } }); response = new WebResourceResponse("image/png", "UTF-8", in); }catch (Exception e){ e.printStackTrace(); } } return response; }



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值