Jetpack Compose 弹出框

版本是Jetpack Compose Android 1.1.1

import androidx.compose.foundation.layout.Column
import androidx.compose.foundation.layout.Spacer
import androidx.compose.foundation.layout.height
import androidx.compose.foundation.layout.padding
import androidx.compose.material.AlertDialog
import androidx.compose.material.Button
import androidx.compose.material.Text
import androidx.compose.runtime.Composable
import androidx.compose.ui.Modifier
import androidx.compose.ui.unit.dp

@Composable
fun MessageDialog(
    visible: Boolean,
    title: String,
    leftButtonText: String,
    rightButtonText: String,
    onClickLeftButton: () -> Unit,
    onClickRightButton: () -> Unit
) {
    if (visible) {
        AlertDialog(
            onDismissRequest = onClickRightButton,
            title = { Text(text = title) },
            buttons = {
                Column {
                    Button(
                        modifier = Modifier.padding(8.dp),
                        onClick = onClickLeftButton
                    ) {
                        Text(text = leftButtonText)
                    }
                    Spacer(modifier = Modifier.height(8.dp))
                    Button(
                        modifier = Modifier.padding(8.dp),
                        onClick = onClickRightButton
                    ) {
                        Text(text = rightButtonText)
                    }
                }
            }
        )
    }
}

使用组件

import androidx.compose.runtime.mutableStateOf
import androidx.compose.runtime.remember

@Composable
fun MyApp() {
    val (visible, setVisible) = remember { mutableStateOf(false) }

    // 显示或隐藏对话框
    fun toggleDialog() {
        setVisible(!visible)
    }

    // 删除好友操作
    fun deleteFriend() {
        // 在这里执行删除好友的操作
    }

    // 显示对话框按钮
    Button(onClick = toggleDialog) {
        Text("显示对话框")
    }

    // 显示确认对话框
    MessageDialog(
        visible = visible,
        title = "确认删除好友吗?",
        leftButtonText = "删除",
        rightButtonText = "取消",
        onClickLeftButton = {
            toggleDialog()
            deleteFriend()
        },
        onClickRightButton = toggleDialog
    )
}

参考ai腾讯混元

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值