Android WebView加载html里面有js加载图片时无法显示

<div id="canvas" style="margin-top: 0px;margin-left: 170px;">
<canvas id="canvass"  width="1850" height="950" ></canvas>
</div>

<script>
  var canvass = document.getElementById("canvass"),
        r = 10,
        ctx = canvass.getContext("2d"),
        img = new Image();
        var url = "http://192.135.0.00:8181/"+"photo/DistributionBoxes/pdx1000_955.png";//此处图片一直无法显示
        img.src = url ;
        img.onload = function() {
          ctx.drawImage(img, 0, 0);
       }
</script>

解决办法:

<script>
function aa(path){//1.增加js方法调用
  var canvass = document.getElementById("canvass"),
        r = 10,
        ctx = canvass.getContext("2d"),
        img = new Image();
        img.src = path;
        img.onload = function() {
          ctx.drawImage(img, 0, 0);
       }
}
</script>
 webView.setWebChromeClient(new chromClient());//2.在webView增加此方法
    private class chromClient extends WebChromeClient {
        @Override
        public void onProgressChanged(WebView view, int newProgress) {
            if(newProgress==100){
                String path = "http://192.135.0.00:8181/"+"photo/DistributionBoxes/pdx1000_955.png";
                String action="javascript:aa('"+path+"')";//3.在此处重新给调用一下JS
                runWebView(action);//4.然后再刷新,就可以显示了
            }

            super.onProgressChanged(view, newProgress);
        }
    }
    private void runWebView(final String url){
        runOnUiThread(new Runnable() {
            @Override
            public void run() {
                webView.loadUrl(url);
            }
        });
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值