===============================================================
选择图片
private fun openAlbum() {
val intent = Intent()
intent.type = “image/*”
intent.action = “android.intent.action.GET_CONTENT”
intent.addCategory(“android.intent.category.OPENABLE”)
startActivityForResult(intent, REQUEST_CODE_ALBUM)
}
固定写法,大差不差。
既然是startActivityForResult
启动方式,来看看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!!)
}
…
}
}
}
在requestCode
是REQUEST_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
,然后取值操作
回调
结尾
好了,今天的分享就到这里,如果你对在面试中遇到的问题,或者刚毕业及工作几年迷茫不知道该如何准备面试并突破现状提升自己,对于自己的未来还不够了解不知道给如何规划,可以来看看同行们都是如何突破现状,怎么学习的,来吸收他们的面试以及工作经验完善自己的之后的面试计划及职业规划。
这里放上一部分我工作以来以及参与过的大大小小的面试收集总结出来的一套进阶学习的视频及面试专题资料包,主要还是希望大家在如今大环境不好的情况下面试能够顺利一点,希望可以帮助到大家~
无法访问,所以添加一个输出保存位置photoUri
,然后取值操作
回调
结尾
好了,今天的分享就到这里,如果你对在面试中遇到的问题,或者刚毕业及工作几年迷茫不知道该如何准备面试并突破现状提升自己,对于自己的未来还不够了解不知道给如何规划,可以来看看同行们都是如何突破现状,怎么学习的,来吸收他们的面试以及工作经验完善自己的之后的面试计划及职业规划。
这里放上一部分我工作以来以及参与过的大大小小的面试收集总结出来的一套进阶学习的视频及面试专题资料包,主要还是希望大家在如今大环境不好的情况下面试能够顺利一点,希望可以帮助到大家~
[外链图片转存中…(img-fAvNHDLQ-1719293514734)]
[外链图片转存中…(img-7G4nnu1f-1719293514735)]