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 = "")
                            }
                        }
                    }
                }
            )
        }

    }
}
相关推荐
2501_946244783 小时前
Flutter & OpenHarmony OA系统图片预览组件开发指南
android·javascript·flutter
极客小云3 小时前
【IEEE Transactions系列期刊全览:计算机领域核心期刊深度解析】
android·论文阅读·python
wanghowie3 小时前
02.01 Spring Boot|自动配置机制深度解析
android·spring boot·后端
一起搞IT吧3 小时前
三方相机问题分析十一:【手电筒回调异常】手电筒打开3档时,达到档位控制温度,手电筒二级界面中档位为0
android·图像处理·数码相机
2501_924064113 小时前
2025年移动应用渗透测试流程方案及iOS安卓测试方法对比
android·ios
千里马学框架3 小时前
安卓14-16车机手机仿小米su7三分屏实战项目专题
android·智能手机·framework·分屏·车载·小米汽车·三分屏
走在路上的菜鸟4 小时前
Android学Flutter学习笔记 第二节 Android视角认知Flutter(resource,生命周期,layout)
android·学习·flutter
zh_xuan4 小时前
kotlin的常见空检查
android·开发语言·kotlin
踏雪羽翼13 小时前
android TextView实现文字字符不同方向显示
android·自定义view·textview方向·文字方向·textview文字显示方向·文字旋转·textview文字旋转