news 2026/3/30 20:15:45

Android Jetpack Compose - 进度指示器、SegmentedButton、Chip

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Android Jetpack Compose - 进度指示器、SegmentedButton、Chip

一、进度指示器

1、基本介绍
  1. 进度指示器可以分为 2 种类型
类型说明
确定型准确显示已完成的进度
不确定型持续动画显示,不考虑进度
  1. 进度指示器可以采用 2 种形式
类型说明
线性从左向右填充的水平条
圆形笔画长度不断增加,直到覆盖整个圆周的圆
2、基本使用
varcurrentProgressbyremember{mutableFloatStateOf(0f)}varloadingbyremember{mutableStateOf(false)}valscope=rememberCoroutineScope()Column(verticalArrangement=Arrangement.spacedBy(12.dp),horizontalAlignment=Alignment.CenterHorizontally,modifier=Modifier.fillMaxWidth().padding(12.dp)){Button(onClick={scope.launch{loading=truefor(iin0..100){delay(100)currentProgress=i.toFloat()/100}loading=false}},enabled=!loading){Text("开始加载")}if(loading){LinearProgressIndicator(progress={currentProgress},modifier=Modifier.fillMaxWidth(),)}}
varcurrentProgressbyremember{mutableFloatStateOf(0f)}varloadingbyremember{mutableStateOf(false)}valscope=rememberCoroutineScope()Column(verticalArrangement=Arrangement.spacedBy(12.dp),horizontalAlignment=Alignment.CenterHorizontally,modifier=Modifier.fillMaxWidth().padding(12.dp)){Button(onClick={scope.launch{loading=truefor(iin0..100){delay(100)currentProgress=i.toFloat()/100}loading=false}},enabled=!loading){Text("开始加载")}if(loading){CircularProgressIndicator(progress={currentProgress},)}}
3、不确定型进度指示器
  1. 不确定型通过动画向用户指示正在进行处理,但不会指定任何完成程度

  2. LinearProgressIndicator 或 CircularProgressIndicator 都可以创建为不确定指示器,但不传入 progress 参数

varloadingbyremember{mutableStateOf(false)}valscope=rememberCoroutineScope()Column(verticalArrangement=Arrangement.spacedBy(12.dp),horizontalAlignment=Alignment.CenterHorizontally,modifier=Modifier.fillMaxWidth().padding(12.dp)){Button(onClick={scope.launch{loading=truefor(iin0..100){delay(100)}loading=false}},enabled=!loading){Text("开始加载")}if(loading){LinearProgressIndicator(modifier=Modifier.fillMaxWidth(),)}}
varloadingbyremember{mutableStateOf(false)}valscope=rememberCoroutineScope()Column(verticalArrangement=Arrangement.spacedBy(12.dp),horizontalAlignment=Alignment.CenterHorizontally,modifier=Modifier.fillMaxWidth().padding(12.dp)){Button(onClick={scope.launch{loading=truefor(iin0..100){delay(100)}loading=false}},enabled=!loading){Text("开始加载")}if(loading){CircularProgressIndicator()}}

二、SegmentedButton

1、基本介绍
  • SegmentedButton,即分段按钮,它可让用户从一组并排显示的选项中进行选择, SegmentedButton 有 2 种类型
  1. 单选按钮:可让用户选择一个选项

  2. 多选按钮:可让用户选择 2 到 5 个选项,对于更复杂的选择或超过 5 个选项,可以使用使用 Chip

2、演示
varselectedIndexbyremember{mutableIntStateOf(0)}valoptions=listOf("Day","Month","Week")Box(modifier=Modifier.fillMaxSize(),contentAlignment=Alignment.Center,){SingleChoiceSegmentedButtonRow{options.forEachIndexed{index,label->SegmentedButton(shape=SegmentedButtonDefaults.itemShape(index=index,count=options.size),selected=(selectedIndex==index),onClick={selectedIndex=index},label={Text(label)})}}}
valselectedOptions=remember{mutableStateListOf(false,false,false)}valoptions=listOf("Mail Outline","Call","Date Range")Box(modifier=Modifier.fillMaxSize(),contentAlignment=Alignment.Center,){MultiChoiceSegmentedButtonRow{options.forEachIndexed{index,label->SegmentedButton(shape=SegmentedButtonDefaults.itemShape(index=index,count=options.size),checked=selectedOptions[index],onCheckedChange={selectedOptions[index]=it},label={when(label){"Mail Outline"->Icon(imageVector=Icons.Default.MailOutline,contentDescription="Mail Outline")"Call"->Icon(imageVector=Icons.Default.Call,contentDescription="Call")"Date Range"->Icon(imageVector=Icons.Default.DateRange,contentDescription="Date Range")}})}}}

三、Chip

1、基本介绍
  • Chip 是一种小型交互组件,它提供了快速、高效的交互方式,例如,操作、筛选等,Chip 有如下 4 种类型
类型说明
AssistChip辅助型 Chip,用于触发操作,带图标的操作
FilterChip筛选型 Chip,用于筛选选项,可选中 / 取消
InputChip输入型 Chip,用于实体输入,可删除的实体
SuggestionChip建议型 Chip,用于内容建议,轻量级建议
2、演示
valcontext=LocalContext.currentBox(modifier=Modifier.fillMaxSize(),contentAlignment=Alignment.Center){AssistChip(onClick={Toast.makeText(context,"Click Assist Chip",Toast.LENGTH_SHORT).show()},label={Text("Assist Chip")},leadingIcon={Icon(Icons.Filled.Settings,contentDescription="Icon Settings",Modifier.size(AssistChipDefaults.IconSize))})}
varselectedbyremember{mutableStateOf(false)}Box(modifier=Modifier.fillMaxSize(),contentAlignment=Alignment.Center){FilterChip(onClick={selected=!selected},label={Text("Filter Chip")},selected=selected,leadingIcon=if(selected){{Icon(imageVector=Icons.Filled.Done,contentDescription="Done",modifier=Modifier.size(FilterChipDefaults.IconSize))}}else{null},)}
varenabledbyremember{mutableStateOf(true)}if(!enabled)returnBox(modifier=Modifier.fillMaxSize(),contentAlignment=Alignment.Center){InputChip(onClick={enabled=!enabled},label={Text("Input Chip")},selected=enabled,avatar={Icon(Icons.Filled.Person,contentDescription="Localized description",Modifier.size(InputChipDefaults.AvatarSize))},trailingIcon={Icon(Icons.Default.Close,contentDescription="Localized description",Modifier.size(InputChipDefaults.AvatarSize))},)}
valcontext=LocalContext.currentBox(modifier=Modifier.fillMaxSize(),contentAlignment=Alignment.Center){SuggestionChip(onClick={Toast.makeText(context,"Click Suggestion Chip",Toast.LENGTH_SHORT).show()},label={Text("Suggestion Chip")})}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/28 8:48:46

Android16 RK3576 默认修改时间为24小时制

项目需求修改时间为24小时制,修改如下: 在frameworks\base\packages\SettingsProvider\src\com\android\providers\settings\DatabaseHelper.java里面修改 diff --git a/base/packages/SettingsProvider/src/com/android/providers/settings/DatabaseHelper.java b/base/pa…

作者头像 李华
网站建设 2026/3/15 10:03:34

119页精品PPT | 某光伏巨头数字化转型SAP蓝图解决方案

光伏能源集团通常采用多法人、多地域组织架构。不同子公司业务流程不统一,数据分散存储在各系统中。跨国销售涉及多方交易,手工处理方式效率低下。客户信用评级缺乏统一标准,坏账风险难以控制。销售、生产、财务环节相互脱节,订单…

作者头像 李华
网站建设 2026/3/24 3:40:11

基于深度学习YOLOv11的足球运动员检测系统(YOLOv11+YOLO数据集+UI界面+登录注册界面+Python项目源码+模型)

一、项目介绍 本文设计并实现了一种基于深度学习YOLOv11算法的足球运动员检测系统,能够实时检测足球场上的运动员、守门员、裁判及足球目标。系统采用YOLOv11模型进行目标检测,并基于PyTorch框架完成训练与部署。共4类目标(足球、守门员、球…

作者头像 李华
网站建设 2026/3/17 11:01:35

基于深度学习YOLOv12的轴承缺陷识别检测系统(YOLOv12+YOLO数据集+UI界面+登录注册界面+Python项目源码+模型)

一、项目介绍 轴承作为机械设备中的关键部件,其健康状态直接影响设备的运行效率与安全性。传统轴承缺陷检测方法依赖人工检查,存在效率低、主观性强等问题。为此,本文提出了一种基于深度学习YOLOv12的轴承缺陷识别检测系统,能够高…

作者头像 李华
网站建设 2026/3/28 20:32:36

Thinkphp和Laravel框架的农家乐民宿客房美食预订活动管理系统

目录ThinkPHP与Laravel框架的农家乐民宿管理系统摘要功能模块设计ThinkPHP实现特点Laravel实现优势技术对比适用场景建议开发技术源码文档获取/同行可拿货,招校园代理 :文章底部获取博主联系方式!ThinkPHP与Laravel框架的农家乐民宿管理系统摘要 功能模…

作者头像 李华