【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()
    }
}
相关推荐
赏金术士32 分钟前
Compose 教学项目
android·kotlin·compose
晓梦林38 分钟前
ximai靶场学习笔记
android·笔记·学习
十六年开源服务商5 小时前
2026服务器配置优化与WordPress运维实战指南
android·运维·服务器
音视频牛哥7 小时前
大牛直播SDK(SmartMediaKit)Android平台Unity3D RTSP/RTMP播放器集成实践
android·unity3d·rtsp播放器·rtmp播放器·unity3d rtmp播放器·安卓unity rtsp播放器·安卓unity rtmp播放器
w1wi7 小时前
安卓抓包完全指南(一):从入门到 SSL Pinning 绕过
android·网络协议·ssl
aqi009 小时前
一文理清 HarmonyOS 6.0.2 涵盖的十个升级点
android·华为·harmonyos·鸿蒙·harmony
赏金术士10 小时前
Jetpack Compose 状态提升(State Hoisting)完全指南
android·kotlin·compose
BoomHe10 小时前
git Rebase 为任意一笔提交补上 Change-Id
android·git·android studio
TDengine (老段)10 小时前
TDengine 超级表/子表/普通表 — 设计理念与内部表示
android·大数据·数据库·物联网·时序数据库·tdengine·涛思数据