Compose - 权限申请

一、概念

二、使用 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(
    permissions: List<String>
): MultiplePermissionsState

发起请求

fun launchPermissionRequest(): Unit

 fun launchMultiplePermissionRequest(): Unit

权限回调

@Composable
fun PermissionRequired(
    permissionState: PermissionState,
    permissionNotGrantedContent: @Composable (() -> Unit),
    permissionNotAvailableContent: @Composable (() -> Unit),
    content: @Composable (() -> Unit),

@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("点击申请")
    }
}

Android Compose 是一种全新的声明式 UI 工具包,用于构建 Android 应用程序用户界面。在 Android Compose 中,选择文件的功能可以通过使用 FilePicker 或 DocumentPicker API 实现。 要实现文件选择功能,首先需要在项目的 build.gradle 文件中加入以下依赖项: ```kotlin dependencies { // ... implementation "androidx.activity:activity-compose:1.3.1" } ``` 然后,在 Compose 组件中,可以使用带有回调函数的按钮来触发文件选择器的打开: ```kotlin import androidx.activity.compose.* import androidx.activity.result.contract.ActivityResultContracts @Composable fun FileChooserButton() { val openFileLauncher = rememberLauncherForActivityResult( contract = ActivityResultContracts.GetContent() ) { uri -> // 处理选择的文件 } Button( onClick = { openFileLauncher.launch("application/*") } ) { Text("选择文件") } } ``` 在上述代码中,我们使用了 `ActivityResultContracts.GetContent()` 启动器来打开文件选择器,并通过回调函数实现在选择文件后处理文件的逻辑。选择的文件可以通过 `uri` 参数进行进一步处理,例如读取文件内容、保存文件等操作。 需要注意的是,为了使用 `ActivityResultContracts.GetContent()` 启动器,需要进行相关权限申请,并在 AndroidManifest.xml 文件中添加相应的权限声明。 总之,通过使用 Android Compose 和 ActivityResultContracts.GetContent() 启动器,我们可以实现选择文件的功能,使用户能够在应用程序中方便地浏览和选择他们所需的文件。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值