在Android 12中,onRequestPermissionsResult函数在请求权限时不再等待用户输入,导致在进行多次请求时会出现问题。为了解决这个问题,我们需要手动去实现回调函数,在权限被授权/拒绝的情况下进行适当的处理。
以下是一个实现回调函数的示例代码:
private lateinit var callback: PermissionCallback
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
callback = object : PermissionCallback {
override fun onPermissionGranted() {
// 权限已授予
}
override fun onPermissionDenied() {
// 权限被拒绝
}
override fun onPermissionDeniedAndNeverAskAgain() {
// 权限被拒绝,并且勾选了不再询问
}
}
}
interface PermissionCallback {
fun onPermissionGranted()
fun onPermissionDenied()
fun onPermissionDeniedAndNeverAskAgain()
}
private fun requestPermission() {
if (Build.VERSION.SDK_INT < Build.VERSION_CODES.M) {
callback.onPermissionGranted()
return
}
if (checkSelfPermission(Manifest.permission.WRITE_EXTERNAL_STORAGE) == PackageManager.PERMISSION_GRANTED) {
callback.onPermissionGranted()
} else {
with (ActivityResultContracts.RequestPermission()) {
launch(Manifest.permission.WRITE_EXTERNAL_STORAGE) {
if (it) {
callback.onPermissionGranted()
} else {
if (shouldShowRequestPermissionRationale(Manifest.permission.WRITE_EXTERNAL_STORAGE)) {
callback.onPermissionDenied()
} else {
callback.onPermissionDeniedAndNeverAskAgain()
}
}
}
}
}
}
在上面的代码中,我们首先定义了一个PermissionCallback接口和一个回调变量callback用于处理权限的授权结果。在onCreate函数中,我们初始化callback的实现,然后在requestPermission函数中请求文件读写的权限。如果获得了授权,则调用callback的onPermissionGranted方法;如果被拒绝,则调用callback的
上一篇:Android12(API31)-Fragment在后台时没有被销毁
下一篇:Android12(ApiLevel31):TfLiteGpuDelegateInvoke:GpuDelegate必须在初始化它的线程中运行