news 2026/4/18 10:47:29

Android Jetpack Compose - TopAppBar、BottomAppBar、Scaffold

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Android Jetpack Compose - TopAppBar、BottomAppBar、Scaffold

一、TopAppBar

1、基本介绍
  • TopAppBar 用于实现顶部的应用栏,它封装了顶部的应用栏的常见样式和交互,例如,标题、导航图标、操作按钮、滚动联动
参数说明
title显示在应用栏中的文字
navigationIcon用于导航的主图标,显示在应用栏的左侧
actions可让用户访问关键操作的图标,它们显示在应用栏的右侧
scrollBehavior确定顶部应用栏如何响应容器内部内容的滚动
colors确定应用栏的显示方式
2、演示
TopAppBar(colors=topAppBarColors(containerColor=MaterialTheme.colorScheme.primaryContainer,titleContentColor=MaterialTheme.colorScheme.primary,),title={Text("顶部的应用栏")})
TopAppBar(colors=topAppBarColors(containerColor=MaterialTheme.colorScheme.primaryContainer,titleContentColor=MaterialTheme.colorScheme.primary,),navigationIcon={IconButton(onClick={}){Icon(imageVector=Icons.AutoMirrored.Filled.ArrowBack,contentDescription="返回")}},actions={IconButton(onClick={}){Icon(imageVector=Icons.Filled.Menu,contentDescription="菜单")}},title={Text("顶部的应用栏")})
valscrollBehavior=TopAppBarDefaults.pinnedScrollBehavior(rememberTopAppBarState())Column(modifier=Modifier.fillMaxSize()){TopAppBar(title={Text("顶部的应用栏")},scrollBehavior=scrollBehavior)LazyColumn(modifier=Modifier.fillMaxSize().nestedScroll(scrollBehavior.nestedScrollConnection),contentPadding=PaddingValues(top=8.dp)){items(50){Text("列表项${it+1}",modifier=Modifier.padding(16.dp))}}}
3、其他顶部应用栏
  1. 居中对齐顶部应用栏
valscrollBehavior=TopAppBarDefaults.pinnedScrollBehavior(rememberTopAppBarState())Column(modifier=Modifier.fillMaxSize()){CenterAlignedTopAppBar(colors=topAppBarColors(containerColor=MaterialTheme.colorScheme.primaryContainer,titleContentColor=MaterialTheme.colorScheme.primary,),navigationIcon={IconButton(onClick={}){Icon(imageVector=Icons.AutoMirrored.Filled.ArrowBack,contentDescription="返回")}},actions={IconButton(onClick={}){Icon(imageVector=Icons.Filled.Menu,contentDescription="菜单")}},title={Text("顶部的应用栏")},scrollBehavior=scrollBehavior)LazyColumn(modifier=Modifier.fillMaxSize().nestedScroll(scrollBehavior.nestedScrollConnection),contentPadding=PaddingValues(top=8.dp)){items(50){Text("列表项${it+1}",modifier=Modifier.padding(16.dp))}}}
  1. 中等顶部应用栏
MediumTopAppBar(colors=topAppBarColors(containerColor=MaterialTheme.colorScheme.primaryContainer,titleContentColor=MaterialTheme.colorScheme.primary,),title={Text("顶部的应用栏")})
  1. 大顶部应用栏
LargeTopAppBar(colors=topAppBarColors(containerColor=MaterialTheme.colorScheme.primaryContainer,titleContentColor=MaterialTheme.colorScheme.primary,),title={Text("顶部的应用栏")})

二、BottomAppBar

1、基本介绍
  • BottomAppBar 用于实现底部的应用栏,它封装了底部的应用栏的常见样式和交互,例如,操作按钮、浮动操作按钮
2、演示
  1. BottomAppBar 基本使用,BottomAppBar 默认不会固定在底部
BottomAppBar(actions={IconButton(onClick={}){Icon(Icons.Filled.Check,contentDescription="Check")}IconButton(onClick={}){Icon(Icons.Filled.Edit,contentDescription="Edit",)}IconButton(onClick={}){Icon(Icons.Filled.ThumbUp,contentDescription="ThumbUp",)}IconButton(onClick={}){Icon(Icons.Filled.MailOutline,contentDescription="MailOutline",)}},floatingActionButton={FloatingActionButton(onClick={},containerColor=BottomAppBarDefaults.bottomAppBarFabColor,elevation=FloatingActionButtonDefaults.bottomAppBarFabElevation()){Icon(Icons.Filled.Add,"Add")}})
  1. BottomAppBar 固定在底部实现
ConstraintLayout(modifier=Modifier.fillMaxSize()){val(content,bottomBar)=createRefs()// 填满剩余空间LazyColumn(modifier=Modifier.constrainAs(content){top.linkTo(parent.top)start.linkTo(parent.start)end.linkTo(parent.end)bottom.linkTo(bottomBar.top)width=Dimension.fillToConstraints height=Dimension.fillToConstraints}.fillMaxWidth()){items(50){index->Text(text="Item${index+1}",modifier=Modifier.fillMaxWidth().padding(16.dp))}}BottomAppBar(modifier=Modifier.constrainAs(bottomBar){bottom.linkTo(parent.bottom)start.linkTo(parent.start)end.linkTo(parent.end)},actions={IconButton(onClick={}){Icon(Icons.Filled.Check,contentDescription="Check")}IconButton(onClick={}){Icon(Icons.Filled.Edit,contentDescription="Edit",)}IconButton(onClick={}){Icon(Icons.Filled.ThumbUp,contentDescription="ThumbUp",)}IconButton(onClick={}){Icon(Icons.Filled.MailOutline,contentDescription="MailOutline",)}},floatingActionButton={FloatingActionButton(onClick={},containerColor=BottomAppBarDefaults.bottomAppBarFabColor,elevation=FloatingActionButtonDefaults.bottomAppBarFabElevation()){Icon(Icons.Filled.Add,"Add")}})}

三、Scaffold

1、基本介绍
  • Scaffold 是 Compose 中用于构建标准化的页面结构的脚手架组件
@ComposablefunScaffold(modifier:Modifier=Modifier,topBar:@Composable()->Unit={},bottomBar:@Composable()->Unit={},snackbarHost:@Composable()->Unit={},floatingActionButton:@Composable()->Unit={},floatingActionButtonPosition:FabPosition=FabPosition.End,containerColor:Color=MaterialTheme.colorScheme.background,contentColor:Color=contentColorFor(containerColor),contentWindowInsets:WindowInsets=ScaffoldDefaults.contentWindowInsets,content:@Composable(PaddingValues)->Unit)
参数说明
modifier整体修饰符
topBar顶部栏
bottomBar底部栏
snackbarHostSnackbar 的组件
floatingActionButton浮动按钮
floatingActionButtonPosition浮动按钮位置
containerColor容器背景色
contentColor内容文字色
contentWindowInsets窗口边距
content主要内容区域
2、基本使用
varpressesbyremember{mutableIntStateOf(0)}Scaffold(topBar={TopAppBar(colors=topAppBarColors(containerColor=MaterialTheme.colorScheme.primaryContainer,titleContentColor=MaterialTheme.colorScheme.primary,),title={Text("顶部应用栏")})},bottomBar={BottomAppBar(containerColor=MaterialTheme.colorScheme.primaryContainer,contentColor=MaterialTheme.colorScheme.primary,){Text(modifier=Modifier.fillMaxWidth(),textAlign=TextAlign.Center,text="底部应用栏",)}},floatingActionButton={FloatingActionButton(onClick={presses++}){Icon(Icons.Default.Add,contentDescription="添加")}}){innerPadding->Column(modifier=Modifier.padding(innerPadding),){Text("点击了$presses次")}}
3、使用 floatingActionButtonPosition
(1)基本介绍
  • FabPosition 是用于控制 Scaffold 中 FloatingActionButton(FAB)位置的枚举类
枚举值说明
End屏幕右下角
Center屏幕底部正中央
Start屏幕左下角
EndOverlay屏幕右下角,悬浮在 BottomAppBar 上方
(2)演示
varpressesbyremember{mutableIntStateOf(0)}Scaffold(topBar={TopAppBar(colors=topAppBarColors(containerColor=MaterialTheme.colorScheme.primaryContainer,titleContentColor=MaterialTheme.colorScheme.primary,),title={Text("顶部应用栏")})},bottomBar={BottomAppBar(containerColor=MaterialTheme.colorScheme.primaryContainer,contentColor=MaterialTheme.colorScheme.primary,){Text(modifier=Modifier.fillMaxWidth(),textAlign=TextAlign.Center,text="底部应用栏",)}},floatingActionButton={FloatingActionButton(onClick={presses++}){Icon(Icons.Default.Add,contentDescription="添加")}},floatingActionButtonPosition=FabPosition.EndOverlay){innerPadding->Column(modifier=Modifier.padding(innerPadding),){Text("点击了$presses次")}}
4、关于 innerPadding
(1)基本介绍
  • innerPadding 是 Scaffold 自动计算并传递给主要内容区域的安全边距值,它确保内容不会被 Scaffold 的其他部分遮挡,例如,顶部栏、底部栏
(2)演示
  • 不使用 innerPadding,顶部内容会被顶部栏遮挡,底部内容会被底部栏遮挡
varpressesbyremember{mutableIntStateOf(0)}Scaffold(topBar={TopAppBar(colors=topAppBarColors(containerColor=MaterialTheme.colorScheme.primaryContainer,titleContentColor=MaterialTheme.colorScheme.primary,),title={Text("顶部应用栏")})},bottomBar={BottomAppBar(containerColor=MaterialTheme.colorScheme.primaryContainer,contentColor=MaterialTheme.colorScheme.primary,){Text(modifier=Modifier.fillMaxWidth(),textAlign=TextAlign.Center,text="底部应用栏",)}},floatingActionButton={FloatingActionButton(onClick={presses++}){Icon(Icons.Default.Add,contentDescription="添加")}}){innerPadding->Column(modifier=Modifier.fillMaxSize()){LazyColumn(modifier=Modifier.fillMaxSize()){items(50){Text("列表项${it+1}",modifier=Modifier.padding(16.dp))}}}}
5、使用 snackbarHost
varpressesbyremember{mutableIntStateOf(0)}valscope=rememberCoroutineScope()valsnackbarHostState=remember{SnackbarHostState()}Scaffold(topBar={TopAppBar(colors=topAppBarColors(containerColor=MaterialTheme.colorScheme.primaryContainer,titleContentColor=MaterialTheme.colorScheme.primary,),title={Text("顶部应用栏")})},bottomBar={BottomAppBar(containerColor=MaterialTheme.colorScheme.primaryContainer,contentColor=MaterialTheme.colorScheme.primary,){Text(modifier=Modifier.fillMaxWidth(),textAlign=TextAlign.Center,text="底部应用栏",)}},snackbarHost={SnackbarHost(hostState=snackbarHostState)},floatingActionButton={FloatingActionButton(onClick={scope.launch{presses++valresult=snackbarHostState.showSnackbar(message="点击了$presses次",actionLabel="撤销",duration=SnackbarDuration.Short)if(result==SnackbarResult.ActionPerformed){presses--}}}){Icon(Icons.Default.Add,contentDescription="添加")}}){innerPadding->Column(modifier=Modifier.padding(innerPadding),){Text("点击了$presses次")}}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/17 10:12:09

Windows苹果触控板驱动完整使用指南:解锁专业级触控体验

Windows苹果触控板驱动完整使用指南:解锁专业级触控体验 【免费下载链接】mac-precision-touchpad Windows Precision Touchpad Driver Implementation for Apple MacBook / Magic Trackpad 项目地址: https://gitcode.com/gh_mirrors/ma/mac-precision-touchpad …

作者头像 李华
网站建设 2026/4/18 8:32:11

地理知识图谱构建:MGeo与Neo4j的云端协同

地理知识图谱构建:MGeo与Neo4j的云端协同实战 在构建地理知识图谱时,地址对齐是一个关键但极具挑战性的任务。传统方法往往难以处理地址表述的多样性和模糊性,而MGeo作为多模态地理语言模型,能够精准识别不同表述的地址是否指向同…

作者头像 李华
网站建设 2026/4/18 8:51:53

JetBrains Mono:为开发者量身打造的开源编程字体终极方案

JetBrains Mono:为开发者量身打造的开源编程字体终极方案 【免费下载链接】JetBrainsMono JetBrains Mono – the free and open-source typeface for developers 项目地址: https://gitcode.com/gh_mirrors/je/JetBrainsMono 还在为代码阅读时的视觉疲劳而烦…

作者头像 李华
网站建设 2026/4/18 9:21:19

5步搞定复杂信号基线校正:从数据困扰到精准分析

5步搞定复杂信号基线校正:从数据困扰到精准分析 【免费下载链接】airPLS baseline correction using adaptive iteratively reweighted Penalized Least Squares 项目地址: https://gitcode.com/gh_mirrors/ai/airPLS 当你面对光谱或色谱数据时,是…

作者头像 李华
网站建设 2026/4/16 21:36:42

5分钟解放双手:MaaYuan游戏自动化助手深度体验指南

5分钟解放双手:MaaYuan游戏自动化助手深度体验指南 【免费下载链接】MaaYuan 代号鸢 / 如鸢 一键长草小助手 项目地址: https://gitcode.com/gh_mirrors/ma/MaaYuan 还在为每天重复的游戏日常任务感到厌烦吗?MaaYuan作为一款专为代号鸢和如鸢玩家…

作者头像 李华
网站建设 2026/4/18 8:55:55

终极指南:基于预训练ResNet-50的U-Net图像分割实战教程

终极指南:基于预训练ResNet-50的U-Net图像分割实战教程 【免费下载链接】pytorch-unet-resnet-50-encoder 项目地址: https://gitcode.com/gh_mirrors/py/pytorch-unet-resnet-50-encoder 在计算机视觉领域,图像分割技术正经历着革命性的变革。面…

作者头像 李华