news 2026/6/10 20:59:38

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/6/10 9:47:29

基于深度学习YOLOv12的红外森林火灾火焰烟雾识别检测系统(YOLOv12+YOLO数据集+UI界面+登录注册界面+Python项目源码+模型)

一、项目介绍 森林火灾是威胁生态环境和人类安全的重要灾害之一,快速准确的火灾检测对灾害防控至关重要。本文基于深度学习目标检测算法YOLOv12,构建了一套红外森林火灾火焰与烟雾检测系统。该系统利用红外图像数据,通过YOLOv12模型实现了对…

作者头像 李华
网站建设 2026/6/10 9:48:08

计算机是如何工作的

一.冯诺伊曼体系 CPU 中央处理器: 进⾏算术运算和逻辑判断. 存储器: 分为外存和内存, ⽤于存储数据(使⽤⼆进制⽅式存储) 输⼊设备: ⽤⼾给计算机发号施令的设备. 输出设备: 计算机个⽤⼾汇报结果的设备. 二.指令 1.概念 所谓指令,即指导 CPU 进⾏⼯作的命令…

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

标签是“养”出来的:如何让沉睡数据变成消金公司的印钞机

1. 撕开迷雾:消金业务的四层标签塔构建实战 做大数据的兄弟们都知道,标签这玩意儿,建起来容易,用起来难。很多公司搞了成百上千个标签,最后业务方只用“性别”和“年龄”,简直是资源的巨大浪费。在消费金融…

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

每日AI分享-2月3日(提示词管理插件+AI对话记录+Skills认识)

提示词管理插件 定义:一款可以读取飞书多维表格、支持一键复制提示词的谷歌浏览器插件。 首先我们需要打开谷歌插件地址:https://chromewebstore.google.com/detail/%E6%8F%90%E7%A4%BA%E8%AF%8D%E7%AE%A1%E7%90%86%E5%8A%A9%E6%89%8B/jjgllljbegnmmpoc…

作者头像 李华