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

    }
}
相关推荐
alexhilton4 小时前
Android的Agent优先时代:构建时vs运行时
android·kotlin·android jetpack
Cutecat_5 小时前
视频字幕处理工具横向:提取模式 vs 编辑模式,该如何选择
android·前端·ios·语音识别
2601_961765296 小时前
【分享】PlayerPro媒体音乐播放器 完整专业版
android·媒体
JohnnyDeng949 小时前
【Android】Android 包体积优化:R8/ProGuard 深度配置全攻略
android·性能优化·kotlin·jetpack
故渊at9 小时前
第九板块:Android 多媒体体系 | 第二十四篇:Camera Service 与 HAL3 成像流水线
android·camera·多媒体体系·hal3
Jinkxs12 小时前
Python基础 - 初识内置函数 Python自带的便捷工具
android·java·python
私人珍藏库12 小时前
【Android】VLLO-韩国热门手机剪辑APP
android·app·工具·软件·多功能
Cloud_Shy61813 小时前
解读《Effective Python 3rd Edition》:从练气到老魔(第六章 Item 40 - 43)
android·开发语言·人工智能·笔记·python·学习方法
AFinalStone14 小时前
Android12 U盘插拔链路源码全解析(五):Framework层(下) StorageManagerService
android·frameworks
林九生15 小时前
【实用技巧】MySQL 绿色版一键路径更新脚本详解 —— update_path.bat 深度解析
android·数据库·mysql