我们在本章回中介绍的Dialog
就是常用的对话框,主要用来给用户发出提示消息,这一点与上一章回中介绍过使用SnackBar
相同,不过它发出的消息不会自动消失,需要用户确认后才会消失,因此对话框常常用来发出需要用户确认的消息。我们将在本章回中详细介绍对话框的使用方法。
在Jetpack compose库中使用AlertDialog
可组合函数可以创建对话框,该函数提供了相关的参数来控制自己,下面是常用的参数:
上面介绍的这些参数都是用来控制对话框的,给它们赋值后就可以创建一个对话框,不过这个对话框会一起显示在页面中,这显然不符合使用场景:当某个条件触发时弹出对话框,给用户相关提示信息,让用户进行确认。接下来我们将介绍如何控制对话框的显示与关闭。
我们需要使用一个条件值,然后对该条件值进行判断,如果条件值符合某种条件就弹出对话框,否则不弹出对话框。而且我们还需要在对话框窗口中修改条件值,这样可以在点击对话框窗口中的按钮时关闭对话框。这么介绍可能比较抽象,稍后我们通过具体的代码来演示。
//显示对话框
@Composable
fun ExDialog(
onDismissRequest: () ->Unit,
onConfirmation:() -> Unit,
title: String,
message: String,
icon: ImageVector
) {
AlertDialog(
icon = { Icon(imageVector = icon, contentDescription = null)},
title = { Text(text = title)},
text = { Text(text = message)},
//控制dialog中文字,标题、图标的颜色,不过没有包含底部yes/no两个文字的颜色
containerColor = Color.LightGray,
textContentColor = Color.Black,
titleContentColor = Color.Red,
iconContentColor = Color.Yellow,
//这两个值用来控制点击dialog区域外时,dialog是否会消失,默认值为true
properties = DialogProperties(
dismissOnClickOutside = false,
dismissOnBackPress = false,
),
onDismissRequest = {onConfirmation()},
confirmButton = {
TextButton(onClick = {onConfirmation()}) {
Text(text = "Yes")
}
},
dismissButton = {
TextButton(onClick = {onDismissRequest()}) {
Text(text = "No",color = Color.Black )
}
}
)
}
//弹出对话框
@Composable
fun ShowDialog(showDialog:MutableState<Boolean>){
when {
showDialog.value -> {
ExDialog(
onDismissRequest = { showDialog.value = false},
onConfirmation = { showDialog.value = false },
title = "Title of AlertDialog",
message = "Message of AlertDialog",
icon = Icons.Default.Warning
)
}
}
}
//通过点击按钮弹出对话框
val showDialog = remember { mutableStateOf(false) }
Column (
horizontalAlignment = Alignment.CenterHorizontally,
verticalArrangement = Arrangement.SpaceAround){
//点击按钮显示图标
ElevatedButton(onClick = {
showDialog.value = true
}) {
Text(text = "Show Dialog")
}
ShowDialog(showDialog)
)
上面的示例代码中对相关功能进行了封装,把每一个功能都封装成了独立的函数,大家查看函数前面的注释就能明白函数的功能。下面是程序的运行效果图:
最后,我们对本章回的内容做一个全面的总结:
看官们,与Jetpack中对话框相关的内容就介绍到这里,欢迎大家在评论区交流与讨论!