【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()
    }
}
相关推荐
Gary Studio21 小时前
安卓HAL编写
android
_李小白1 天前
【android opencv学习笔记】Day 2: Mat类(图片数据结构体)
android·opencv·学习
jinanwuhuaguo1 天前
OpenClaw工程解剖——RAG、向量织构与“记忆宫殿”的索引拓扑学(第十三篇)
android·开发语言·人工智能·kotlin·拓扑学·openclaw
小怪吴吴1 天前
idea 开发Android
android·java·intellij-idea
xiaoyan20151 天前
2026爆肝!Flutter3.41纯手撸微信聊天APP原生应用
android·flutter·dart
jinanwuhuaguo1 天前
OpenClaw协议霸权——从 MCP 标准到意图封建化的政治经济学(第十八篇)
android·人工智能·kotlin·拓扑学·openclaw
撩得Android一次心动1 天前
Android Room 数据库详解【源码篇】
android·数据库·android jetpack·room
TO_ZRG1 天前
Android WorkManager 完全入门指南
android
a8a3021 天前
Laravel 6.x新特性全解析
android
用户游民1 天前
Android 腾讯X5WebView如何禁止系统自带剪切板和自定义剪切板视图
android·java