【JetCompose】入门教程实战基础案例01之显隐动画

任务

实现一个文字显示隐藏的动画

效果预览

图文混排组件

核心组件代码

js 复制代码
@Composable
fun JetpackCompose(modifier: Modifier = Modifier){
    Card(modifier = modifier) {
        var expaned by remember { mutableStateOf(false) }
        Column(verticalArrangement = Arrangement.Center,
            horizontalAlignment = Alignment.CenterHorizontally,
            modifier = Modifier.padding(all = 16.dp).clickable {
                expaned = !expaned
            }
            ) {
            Image(
                painter = painterResource(id = R.drawable.avatar),
                contentDescription = null,
                modifier = Modifier.padding(all = 8.dp).clip(CircleShape)
            )
           AnimatedVisibility(expaned) {
               Text(text = "Hello World", style = MaterialTheme.typography.bodyLarge)
           }
        }
    }
}

组件预览

js 复制代码
@Preview
@Composable
fun PreviewJetpackCompose(){
    MyJetCompomApp01Theme {
        JetpackCompose()
    }
}

完整实现

js 复制代码
class MainActivity05 : ComponentActivity() {
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        enableEdgeToEdge()
        setContent {
            MyJetCompomApp01Theme {
                Scaffold(modifier = Modifier.fillMaxSize()) { innerPadding ->
                    JetpackCompose(
                        modifier = Modifier.padding(innerPadding)
                    )
                }
            }
        }
    }
}

@Composable
fun JetpackCompose(modifier: Modifier = Modifier){
    Card(modifier = modifier) {
        var expaned by remember { mutableStateOf(false) }
        Column(verticalArrangement = Arrangement.Center,
            horizontalAlignment = Alignment.CenterHorizontally,
            modifier = Modifier.padding(all = 16.dp).clickable {
                expaned = !expaned
            }
            ) {
            Image(
                painter = painterResource(id = R.drawable.avatar),
                contentDescription = null,
                modifier = Modifier.padding(all = 8.dp).clip(CircleShape)
            )
           AnimatedVisibility(expaned) {
               Text(text = "Hello World", style = MaterialTheme.typography.bodyLarge)
           }
        }
    }
}

@Preview
@Composable
fun PreviewJetpackCompose(){
    MyJetCompomApp01Theme {
        JetpackCompose()
    }
}
相关推荐
Lei活在当下1 小时前
Codex 工程化实践指南:深入理解 AGENTS.md、SKILL.md 与 MCP
android·openai·ai编程
修炼者2 小时前
Toast的显示流程
android
simplepeng5 小时前
Room 3.0 KMP Alpha-01
android·kotlin·android jetpack
Lei活在当下5 小时前
Windows 下 Codex 高效工作流最佳实践
android·openai·ai编程
fatiaozhang95275 小时前
基于slimBOXtv 9.19.0 v4(通刷晶晨S905L3A/L3AB芯片)ATV-安卓9-完美版线刷固件包
android·电视盒子·刷机固件·机顶盒刷机·晶晨s905l3ab·晶晨s905l3a
私房菜6 小时前
Selinux 及在Android 的使用详解
android·selinux·sepolicy
一只特立独行的Yang7 小时前
Android中的系统级共享库
android
两个人的幸福online7 小时前
php开发者 需要 协程吗
android·开发语言·php
修炼者8 小时前
WindowManager(WMS)构建全局悬浮窗
android
xiaoshiquan12069 小时前
Android Studio里,SDK Manager显示不全问题
android·ide·android studio