山高水长
首页
  • 分类
  • 标签
  • 归档
友情链接
GitHub (opens new window)

山高水长

首页
  • 分类
  • 标签
  • 归档
友情链接
GitHub (opens new window)
  • Android Compose 使用 Dialog
  • Android Compose 权限请求
    • 实现
      • 权限请求
      • 请求失败对话框提示(可选)
    • Demo
    • 截图
    • 参考
  • android
Shanya
2022-08-12
目录

Android Compose 权限请求

# Android Compose 权限请求

在Compose中以往的权限请求方式就不再适用了。因此我在使用过程中发现了一种非常简单优雅的权限申请方法。

全部代码见Github Shanyaliux/ComposeDemo (github.com) (opens new window)

# 实现

# 权限请求

  • 在Activity中添加一下请求方法

    private fun requestPermissions(permissions: Array<String>, onResult: (List<String>) -> Unit) {
            registerForActivityResult(ActivityResultContracts.RequestMultiplePermissions()) { result ->
                val failed = result.filter { !it.value }.keys
                onResult(failed.toList())
            }.launch(permissions)
        }
    
    1
    2
    3
    4
    5
    6
  • 请求权限,改写onCreate的部分代码如下

    override fun onCreate(savedInstanceState: Bundle?) {
            super.onCreate(savedInstanceState)
            val requestList =
                arrayOf(Manifest.permission.ACCESS_FINE_LOCATION)
    
            requestPermissions(requestList) {
                setContent {
                    if (it.isEmpty()) {
                        Text(text = "已获取全部权限.")
                    } else {
                        RequestFailedDialog(it)
                    }
                }
            }
        }
    
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15

    注意

    别忘了在Manifest文件中先声明权限

    <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"/>
    
    1

# 请求失败对话框提示(可选)

@Composable
fun RequestFailedDialog(permissions: List<String>) {
    val activity = LocalContext.current as? Activity
    AlertDialog(onDismissRequest = {  },
        buttons = {
            Row {
                Button(
                    onClick = {
                        activity?.finish()
                    },
                    modifier = Modifier.weight(1f,true),
                    shape = RoundedCornerShape(bottomStart = 8.dp),
                    colors = ButtonDefaults.buttonColors(backgroundColor = Color.White),
                ) {
                    Text(text = "取消")
                }
                Button(
                    onClick = {
                        val intent = Intent()
                        intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK)
                        intent.action = "android.settings.APPLICATION_DETAILS_SETTINGS"
                        intent.data = Uri.fromParts("package", activity?.packageName, null)
                        activity?.startActivity(intent)
                    },
                    modifier = Modifier.weight(1f,true),
                    shape = RoundedCornerShape(bottomEnd = 8.dp),
                    colors = ButtonDefaults.buttonColors(backgroundColor = Color.White),
                ) {
                    Text(text = "确定")
                }
            }
        },
        title = {
            Text(text = "提示")
        },
        text = {
            Surface {
                LazyColumn() {
                    items(permissions) { permission ->
                        Text(text = permission)
                    }
                }
            }
        },
        shape = RoundedCornerShape(8.dp),
        backgroundColor = Color.White,
        contentColor = Color.Black,
        properties = DialogProperties()

    )
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51

# Demo

完整Demo代码见GitHub:ComposeDemo/app/src/main/java/cn/shanyaliux/composedemo/permission at master · Shanyaliux/ComposeDemo (github.com) (opens new window)

# 截图

image-20220812224844049

image-20220812225142494

# 参考

https://icode.best/i/68552745363490 (opens new window)

编辑 (opens new window)
#android
上次更新: 2022/09/30, 04:53:04
Android Compose 使用 Dialog

← Android Compose 使用 Dialog

最近更新
01
FCOS
09-30
02
Python执行终端命令
09-13
03
Android Compose 使用 Dialog
08-10
更多文章>
Theme by Vdoing | Copyright © 2020-2022 Shanya | MIT License
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式