一、概念
二、使用 Accompanist Permissions
不同版本中,权限状态(如PermissionState)中获取属性的方法不同,例如在“0.23.1”中,通过 PermissionState.hasPermission 属性拿到是否通过的 Boolean 值,在“0.35.0-alpha”中,通过 PermissionState.status.isGranted 属性拿到。
单个权限 | 多个权限 | |
添加权限 | @Composable fun rememberPermissionState( permission: String ): PermissionState | @Composable fun rememberMultiplePermissionsState( |
发起请求 | fun launchPermissionRequest(): Unit | fun launchMultiplePermissionRequest(): Unit |
权限回调 | @Composable | @Composable fun PermissionsRequired( multiplePermissionsState: MultiplePermissionsState, permissionsNotGrantedContent: @Composable (() -> Unit), permissionsNotAvailableContent: @Composable (() -> Unit), content: @Composable (() -> Unit), ) |
2.1 添加依赖
implementation "com.google.accompanist:accompanist-permissions:0.37.0"
注意:这里 v0.37.0 版本已经没有上述 PermissionRequired() 的回调可使用了。
2.2 单个权限申请
@OptIn(ExperimentalPermissionsApi::class)
@Composable
fun Demo() {
val context = LocalContext.current
val permissionState = rememberPermissionState(
Manifest.permission.CAMERA
)
LaunchedEffect(Unit) {
//直接显示不再询问的界面,只有第一次点拒绝后才会显示shouldShowRationale权限说明
permissionState.launchPermissionRequest()
}
Column(
modifier = Modifier.fillMaxSize(),
verticalArrangement = Arrangement.Center,
horizontalAlignment = Alignment.CenterHorizontally
) {
if (permissionState.status.isGranted) {
Text("已授权")
} else if (permissionState.status.shouldShowRationale) {
Text("摄像头对此应用程序非常重要。请授予权限")
Button(onClick = {
permissionState.launchPermissionRequest()
}) { Text("申请权限") }
} else {
Text("摄像头对此应用程序非常重要。请授予权限")
Button(onClick = {
context.startActivity(
Intent(Settings.ACTION_APPLICATION_DETAILS_SETTINGS).apply {
data = Uri.fromParts("package", context.packageName, null)
}
)
}) { Text("点击跳转") }
}
}
}
2.3 多个权限申请
val permissionState = rememberMultiplePermissionsState(
listOf(
Manifest.permission.CAMERA,
Manifest.permission.READ_EXTERNAL_STORAGE,
Manifest.permission.WRITE_EXTERNAL_STORAGE,
Manifest.permission.RECORD_AUDIO
)
)
LaunchedEffect(Unit) {
permissionState.launchMultiplePermissionRequest()
}
三、使用 rememberLauncherForActivityResult()
@Composable
fun Demo() {
val launcher = rememberLauncherForActivityResult(ActivityResultContracts.RequestPermission()) { isGranted ->
if (isGranted) {
} else {
}
}
Button({ launcher.launch(Manifest.permission.READ_EXTERNAL_STORAGE) }) {
Text("点击申请")
}
}