android webview打开相册,Android 用 Webview 显示网络图片跳坑指南

主要内容使用WebView加载网络图片

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

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

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

AAffA0nNPuCLAAAAAElFTkSuQmCC

image.png

我目前项目使用的图片加载库是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 

return true;

}                    break;              default:                    break;

}        return false;

}

});

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

* 在 onDestory 中移除 webview 防止内存泄漏

*/

public void removeWebView() {        for (int i = 0; i 

WebView webView = webViews.get(i);            if (webView != null){

webView.removeAllViews();

webView.destroy();

webView.setVisibility(View.GONE);

}

}

}

作者:_龙衣

链接:https://www.jianshu.com/p/54a6fb54d145

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值