这篇文章主要介绍了适配AndroidQ拍照和读取相册图片的实现方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
Google发行Android Q版本也有很长一段时间了,华为应用市场已经要求要适配Android Q版本了,所以,我们也要去对Android Q进行适配。
先讲一下咱们这节用到的新特性
- Android Q文件存储机制修改成了沙盒模式,类似于iOS
- 应用只能访问自己沙盒下的文件和公共媒体文件
如果有想具体了解Android Q新版特效的可以去 官方文档
我们在这个地方记录一下Android Q版本进行拍照保存到相册的功能。
权限问题
Android Q不再需要申请文件读写权限,默认可以读写自己沙盒文件和公共媒体文件。因为相册属于公共媒体文件,所以,Android Q 可以不用 再动态申请权限。但是Android Q以下版本必须要申请权限才可以访问。
拍照
图片正常保存
拍照:Android Q之前版本使用的,将图片保存到指定文件夹,拍照完成后需要通知相册刷新
拍照代码
// 拍照存放路径
File fileDir = new File(Environment.getExternalStorageDirectory(), "Pictures");
if (!fileDir.exists()) {
fileDir.mkdir();
}
//图片名称
String fileName = "/IMG_" + System.currentTimeMillis() + ".jpg";
//跳转到相机
Intent intent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE);
Uri uri;
//适配Android N之后版本
if (Build.VERSION.SDK_INT >= 24) {
uri = FileProvider.getUriForFile(this, ImagePickerProvider.getFileProviderName(this), new File(mFilePath));
} else {
//适配Android N版本之前
uri = Uri.fromFile(new File(mFilePath));
}
intent.putExtra(MediaStore.EXTRA_OUTPUT, uri);
//跳转,需要在onActivityResult进行处理
startActivityForResult(intent, 1111);
刷新相册代码
sendBroadcast(new Intent(Intent.ACTION_MEDIA_SCANNER_SCAN_FILE, Uri.parse("file://" + mFilePath)));
以上就是Android Q之前版本通用的拍照代码,有需要的可以直接复制就行
将图片保存到沙盒内
- 沙盒里面操作文件不再需要申请权限
- 沙盒中新建文件夹只能再系统指定的子文件夹中新建
Android Q版本使用,将图片存放到沙盒文件内,图库无法刷新,无法显示
// 获取图片沙盒文件夹
File PICTURES = getExternalFilesDir(Environment.DIRECTORY_PICTURES);
//图片名称
mFileName = "IMG_" + System.currentTimeMillis() + ".jpg";
//图片路径
mFilePath = PICTURES.getAbsolutePath()+"/"+mFileName;
//跳转到相机
Intent intent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE);
Uri uri;
if (Build.VERSION.SDK_INT >= 24) {
uri = FileProvider.getUriForFile(this, ImagePickerProvider.getFileProviderName(this), new File(mFilePath));
} else {
uri = Uri.fromFile(new File(mFilePath));
}
intent.putExtra(MediaStore.EXTRA_OUTPUT, uri);
startActivityForResult(intent, 1111);
这个不用调用代码刷新相册库,因为刷新了也不能显示😁
仔细对比一下发现这两种基本上没有什么差别,只有文件存放路径不同,因为在Android Q新版本上对存储做出了改变。
将图片保存到公共文件夹
//-------------------------
//拍照存放路径
//为了适配Android Q版本以下
File fileDir = new File(Environment.getExternalStorageDirectory(), "Pictures");
if (!fileDir.exists()) {
fileDir.mkdir();
}
String fileName = "/IMG_" + System.currentTimeMillis() + ".jpg";
//--------------------------
//--------------------------
//设置参数
Uri uri = null;
// 设置保存参数到ContentValues中
ContentValues contentValues = new ContentValues();
//设置文件名
contentValues.put(MediaStore.Images.Media.DISPLAY_NAME, fileName);
//兼容Android Q和以下版本
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.Q) {
//android Q中不再使用DATA字段,而用RELATIVE_PATH代替
//RELATIVE_PATH是相对路径不是绝对路径
//DCIM是系统文件夹,关于系统文件夹可以到系统自带的文件管理器中查看,不可以写没存在的名字
contentValues.put(MediaStore.Images.Media.RELATIVE_PATH, "DCIM/Pictures");
} else {
//Android Q以下版本
contentValues.put(MediaStore.Images.Media.DATA, mFilePath);
}
//设置文件类型
contentValues.put(MediaStore.Images.Media.MIME_TYPE, "image/JPEG");
//执行insert操作,向系统文件夹中添加文件
//EXTERNAL_CONTENT_URI代表外部存储器,该值不变
uri = getContentResolver().insert(MediaStore.Images.Media.EXTERNAL_CONTENT_URI, contentValues);
// 若生成了uri,则表示该文件添加成功
Intent intent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE);
intent.putExtra(MediaStore.EXTRA_OUTPUT, uri);
startActivityForResult(intent, 1111);
使用这段代码也不用刷新相册库,会自动刷新。
存到公共文件的操作,相对来说麻烦点,但是也还好。
到此这篇关于适配AndroidQ拍照和读取相册图片的实现方法的文章就介绍到这了,更多相关AndroidQ拍照和读取相册图片内容请搜索编程学习网以前的文章希望大家以后多多支持编程学习网!
本文标题为:适配AndroidQ拍照和读取相册图片的实现方法


- iOS 对当前webView进行截屏的方法 2023-03-01
- Android studio实现动态背景页面 2023-05-23
- Flutter实现底部和顶部导航栏 2022-08-31
- Android实现监听音量的变化 2023-03-30
- 最好用的ios数据恢复软件:PhoneRescue for Mac 2023-09-14
- Android实现轮询的三种方式 2023-02-17
- 详解flutter engine 那些没被释放的东西 2022-12-04
- SurfaceView播放视频发送弹幕并实现滚动歌词 2023-01-02
- 作为iOS开发,这道面试题你能答出来,说明你基础很OK! 2023-09-14
- Android MaterialButton使用实例详解(告别shape、selector) 2023-06-16