android web长按保存图片,Android中Webview实现长按保存图片、并添加到媒体扫描器...

Android中Webview实现长按保存图片、并添加到媒体扫描器

实现步骤:web

1、给webView添加长按监听OnLongClickListener

2、获取长按元素类型,判断是不是图片

3、将获取到的元素转换为图片并保存

4、添加到媒体扫描器,使相册能够实时扫描到更改数组

代码以下:ide

webView.setLongClickable(true);//长按保存图片监听

webView.setOnLongClickListener(new View.OnLongClickListener() {

@Override

public boolean onLongClick(View v) {

final WebView.HitTestResult result = webView.getHitTestResult();//获取元素内容

//判断元素类型是 图片 || 图片URL

if (result.getType() == WebView.HitTestResult.IMAGE_TYPE ||

result.getType() == WebView.HitTestResult.SRC_IMAGE_ANCHOR_TYPE) {

String picture = result.getExtra();//获取元素

String picName = System.currentTimeMillis() + ".png";

//将Base64格式转换为图片并保存

if (base64ToFile(picture,

Environment.getExternalStorageDirectory().getPath()

+ File.separator

+ "CHINARES_APP"

+ File.separator

+ picName)) {

//添加到媒体扫描器,若是是媒体类文件会显示在相册等地方,而且添加到最近下载列表中

File outFile = new File(

Environment.getExternalStorageDirectory().getPath()

+ File.separator

+ "CHINARES_APP"

+ File.separator

+ picName);

if (outFile != null && outFile.exists()) {

//添加到媒体扫描器

PromotionWebViewActivity.this.sendBroadcast(new Intent(Intent.ACTION_MEDIA_SCANNER_SCAN_FILE, Uri.fromFile(outFile)));

}

ToastUtil.show(PromotionWebViewActivity.this, "保存成功!请到相册查看!", Toast.LENGTH_SHORT);

} else

ToastUtil.show(PromotionWebViewActivity.this, "保存失败!", Toast.LENGTH_SHORT);

}

return true;

}

});

其中:

onLongClick 的返回值为true表示不监听单击事件,若是须要在该方法里面弹出提示框选择不一样的操做时,须要监听单击事件、这里要返回false。svg

result.getExtra():方法获取到的数据是base64编码后的data,须要还原成字节数组才能进行存储,这个方法在配置过url的图片中返回的是图片连接this

将Base64格式转换为图片并保存:编码

/**

* base64编码字符集转化成图片文件。

*

* @param base64Str

* @param path 文件存储路径

* @return 是否成功

*/

public static boolean base64ToFile(String base64Str, String path) {

byte[] data = Base64.decode(base64Str.split(",")[1], Base64.DEFAULT);

for (int i = 0; i < data.length; i++) {

if (data[i] < 0) {

//调整异常数据

data[i] += 256;

}

}

OutputStream os = null;

try {

os = new FileOutputStream(path);

os.write(data);

os.flush();

os.close();

return true;

} catch (FileNotFoundException e) {

e.printStackTrace();

return false;

} catch (IOException e) {

e.printStackTrace();

return false;

}

}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值