news 2026/5/1 10:36:14

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/5/1 8:44:21

2026网络安全法正式实施,这6个专业直通网络安全领域!

【收藏必备】2026新《网络安全法》实施,网络安全人才缺口大,这6个专业值得关注! 2026年新修订的《网络安全法》正式施行,标志着我国网络安全治理体系重要升级,为人工智能时代的网络安全挑战提供法律支撑。随着治理体系…

作者头像 李华
网站建设 2026/4/21 2:13:03

双机党:一台小米一台华为,怎样相互远程控制?

林薇把新买的小米手机放进通勤包时,指尖划过机身流畅的曲面屏,新手机的质感让她心情愉悦。桌角的华为手机还亮着屏,上周刚换主力机时她纠结了好久,这部华为机里存着三年来的客户资料、项目备份,还有几个专属工作账号&a…

作者头像 李华
网站建设 2026/5/1 3:59:36

别再发 jar 了!用 Spring Boot + jpackage 一键生成 exe / msi 安装包

你是不是也遇到过这种情况:辛辛苦苦写好了一个 Spring Boot 项目,打成 jar 包发给别人,结果对方一句:“你这还要装 Java 啊?”对于很多非技术用户来说,“装 JDK、配环境变量”这一步,就已经把人…

作者头像 李华