Android 11适配指南之系统相机拍照、打开相册

}

}

}

requestCodeREQUEST_CODE_ALBUM的情况下:

doCrop(data?.data!!)

data?.data!!即是选择图片返回的Uri,可以直接使用,这里进行了下一步操作,剪裁

剪裁

private fun doCrop(sourceUri: Uri) {

Intrinsics.checkParameterIsNotNull(sourceUri, “资源为空”)

UCrop.of(sourceUri, getDestinationUri())//当前资源,保存目标位置

.withAspectRatio(1f, 1f)//宽高比

.withMaxResultSize(500, 500)//宽高

.start(this)

}

为了方便,这里使用了一个三方库UCrop,使用简单方便。

getDestinationUri()是当前资源裁剪后保存的目标位置

private fun getDestinationUri(): Uri {

val fileName = String.format(“fr_crop_%s.jpg”, System.currentTimeMillis())

val cropFile = File(getExternalFilesDir(Environment.DIRECTORY_PICTURES), fileName)

return Uri.fromFile(cropFile)

}

UCrop的回调同样也在onActivityResult

override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent?) {

super.onActivityResult(requestCode, resultCode, data)

if (resultCode == RESULT_OK) {

when (requestCode) {

REQUEST_CODE_ALBUM -> {

doCrop(data?.data!!)

}

UCrop.REQUEST_CROP -> {

val resultUri: Uri = UCrop.getOutput(data!!)!!

val bitmap = BitmapFactory.decodeStream(contentResolver.openInputStream(resultUri))

// todo

}

UCrop.RESULT_ERROR -> {

val error: Throwable = UCrop.getError(data!!)!!

ToastUtil.show(“图片剪裁失败” + error.message)

}

}

}

}

UCrop.getOutput(data!!)!!,即是返回的Uri,可以直接操作,也可以转成bitmap

ok,到这里打开相册就介绍完了。

接下来看重点,打开相机。

author:yechaoa

打开相机

===============================================================

打开相机的流程就要稍微复杂一点了。

权限

第一步不是打开,而是先检查是否有相机权限,这个在某些手机上是必须的,比如华为。

  • 配置文件添加:
  • 代码:

private fun checkPermission() {

if (ContextCompat.checkSelfPermission(this, Manifest.permission.CAMERA) == PackageManager.PERMISSION_GRANTED) {

openCamera()

} else {

ActivityCompat.requestPermissions(this, arrayOf(Manifest.permission.CAMERA), REQUEST_CODE_PERMISSIONS)

}

}

  • 回调:

override fun onRequestPermissionsResult(requestCode: Int, permissions: Array, grantResults: IntArray) {

super.onRequestPermissionsResult(requestCode, permissions, grantResults)

if (requestCode == REQUEST_CODE_PERMISSIONS) {

if (grantResults.isNotEmpty() && grantResults[0] == PackageManager.PERMISSION_GRANTED) {

openCamera()

} else {

ToastUtil.show(“拒绝会导致无法使用相机”)

}

}

}

openCamera方法就是打开相机了。

打开前适配

private fun openCamera() {

val intent = Intent(MediaStore.ACTION_IMAGE_CAPTURE)

photoUri = getDestinationUri()

photoUri = if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) {

//适配Android 7.0文件权限,通过FileProvider创建一个content类型的Uri

FileProvider.getUriForFile(this, “$packageName.fileProvider”, File(photoUri.path!!))

} else {

getDestinationUri()

}

//android11以后强制分区存储,外部资源无法访问,所以添加一个输出保存位置,然后取值操作

intent.putExtra(MediaStore.EXTRA_OUTPUT, photoUri)

startActivityForResult(intent, REQUEST_CODE_CAMERA)

}

  • 适配一:

FileProvider.getUriForFile(this, “$packageName.fileProvider”, File(photoUri.path!!))

7.0以上,使用fileProvider的方式共享文件。

  • 适配二:

intent.putExtra(MediaStore.EXTRA_OUTPUT, photoUri)

android 11以后强制分区存储,外部资源无法访问,所以添加一个输出保存位置photoUri,然后取值操作

回调

override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent?) {

super.onActivityResult(requestCode, resultCode, data)

if (resultCode == RESULT_OK) {

when (requestCode) {

REQUEST_CODE_ALBUM -> {

doCrop(data?.data!!)

}

REQUEST_CODE_CAMERA -> {

//从保存的位置取值

doCrop(photoUri)

}

UCrop.REQUEST_CROP -> {

val resultUri: Uri = UCrop.getOutput(data!!)!!

val bitmap = BitmapFactory.decodeStream(contentResolver.openInputStream(resultUri))

// todo

}

UCrop.RESULT_ERROR -> {

val error: Throwable = UCrop.getError(data!!)!!

ToastUtil.show(“图片剪裁失败” + error.message)

}

}

}

这里注意,不是相册那样从data取值了,而是从我们保存的位置里取值。

后面剪裁跟相册都是一样的流程了。

总结

=============================================================

这个功能点最大的变动就是分区存储了,Android 10或许还能过度一下,但是Android 11以后就是强制执行分区存储了。

应用可以在不需要读写权限的情况下,访问自己的分区,执行读写操作,卸载之后分区文件也相应删除,所以就不能有把缓存文件放到竞品的文件夹下这种操作了,还是乖乖的吧。

在Android 10以下,还是要读写权限的,还是可以胡作非为的。

获取自己的分区地址:

getExternalFilesDir(Environment.DIRECTORY_PICTURES)

对应地址:

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则近万的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

img

img

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:Android)

尾声

在我的博客上很多朋友都在给我留言,需要一些系统的面试高频题目。之前说过我的复习范围无非是个人技术博客还有整理的笔记,考虑到笔记是手写版不利于保存,所以打算重新整理并放到网上,时间原因这里先列出面试问题,题解详见:


展示学习笔记

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

尾声

在我的博客上很多朋友都在给我留言,需要一些系统的面试高频题目。之前说过我的复习范围无非是个人技术博客还有整理的笔记,考虑到笔记是手写版不利于保存,所以打算重新整理并放到网上,时间原因这里先列出面试问题,题解详见:

[外链图片转存中…(img-F4YywTUT-1712606539448)]
展示学习笔记
[外链图片转存中…(img-NUicg7Ay-1712606539448)]
[外链图片转存中…(img-4D9XItpw-1712606539448)]

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值