Android开发利用webview识别H5中图片并保存到相册

2024-02-28 08:08

本文主要是介绍Android开发利用webview识别H5中图片并保存到相册,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言
本文是基于在fragment中执行保存H5图片到本地相册的,相对于在acvitity中执行,削微有一点点复杂,但差别不大,代码中有明显区别

Step1:webview添加长按事件private WebView.HitTestResult hitTestResult;

webView.setOnLongClickListener(new View.OnLongClickListener() {@Overridepublic boolean onLongClick(View v) {hitTestResult=webView.getHitTestResult();// 如果是图片类型或者是带有图片链接的类型if (hitTestResult.getType() == WebView.HitTestResult.IMAGE_TYPE ||hitTestResult.getType() == WebView.HitTestResult.SRC_ANCHOR_TYPE){// 弹出保存图片的对话框showBottomDialog();return true;}return false;}});


Step2:弹出保存图片的底部对话框

 private void showBottomDialog(){//1、使用Dialog、设置stylefinal Dialog dialog = new Dialog(context);//2、设置布局View view = View.inflate(context,R.layout.dialog_custom_layout,null);dialog.setContentView(view);Window window = dialog.getWindow();//设置弹出位置window.setGravity(Gravity.BOTTOM);//设置弹出动画
//        window.setWindowAnimations(R.style.main_menu_animStyle);//设置对话框大小window.setLayout(ViewGroup.LayoutParams.MATCH_PARENT,ViewGroup.LayoutParams.WRAP_CONTENT);dialog.show();dialog.findViewById(R.id.tv_take_photo).setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View view) {dialog.dismiss();picUrl = hitTestResult.getExtra();//获取图片链接
//                            保存图片到相册new Thread(new Runnable() {@Overridepublic void run() {urlToBitMap(picUrl);}}).start();}});dialog.findViewById(R.id.tv_cancel).setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View view) {dialog.dismiss();}});}


自定义弹窗布局R.layout.dialog_custom_layout就省略了,写了不利于装逼,勿怪Step3:将图片转为Bitmap

/*** 将图片转为Bitmap* @param picUrl*/private void urlToBitMap(String picUrl) {Bitmap bitmap=null;try {URL iconUrl=new URL(picUrl);URLConnection connection=iconUrl.openConnection();HttpURLConnection httpURLConnection= (HttpURLConnection) connection;int length = httpURLConnection.getContentLength();connection.connect();inputStream=connection.getInputStream();bufferedInputStream=new BufferedInputStream(inputStream,length);bitmap=BitmapFactory.decodeStream(bufferedInputStream);bufferedInputStream.close();inputStream.close();if (bitmap != null){saveToAlbum(bitmap);}} catch (Exception e) {LogUtils.e("保存失败:",e.toString());activity.runOnUiThread(new Runnable() {@Overridepublic void run() {
//                    Toast.makeText(context, "保存失败", Toast.LENGTH_SHORT).show();}});e.printStackTrace();}}


Step4:保存到相册(动态权限申请)

/*** 保存到相册* @param bitmap*/private void saveToAlbum(Bitmap bitmap) {permissions= new String[]{Manifest.permission.WRITE_EXTERNAL_STORAGE};if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M){
//            手机系统6.0(23)以上动态申请权限int i=ContextCompat.checkSelfPermission(context,permissions[0]);if (i!=PackageManager.PERMISSION_GRANTED){
//                用户未授权,提醒授权ActivityCompat.requestPermissions((Activity) context,new String[]{Manifest.permission.WRITE_EXTERNAL_STORAGE},111);}else {appDir = new File(Environment.getExternalStorageDirectory().getAbsolutePath(), "kuaizai");if (!appDir.exists()) {appDir.mkdirs();}}}else {
//            系统23以下不需要动态授权appDir = new File(Environment.getExternalStorageDirectory().getAbsolutePath(), "kuaizai");if (!appDir.exists()) {appDir.mkdirs();}}
//        savePicture();String[] str = picUrl.split("/");String fileName = str[str.length - 1];if (appDir != null){File file = new File(appDir, fileName);try {fos = new FileOutputStream(file);//解决7.0系统打开sd卡找不到文件的问题if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) {StrictMode.VmPolicy.Builder builder = new StrictMode.VmPolicy.Builder();StrictMode.setVmPolicy(builder.build());}bitmap.compress(Bitmap.CompressFormat.JPEG, 100, fos);fos.flush();fos.close();onSaveSuccess(file);} catch (final IOException e) {activity.runOnUiThread(new Runnable() {@Overridepublic void run() {Toast.makeText(context, "保存失败"+e.toString(), Toast.LENGTH_SHORT).show();LogUtils.e("保存失败:",e.toString());}});e.printStackTrace();}}else {Toast.makeText(context, "授权失败!", Toast.LENGTH_SHORT).show();}}


Step5 保存成功,通知系统更新相册

/*** 保存图片成功* @param file*/private void onSaveSuccess(final File file) {activity.runOnUiThread(new Runnable() {@Overridepublic void run() {~~try {MediaStore.Images.Media.insertImage(context.getContentResolver(),file.getAbsolutePath(), file.getName(), null);} catch (FileNotFoundException e) {e.printStackTrace();}~~ //用以下方式替换上边try- catch内容,避免保存时在本地生成两次图片ContentValues values = new ContentValues();values.put(MediaStore.Images.Media.DATA, file.getAbsolutePath());values.put(MediaStore.Images.Media.MIME_TYPE, "image/jpeg");Uri uri = context.getContentResolver().insert(MediaStore.Images.Media.EXTERNAL_CONTENT_URI, values);// 最后通知系统更新相册context.sendBroadcast(new Intent(Intent.ACTION_MEDIA_SCANNER_SCAN_FILE, Uri.fromFile(file)));Toast.makeText(context, "保存成功", Toast.LENGTH_SHORT).show();}});}


Step6,Fragment中动态权限申请回调处理

    @Overridepublic void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {switch (requestCode){case 111:if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M){if (grantResults[0] == PackageManager.PERMISSION_GRANTED){new Thread(new Runnable() {@Overridepublic void run() {urlToBitMap(picUrl);}}).start();}else {ToastUtils.showToast2(context,"用户拒绝!");return;}}break;default:ToastUtils.showToast2(context,"保存失败!");}}


补充
上边步骤就是在webview中长按识别H5中的图片,并保存到手机系统相册,然后通知系统更新相册,整个过程只在Android端完成即可,并不需要像网上很多同僚说的需要和前端联调然后走交互方法才能完成,此方案仅在原生端即可完美解决,并且在各个版本包括pad上都是可以的。
但是开始也说了,如果你是在acvitity中进行上述操作,最后只需要让你的acvitity实现
ActivityCompat.OnRequestPermissionsResultCallback 接口,然后重写onRequestPermissionsResult方法就行了,记得一定要实现接口,不然重写的方法是不会走的,
但是如果在fragment中,执行完上述操作,你会惊喜的发现,fragment中的onRequestPermissionsResult回调方法依然没走,这个有两个原因,一个就是你的fragment也要和acvitity一样实现ActivityCompat.OnRequestPermissionsResultCallback 接口,还有就是你的fragment中onRequestPermissionsResult回调方法被你的载体acvitity给拦截了,所以要在acvitity的onRequestPermissionsResult回调方法中做一点手脚,让acvitity中的onRequestPermissionsResult回调方法传递给依赖于当前acvitity的Fragment,这样就nice了。也就是如下操作:

 

    @Overridepublic void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {super.onRequestPermissionsResult(requestCode, permissions, grantResults);List<Fragment> fragments =getSupportFragmentManager().getFragments();if (fragments == null){return;}for (Fragment fragment: fragments) {if (fragment != null){
//                调用Fragment中的onRequestPermissionsResultfragment.onRequestPermissionsResult(requestCode,permissions,grantResults);}}}
}

 

这篇关于Android开发利用webview识别H5中图片并保存到相册的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/754895

相关文章

Android kotlin中 Channel 和 Flow 的区别和选择使用场景分析

《Androidkotlin中Channel和Flow的区别和选择使用场景分析》Kotlin协程中,Flow是冷数据流,按需触发,适合响应式数据处理;Channel是热数据流,持续发送,支持... 目录一、基本概念界定FlowChannel二、核心特性对比数据生产触发条件生产与消费的关系背压处理机制生命周期

Android ClassLoader加载机制详解

《AndroidClassLoader加载机制详解》Android的ClassLoader负责加载.dex文件,基于双亲委派模型,支持热修复和插件化,需注意类冲突、内存泄漏和兼容性问题,本文给大家介... 目录一、ClassLoader概述1.1 类加载的基本概念1.2 android与Java Class

基于Python实现一个图片拆分工具

《基于Python实现一个图片拆分工具》这篇文章主要为大家详细介绍了如何基于Python实现一个图片拆分工具,可以根据需要的行数和列数进行拆分,感兴趣的小伙伴可以跟随小编一起学习一下... 简单介绍先自己选择输入的图片,默认是输出到项目文件夹中,可以自己选择其他的文件夹,选择需要拆分的行数和列数,可以通过

利用Python脚本实现批量将图片转换为WebP格式

《利用Python脚本实现批量将图片转换为WebP格式》Python语言的简洁语法和库支持使其成为图像处理的理想选择,本文将介绍如何利用Python实现批量将图片转换为WebP格式的脚本,WebP作为... 目录简介1. python在图像处理中的应用2. WebP格式的原理和优势2.1 WebP格式与传统

Android DataBinding 与 MVVM使用详解

《AndroidDataBinding与MVVM使用详解》本文介绍AndroidDataBinding库,其通过绑定UI组件与数据源实现自动更新,支持双向绑定和逻辑运算,减少模板代码,结合MV... 目录一、DataBinding 核心概念二、配置与基础使用1. 启用 DataBinding 2. 基础布局

Android ViewBinding使用流程

《AndroidViewBinding使用流程》AndroidViewBinding是Jetpack组件,替代findViewById,提供类型安全、空安全和编译时检查,代码简洁且性能优化,相比Da... 目录一、核心概念二、ViewBinding优点三、使用流程1. 启用 ViewBinding (模块级

基于 HTML5 Canvas 实现图片旋转与下载功能(完整代码展示)

《基于HTML5Canvas实现图片旋转与下载功能(完整代码展示)》本文将深入剖析一段基于HTML5Canvas的代码,该代码实现了图片的旋转(90度和180度)以及旋转后图片的下载... 目录一、引言二、html 结构分析三、css 样式分析四、JavaScript 功能实现一、引言在 Web 开发中,

Python如何去除图片干扰代码示例

《Python如何去除图片干扰代码示例》图片降噪是一个广泛应用于图像处理的技术,可以提高图像质量和相关应用的效果,:本文主要介绍Python如何去除图片干扰的相关资料,文中通过代码介绍的非常详细,... 目录一、噪声去除1. 高斯噪声(像素值正态分布扰动)2. 椒盐噪声(随机黑白像素点)3. 复杂噪声(如伪

Python中图片与PDF识别文本(OCR)的全面指南

《Python中图片与PDF识别文本(OCR)的全面指南》在数据爆炸时代,80%的企业数据以非结构化形式存在,其中PDF和图像是最主要的载体,本文将深入探索Python中OCR技术如何将这些数字纸张转... 目录一、OCR技术核心原理二、python图像识别四大工具库1. Pytesseract - 经典O

Python实现精准提取 PDF中的文本,表格与图片

《Python实现精准提取PDF中的文本,表格与图片》在实际的系统开发中,处理PDF文件不仅限于读取整页文本,还有提取文档中的表格数据,图片或特定区域的内容,下面我们来看看如何使用Python实... 目录安装 python 库提取 PDF 文本内容:获取整页文本与指定区域内容获取页面上的所有文本内容获取