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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/1137146.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

从零实现稳定USB3.0传输速度:回波损耗控制教程

如何让USB3.0真正跑满5Gbps?一位硬件工程师的回波损耗实战笔记最近在调试一款工业级嵌入式设备时,我遇到了一个老生常谈却又让人头疼的问题:明明芯片手册写着支持SuperSpeed USB 3.0(5 Gbps),系统也识别到了…

SSM校园生活互助平台06qe4(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面

系统程序文件列表系统项目功能:学生,发布者,关于我们,公告类型,公告信息,闲暇兼职,商品分类,闲置交易,服务接单,在线咨询,服务订单,购买商品,订单信息,科目名称,资料分享SSM校园生活互助平台开题报告一、课题研究背景与意义(一)研究背景当前高…

推荐系统用户画像构建:零基础入门教程

推荐系统用户画像构建:从零开始的实战指南你有没有想过,为什么抖音总能“猜中”你想看的视频?为什么淘宝首页推荐的商品,好像知道你最近在找什么?这背后的核心技术之一,就是用户画像。在信息过载的时代&…

跨平台cp2102usb to uart bridge驱动兼容性实战分析

跨平台CP2102 USB to UART桥接实战:从驱动兼容性到稳定通信的全链路解析 你有没有遇到过这样的场景? 手头一块基于CP2102的USB转串模块,在Windows上插上就能用,换到Linux却显示“Permission denied”,而到了M1 Mac更…

2025年大模型盘点:从零基础到精通,收藏这一篇就够了!

2025年大模型领域以推理模型、RLVR与GRPO技术为主导,GRPO成为研究热点。架构上Transformer仍是主流,但效率优化增多。推理扩展和工具调用成为提升性能的重要手段,"刷榜"现象凸显benchmark评估的局限性。AI在编程、写作和研究领域展…

Kotlin 面向对象 - 装箱与拆箱

装箱与拆箱 在 Kotlin 中,装箱与拆箱涉及基本类型与它们的可空引用类型或泛型集合中的类型转换基本类型在大多数情况下直接对应 JVM 的原始类型,不涉及装箱当它们被用作可空类型或放入泛型集合时,会自动装箱为对应的包装类// 基本类型&#x…

新手必看:用万用表区分贴片LED灯正负极

从零开始:用万用表轻松搞定贴片LED正负极识别 你有没有遇到过这种情况——手头有一堆小小的贴片LED,没标签、无型号,焊接前却分不清哪边是正极?一接反,灯不亮,甚至烧了。别急,这几乎是每个电子新…

AUTOSAR网络管理与UDS诊断联动设计示例

AUTOSAR网络管理与UDS诊断联动:从机制到实战的深度解析你有没有遇到过这样的场景?一辆车停在维修工位上,技师用诊断仪尝试连接某个ECU——屏幕显示“通信失败”。可明明电源正常、线路无断路,重启几次后又突然连上了。再一查日志&…

快速理解频率响应验证原理:扫频与阶跃激励对比

频率响应怎么测?扫频和阶跃激励到底该用哪个?你有没有遇到过这种情况:调试一个电源环路,Bode图怎么看都不对劲;或者测试扬声器时发现高频失真严重,却说不清是系统本身的问题还是测量方法出了偏差&#xff1…

AI Agent 架构核心:如何构建多意图路由与动态查询分发引擎

在构建智能体或 RAG 系统时,一个关键瓶颈始终存在:用户用自然语言表达的需求,与系统底层的执行逻辑之间,往往隔着一道难以跨越的沟壑。 当用户脱口而出:“我电脑连不上网了。” 若系统仅做字面匹配,检索“…

吐血整理,常见性能测试缺陷+基准测试分析,一篇通透...

目录:导读 前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结(尾部小惊喜) 前言 1、常见性能测试缺…

上位机是什么意思?了解其在工业控制中的用途

上位机是什么?别再只会说“它是电脑”了!你有没有在工控现场听到过这样的对话:“PLC程序跑通了,但上位机连不上。”“数据没传上来,是不是上位机配置错了?”“这个报警要在上位机里设一下阈值。”听起来&am…

架构之最终一致性

架构之最终一致性 概述 在分布式系统中,AP、CP是不能同时满足的,这是铁律。根据CAP定理,当网络分区发生时,系统必须在一致性(Consistency)和可用性(Availability)之间做出选择。为了…

Leetcode 99 删除排序链表中的重复元素 | 合并两个链表

1 题目 83. 删除排序链表中的重复元素 给定一个已排序的链表的头 head , 删除所有重复的元素,使每个元素只出现一次 。返回 已排序的链表 。 示例 1: 输入:head [1,1,2] 输出:[1,2]示例 2: 输入&#x…

基于IAR的PLC编程:完整指南

用IAR打造高性能PLC系统:从零构建实战指南工业自动化正经历一场静默的变革。当越来越多的产线控制器不再依赖传统PLC厂商封闭的编程环境,而是运行在基于ARM Cortex-M7甚至RISC-V内核的“软PLC”平台上时,一个更灵活、更高效、更具扩展性的控制…

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

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

一文说清TC3中I2C中断的工作原理

深入理解TC3中I2C中断:从硬件机制到实战优化在汽车电子和高可靠性嵌入式系统开发中,英飞凌AURIX™ TC3xx系列微控制器凭借其多核TriCore架构、功能安全支持以及丰富的外设集成能力,已成为ADAS、电机控制和车载网关等关键应用的首选平台。而在…

书籍-E.A.韦斯特马克《人类婚姻史》

E.A.韦斯特马克《人类婚姻史》详细介绍 书籍基本信息 书名:人类婚姻史(The History of Human Marriage) 作者:E.A.韦斯特马克(Edward Alexander Westermarck,1862-1939年) 成书时间:…

从零实现Multisim正确安装避免数据库丢失

如何彻底解决“Multisim数据库未找到”?从零开始的完整安装实战指南 你有没有遇到过这种情况:兴冲冲地装好Multisim,打开软件准备画个电路仿真一下,结果刚点击“放置元件”,弹出一个红色警告—— “multisim数据库未…

计算机毕业设计springboot考试管理系统 基于Spring Boot框架的高校考试管理平台设计与实现 Spring Boot驱动的在线考试管理系统开发与应用

计算机毕业设计springboot考试管理系统5m0cl (配套有源码 程序 mysql数据库 论文) 本套源码可以在文本联xi,先看具体系统功能演示视频领取,可分享源码参考。随着信息技术的飞速发展,传统的考试管理模式面临着诸多挑战。纸质试卷的…