news 2026/5/1 10:17:02

Android Jetpack Compose - Snackbar、Box

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Android Jetpack Compose - Snackbar、Box

Snackbar

1、基本介绍
  1. Snackbar 是一种轻量级反馈机制,它用于提供有关操作或动作的反馈

  2. Snackbar 会在显示几秒后消失,也可以通过用户交互消失,包含一个可选的用户操作

2、基本使用
valscope=rememberCoroutineScope()valsnackbarHostState=remember{SnackbarHostState()}vardescbyremember{mutableStateOf("")}Box(modifier=Modifier.fillMaxSize()){Column(modifier=Modifier.fillMaxSize(),horizontalAlignment=Alignment.CenterHorizontally){Button(onClick={scope.launch{valreuslt=snackbarHostState.showSnackbar(message="这是一条 Snackbar",actionLabel="关闭",duration=SnackbarDuration.Short)when(reuslt){SnackbarResult.ActionPerformed->{desc="Snackbar 手动关闭"}SnackbarResult.Dismissed->{desc="Snackbar 自动关闭"}}}desc="Snackbar 显示"}){Text("显示 Snackbar")}Text(desc)}SnackbarHost(modifier=Modifier.align(Alignment.BottomCenter).padding(16.dp),hostState=snackbarHostState)}

Box

1、基本介绍
@ComposableinlinefunBox(modifier:Modifier=Modifier,contentAlignment:Alignment=Alignment.TopStart,propagateMinConstraints:Boolean=false,content:@ComposableBoxScope.()->Unit)
参数说明
modifier设置基础属性
contentAlignment设置子元素的默认对齐方式
propagateMinConstraints设置是否将最小约束传递给子元素
content主要内容区域
2、基本使用
  1. Box 的基本使用
Box(modifier=Modifier.size(200.dp).background(Color.LightGray)){Text("test1",modifier=Modifier.align(Alignment.BottomStart))Text("test2",modifier=Modifier.align(Alignment.TopEnd))}
Box(modifier=Modifier.fillMaxSize()){Text(text="居中文本",modifier=Modifier.align(Alignment.Center))Button(onClick={},modifier=Modifier.align(Alignment.BottomCenter)){Text("底部按钮")}}
  1. 使用 contentAlignment
Box(modifier=Modifier.size(200.dp).background(Color.LightGray),contentAlignment=Alignment.Center,){Text("test")}
  1. 子元素使用 matchParentSize 函数,填充父元素
Box(modifier=Modifier.size(200.dp)){Box(modifier=Modifier.matchParentSize().background(Color.Red.copy(alpha=0.3f)))Text("test",modifier=Modifier.align(Alignment.Center))}
3、使用 propagateMinConstraints
  1. 外部灰色 Box 的最小约束不会传递给子元素,导致内部红色 Box 尺寸为 0dp,外部灰色 Box 受尺寸范围与内部红色 Box 尺寸影响,尺寸为 100dp
Box(modifier=Modifier.background(Color.LightGray).widthIn(min=100.dp,max=300.dp).heightIn(min=100.dp,max=300.dp)){Box(modifier=Modifier.background(Color.Red.copy(alpha=0.3f)))}
  1. 外部灰色 Box 的最小约束会传递给子元素,导致内部红色 Box 尺寸为 100dp,外部灰色 Box 受尺寸范围与内部红色 Box 尺寸影响,尺寸为 100dp
Box(modifier=Modifier.background(Color.LightGray).widthIn(min=100.dp,max=300.dp).heightIn(min=100.dp,max=300.dp),propagateMinConstraints=true){Box(modifier=Modifier.background(Color.Red.copy(alpha=0.3f)))}
  1. 外部灰色 Box 的最小约束会传递给子元素,内部红色 Box 自定义尺寸为 150dp,外部灰色 Box 受尺寸范围与内部红色 Box 尺寸影响,尺寸为 150dp
Box(modifier=Modifier.background(Color.LightGray).widthIn(min=100.dp,max=300.dp).heightIn(min=100.dp,max=300.dp),propagateMinConstraints=true){Box(modifier=Modifier.size(150.dp).background(Color.Red.copy(alpha=0.3f)))}
4、子元素层级
  1. 后声明的子元素绘制在先声明的子元素之上
Box(modifier=Modifier.size(200.dp).background(Color.LightGray),){Box(modifier=Modifier.size(150.dp).background(Color.Red).align(Alignment.TopStart))Box(modifier=Modifier.size(150.dp).background(Color.Green).align(Alignment.Center))}
  1. 可以使用 zIndex 控制层级,zIndex 值越大,层级越高
Box(modifier=Modifier.size(200.dp).background(Color.LightGray).zIndex(1f),){Box(modifier=Modifier.size(150.dp).background(Color.Red).align(Alignment.TopStart).zIndex(3f))Box(modifier=Modifier.size(150.dp).background(Color.Green).align(Alignment.Center).zIndex(2f))}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/1 6:14:38

TPS22965负载开关控制电路设计操作指南

用好一颗小芯片,省电又稳压:TPS22965负载开关实战设计全解析你有没有遇到过这样的问题?系统一上电,Wi-Fi模块“啪”地一下拉低主电源,MCU直接复位;设备待机几天就没电了,查来查去发现是某个传感…

作者头像 李华
网站建设 2026/5/1 9:40:07

nmodbus4类库使用教程:从零实现TCP客户端实战案例

从零构建工业通信客户端:用 nModbus4 实现 Modbus TCP 数据交互实战你有没有遇到过这样的场景?手头有一台支持 Modbus 协议的 PLC 或传感器,想通过上位机读取它的温度、压力数据,甚至远程控制继电器。但面对一堆寄存器地址和功能码…

作者头像 李华
网站建设 2026/5/1 6:12:19

display driver uninstaller 结合 DDU 模式进行安全卸载示例

显卡驱动清不干净?一招“DDU 模式”彻底卸载,告别蓝屏与性能下降 你有没有遇到过这样的情况: 刚更新完显卡驱动,结果开机黑屏;玩游戏突然花屏、掉帧;甚至系统频繁蓝屏,提示“VIDEO_TDR_FAILURE…

作者头像 李华
网站建设 2026/5/1 9:31:10

数字频率计基础入门:新手必看的零基础讲解指南

从零开始搞懂数字频率计:每个电子新手都该掌握的测量利器你有没有遇到过这样的情况?调试一个单片机系统,发现LED闪烁不对劲;或者手里的晶振标称是16MHz,但程序跑起来总觉得时序有问题。这时候,你最需要的不…

作者头像 李华
网站建设 2026/5/1 7:55:18

通过API接口获取历史数据进行分析。

在周末休市期间,通过API接口获取历史数据进行分析,是进行研究、策略回测和优化投资组合的绝佳时机。StockTv为这类需求提供了稳定可靠的数据支持。 下面这个表格汇总了周末通过API获取和分析历史数据的主要环节和常用工具,你可以快速了解全貌…

作者头像 李华
网站建设 2026/5/1 7:35:26

deepseek的流形约束超连接mHC

mHC: Manifold-Constrained Hyper-Connections https://arxiv.org/abs/2512.24880mHC: Manifold-Constrained Hyper-Connections 概述 mHC(Manifold-Constrained Hyper-Connections)是一种基于流形约束的超连接方法,旨在通过几何约束优化神经…

作者头像 李华