WebView 图片大小自适应问题

三星android 4.4 以下版本遇到 图片过大展示超过手机屏幕的问题:
问题出在img标签中有固定的width大小,导致展示过大。
解决方法1) :缺点是会把style 的其他属性也替换掉

     private String exchangeStyleValue(String htmlString) {
        Document doc = Jsoup.parse(htmlString);
        Elements elements = doc.getElementsByTag("a");
        for (Element element : elements) {
            Elements imgs = element.getElementsByTag("img");
            if (imgs != null && imgs.size() > 0) {
                Attributes attrs = element.attributes();
                for (Attribute attr : attrs) {
                    if (attr.getKey().equals("style")) {
                        attr.setValue("max-width:100% width:auto");
                    } else {
                        continue;
                    }
                }
                for (Element img : imgs) {
                    Attributes attrs2 = img.attributes();
                    for (Attribute attr : attrs2) {
                        if (attr.getKey().equals("style")) {
                            attr.setValue("max-width:100% width:auto");
                        } else {
                            continue;
                        }
                    }
                }
            }
        }
        return doc.toString();
    }

解法2):

signWebView.setWebViewClient(new WebViewClient() {
            @Override
            public boolean shouldOverrideUrlLoading(WebView view, String url) {
                return true;
            }

            @Override
            public void onPageFinished(WebView view, String url) {
                super.onPageFinished(view, url);
                imgStyleChange();
            }
        });

private void imgStyleChange(){
        signWebView.loadUrl("Javascript:" +
                "   var objs = document.getElementsByTagName('a'); " +
                "   for(var i=0;i<objs.length;i++)  { " +
                "       var a = objs[i]; " +
                "       a.style.maxWidth = '100%'; " +
                "       a.style.width = 'auto'; " +
                "         var imgs = objs[i].getElementsByTagName('img'); " +
                "         for(var i=0;i<imgs.length;i++) { " +
                "           var img = imgs[i];" +
                "           img.style.maxWidth = '100%'; " +
                "           img.style.width = 'auto'; " +
                "       } " +
                "}");
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值