亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定

Android 用 Webview 顯示網絡圖片跳坑指南

標簽:
Android

主要内容

  1. 使用WebView加载网络图片

  2. WebView加载图片的点击事件

系统的ImageView控件本就是用来显示图片的,那为什么还使用WebView控件去显示呢?

原因有三:

  1. 我目前项目的图片大小不一,有的很大(22561080),有的很小(3636),在做图片适配的时候不太好实现(是我目前水平不够吧),为了能完成项目的需求,只能先实现效果先。

  2. ImageView本身的scaleType属性不能实现效果。

    webp

    image.png

  3. 我目前项目使用的图片加载库是Glide,在Glide的现有API中使用的效果和项目效果有差别,没有时间深入研究。

我也是在搜索了网络图片适配看到其他博客的介绍,才想到用WebView去加载图片。这里只是实现的一种方式,在具体项目中能用ImageView加载的图片最好还是用ImageView免得又出什么新`Bug。废话不多说了,show me the f**k code。

使用WebView加载网络图片

WebView webView = new WebView(activity);//支持javascriptwebView.getSettings().setJavaScriptEnabled(false);// 设置可以支持缩放webView.getSettings().setSupportZoom(false);// 设置出现缩放工具webView.getSettings().setBuiltInZoomControls(false);//自适应屏幕webView.getSettings().setLayoutAlgorithm(WebSettings.LayoutAlgorithm.SINGLE_COLUMN);
webView.getSettings().setLoadWithOverviewMode(true);
webView.getSettings().setUseWideViewPort(true);// 设置滚动条不显示webView.setHorizontalScrollBarEnabled(false);
webView.setVerticalScrollBarEnabled(false);// 设置网络图片webView.loadUrl(images.get(i));// 这里是将 new 出来的 webview 收集,在不使用的时候统一清空webViews.add(webView);// 设置间距LinearLayout.LayoutParams lineParams = new LinearLayout.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.WRAP_CONTENT);            
lineParams.setMargins(0, DensityUtil.dp2px(10),0,0);            
webView.setLayoutParams(lineParams);            
layoutImage.addView(webView);

WebView加载图片的点击事件

 final int finalI = i;
webView.setOnTouchListener(new View.OnTouchListener() {      @Override
      public boolean onTouch(View v, MotionEvent event) {              switch (event.getAction()) {              case MotionEvent.ACTION_DOWN:
                    DownX = event.getX();//float DownX
                    DownY = event.getY();//float DownY
                    moveX = 0;
                    moveY = 0;
                    currentMS = System.currentTimeMillis();//long currentMS     获取系统时间
                    break;              case MotionEvent.ACTION_MOVE:
                    moveX += Math.abs(event.getX() - DownX);//X轴距离
                    moveY += Math.abs(event.getY() - DownY);//y轴距离
                    DownX = event.getX();
                    DownY = event.getY();                    break;              case MotionEvent.ACTION_UP:                    long moveTime = System.currentTimeMillis() - currentMS;//移动时间

                    // 这里的 55 和 250 是测试的时候取的值(这样做不太好,有1/10 的可能时候会误操作,有更好解决办法想能留言回复我,多谢了~)
                    if( moveTime > 55 && moveTime < 250 && ( moveX == 0.0 || moveY == 0.0 )){                             // 处理点击事件
                             return true;
                    }                    break;              default:                    break;
             }        return false;
     }
 });

清空,防止内存泄漏

使用 Webview 是有内存泄露风险的,所以在不使用的时候要及时置空。

    /**
     * 在 onDestory 中移除 webview 防止内存泄漏
     */
    public void removeWebView() {        for (int i = 0; i < webViews.size(); i++) {
            WebView webView = webViews.get(i);            if (webView != null){
                webView.removeAllViews();
                webView.destroy();
                webView.setVisibility(View.GONE);
            }
        }
    }



作者:_龙衣
链接:https://www.jianshu.com/p/54a6fb54d145


點擊查看更多內容
TA 點贊

若覺得本文不錯,就分享一下吧!

評論

作者其他優質文章

正在加載中
  • 推薦
  • 評論
  • 收藏
  • 共同學習,寫下你的評論
感謝您的支持,我會繼續努力的~
掃碼打賞,你說多少就多少
贊賞金額會直接到老師賬戶
支付方式
打開微信掃一掃,即可進行掃碼打賞哦
今天注冊有機會得

100積分直接送

付費專欄免費學

大額優惠券免費領

立即參與 放棄機會
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號

舉報

0/150
提交
取消