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

    }
}
相关推荐
薿夜7 小时前
SpringSecurity(三)
android
zh_xuan12 小时前
Android Hilt实现依赖注入
android·hilt
freshman_y13 小时前
Qtcreator怎么新建安卓项目?编写一个五子棋游戏APP?
android·qt
时寒的笔记13 小时前
js逆向7_案例惠nong网
android·开发语言·javascript
雨白14 小时前
深入理解 Kotlin 协程 (三):返璞归真,探寻协程基础设施的底层基石
kotlin
肯多洛夫斯基14 小时前
安卓工控屏静默连WiFi全攻略
android
极梦网络无忧15 小时前
Android无障碍服务实现抖音直播间界面监控(场控助手核心原理)
android
call me by ur name16 小时前
ERNIE 5.0 Technical Report论文解读
android·开发语言·人工智能·机器学习·ai·kotlin
kerli16 小时前
Compose 组件:Box 核心参数及其 Bias 算法
android·前端
BLUcoding16 小时前
Android 常用控件及核心属性
android