Compose - Scaffold使用

Compose - Scaffold使用

复制代码
/**
 * Author : wn
 * Email : maoning20080809@163.com
 * Date : 2026/1/1 19:32
 * Description : Scaffold组件提供了一个基本的APP结构,包括AppBar、底部导航栏和主要内容区域。通过声明式的方式,开发者可以轻松创建一致且可扩展的用户界面。
 */
class ScaffoldActivity : ComponentActivity(){

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)

        setContent {
            testScaffold()
        }
    }


    @OptIn(ExperimentalMaterial3Api::class)
    @SuppressLint("UnusedMaterialScaffoldPaddingParameter")
    @Preview
    @Composable
    fun testScaffold(){
        MaterialTheme{
            Scaffold(
                topBar = {
                    SmallTopAppBar(
                        title = {
                            Text(text = "我的TopBar")
                        },
                        actions = {
                            IconButton(onClick = {
                                println("点击1")
                            }) {
                                Icon(Icons.Default.AccountBox, contentDescription = null)
                            }
                        },
                        colors = TopAppBarDefaults.smallTopAppBarColors(
                            containerColor = MaterialTheme.colorScheme.primaryContainer,
                            titleContentColor = MaterialTheme.colorScheme.primary,
                        )
                    )
                },
                content = { innerPadding ->     // 接收 innerPadding 参数
                    Column(
                        modifier = Modifier.padding(innerPadding).fillMaxSize()
                    ) {
                        Text(
                            text = "Scaffold使用",
                            modifier = Modifier.padding(20.dp),
                            fontSize = 30.sp,
                            color = Color.Blue
                        )
                        Button(onClick = {
                            println("点击222")
                        },modifier = Modifier.padding(start = 20.dp)) {
                            Text(text = "Click Me", )
                        }
                    }
                },
                bottomBar = {
                    BottomAppBar() {
                        Row() {
                            IconButton(modifier = Modifier.weight(1f), onClick = {
                                println("点击bottom bar 1")
                            }) {
                                Icon(Icons.Default.Settings, contentDescription = "")
                            }
                            IconButton(modifier = Modifier.weight(1f) , onClick = {
                                println("点击bottom bar 2")
                            }) {
                                Icon(Icons.Default.AccountBox, contentDescription = "")
                            }
                            IconButton(modifier = Modifier.weight(1f), onClick = {
                                println("点击bottom bar 3")
                            }) {
                                Icon(Icons.Default.Add, contentDescription = "")
                            }
                        }
                    }
                }
            )
        }

    }
}
相关推荐
jinanwuhuaguo28 分钟前
(第二十七篇)OpenClaw四月的演化风暴:OpenClaw 2026年4月全版本更新的文明级解读
大数据·人工智能·架构·kotlin·openclaw
随遇丿而安29 分钟前
第2周:`EditText` 不只是输入框,它是 Android 输入体验的第一道门
android
我命由我1234531 分钟前
Kotlin 开发 - lateinit 关键字
android·java·开发语言·kotlin·android studio·android-studio·android runtime
一起搞IT吧1 小时前
Android性能系列专题理论之十:systrace/perfetto相关指标知识点细节含义总结
android·嵌入式硬件·智能手机·性能优化
小书房5 小时前
Kotlin的by
android·开发语言·kotlin·委托·by
jinanwuhuaguo6 小时前
(第二十八篇)OpenClaw成本与感知的奇点——从“Token封建制”到“全民养虾”的本体论地基
android·人工智能·kotlin·拓扑学·openclaw
xxjj998a7 小时前
Laravel4.x核心特性全解析
android·mysql·laravel
JoshRen7 小时前
2026教程:在Android Termux中集成Gemini 3镜像站实现移动端文档自动处理与摘要生成(附国内免费方案)
android
诸神黄昏EX8 小时前
Android Google KEY
android
一起搞IT吧8 小时前
Android性能系列专题理论之十一:block IO问题分析思路
android·嵌入式硬件·智能手机·性能优化