Compose 封装 - 倒计时消失容器

一、封装

  • 不要用封装 Dialog/AlertDialog 来实现弹窗。Dialog 作为基础组件就是个 Box 毫无意义,不必为了用它而多出很多不必要的代码 。AlertDialog 不基础但点击功能你往容器里传入的自定义界面也能实现。
  • 不要用收集 Flow 来实现倒数,collectAsState() 底层用了 remember 持久化,再次弹窗不会从头收集。
Kotlin 复制代码
/**
 * 根布局用Box,该容器与屏幕内容平级,以实现类似对话框弹窗效果。
 * @param maxCount 最大计数
 * @param isShow 是否显示容器
 * @param onDismiss 关闭容器显示
 * @param content 容器界面内容
 */
@Composable
fun CountDownContainer(
    maxCount: Int,
    isShow: Boolean,
    onDismiss: () -> Unit,
    content: @Composable (Int) -> Unit
) {
    var count by remember { mutableIntStateOf(maxCount) }
    LaunchedEffect(isShow) {
        //it是从0开始正数,+1才能减到0(尽管多数1秒)
        repeat(maxCount + 1) {
            count = maxCount - it
            delay(1000)
        }
    }
    if (count == 0) onDismiss()  //数到0就关闭容器
    if (isShow) {
        content(count)
    }
}

二、使用

Kotlin 复制代码
@Composable
private fun Demo(
) {
    var isShow by remember { mutableStateOf(false) }

    Button({
        isShowDialog = true
    }) { Text("点击弹窗") }

    CountDownContainer(
        maxCount = 5,
        isShow = isShow,
        onDismiss = { isShow = false }
    ) {
        Box(
            modifier = Modifier.size(200.dp).background(Color.Red),
            contentAlignment = Alignment.Center
        ) { Text("$it") }
    }
}
相关推荐
coderhuo1 小时前
JibarOS 简介:Android AICore 开源实现方案
android·ai编程
故渊at1 小时前
第十五板块:Android 系统调试与逆向工程 | 第三十六篇:Smali 字节码语义与 Dalvik 指令集
android·指令集·dalvik·smali·字节码语义
J2虾虾1 小时前
Android支持Java语言的标准
android·java·开发语言
charlee441 小时前
Unity在安卓端如何调试输出信息
android·unity·adb·游戏引擎·真机调试
法欧特斯卡雷特1 小时前
从 Kotlin 编译器 API 的变化开始: 2.4.0
android·开源·github
贾艺驰1 小时前
实战Android Framework: 新增一个系统服务
android·源码
火山上的企鹅1 小时前
Codex实战:APP远程升级服务搭建(五)App端远程升级接入
android·服务器·远程升级·qgc
BreezeDove2 小时前
【Android】Flutter3.35项目启动超时问题
android·flutter
故渊at2 小时前
第十四板块:Android 硬件抽象与安全加固 | 第三十四篇:Hardware Composer (HWC) 与 显示安全(HDCP)
android·安全·composer·安全加固·hwc·硬件抽象
KIO no way2 小时前
AI内容编排是什么_聊聊CSDN_AI数字营销背后的分发逻辑
android·人工智能