Jetpack Compose —— ProgressBar

news2025/1/4 7:18:59

           Jetpack Compose的ProgressBar是一种用户界面组件,用于向用户展示长时间操作的当前进度。ProgressBar可以有两种形式:线性和环形,这两种形式都可以通过Jetpack Compose轻松实现。

注意:从Jetpack Compose 1.0版本开始,ProgressBar已经被LinearProgressIndicatorCircularProgressIndicator取代,前者用于水平进度条,后者用于圆形进度条。


          ProgressBar主要有两个属性:进度和颜色。进度是一个浮点数,范围在0.0(无进度)和1.0(完成)之间。颜色可以通过Material主题颜色来设置。

以下是一个环形ProgressBar的Jetpack Compose实现示例1:

@Preview
@Composable
fun ProgressIndicatorSample(){
    var progress by remember {
        mutableStateOf(0.1f)
    }

    //定时更新进度
    LaunchedEffect(key1 =true){
        while(progress <1f){
            progress += 0.01f
            delay(50)
        }
    }
    //使用CircularProgressIndicator构建环形进度条
    CircularProgressIndicator(progress = progress, strokeWidth = 4.dp)
}

 上述代码将创建一个环形的ProgressBar,其进度由变量progress控制,通过LaunchedEffect协程每50毫秒更新一次。

在Jetpack Compose中,通过改变ProgressBar的进度,颜色和形状,可以根据应用的需求来定制ProgressBar的外观和行为。

案例2:模仿下载

@Preview
@Composable
fun DownloadProgressBar(){
    var downloadProgress by remember{
        mutableStateOf(0f)
    }
    var isDownloading by remember{
        mutableStateOf(false)
    }

    Column(modifier = Modifier.fillMaxSize(), horizontalAlignment = Alignment.CenterHorizontally, verticalArrangement = Arrangement.Center){
        Button(onClick = {
            isDownloading =true
        }){
            Text(text = "开始下载")
        }
        Spacer(modifier = Modifier.height(30.dp))
        if(isDownloading){
            CircularProgressIndicator(progress = downloadProgress, strokeWidth = 4.dp)
            //使用协程模拟下载进度
            LaunchedEffect(key1 = true){
                while (downloadProgress < 1f){
                    downloadProgress += 0.01f
                    delay(100)//伪装下载进度
                }
            }
        }
    }
}

 在这个例子中,当点击按钮时,变量isDownloading被设置为true,并显示CircularProgressIndicator。然后,通过LaunchedEffect协程在一段时间内逐渐增加downloadProgress变量的值,模拟了下载进度。当downloadProgress达到1.0时,下载完成。

案例3:长形进度条

@Preview
@Composable
fun FileDownload(){
    var progress by remember {
        mutableStateOf(0f)
    }
    LaunchedEffect(Unit){
        while (progress<1f){
            progress += 0.01f
            delay(100)
        }
    }
    Column(modifier = Modifier.padding(16.dp)){
        Text(text = "下载进度")
        LinearProgressIndicator(progress = progress, color = MaterialTheme.colors.error)
    }
}

 

在这个示例中,我们创建了一个FileDownload函数,该函数是一个Composable函数,用于定义我们的下载界面。它有一个本地状态progress,用于表示下载进度,其值从0(即没有进度)到1(即100%进度)。

LaunchedEffect是一个Jetpack Compose的内置函数,它用于在应用的生命周期中启动和管理协程。在这个例子中,我们使用LaunchedEffect启动一个协程来模拟文件的下载进度。每隔100毫秒,progress就会增加0.01,模拟文件下载的进度。

最后,我们创建了一个LinearProgressIndicator,这是Jetpack Compose提供的一个用于显示进度条的Composable函数。我们将progress作为其参数传入,因此LinearProgressIndicator的长度会根据progress的值变化。

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

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

相关文章

ChatGPT使用的SSE技术是什么?

在现代web应用程序中&#xff0c;实时通信变得越来越重要。HTTP协议的传统请求/响应模式总是需要定期进行轮询以获得最新的数据&#xff0c;这种方式效率低下并且浪费资源。因此&#xff0c;出现了一些新的通信技术&#xff0c;如WebSocket和SSE。但是&#xff0c;GPT为什么选择…

R语言学习4:比例的假设检验

一、实验目的 1. 掌握理解两个总体比例假设检验的相关概念。 2. 掌握理解两个总体比例假设检验的相关方法。 3. 熟悉R语言等语言的集成开发环境。 二、实验分析与内容 完成教材P98的第4题 在一个流行病事件中,A地区656 例病人中完全康复了474人,B地区568例病人中完全康复了…

k8s delete namespace Terminating

版本情况 kubenetes版本: v1.19.10 docker版本: v20.10.6 一、问题经过 早上发现 kubectl delete ns时, 删除namespace一直处于Terminating状态 尝试加上--force参数&#xff0c;执行kubectl delete ns --force&#xff0c;也是一样Terminating 当时Terminating截图 1、猜测…

《网络安全0-100》低层协议安全性

低层协议安全性 IP协议 对于网络层&#xff0c;IP协议是其中一个非常重要的协议。网络层的IP地址相当于数据链路层的Mac地址。协议字段如下&#xff0c;每行4字节&#xff0c;总共4*520字节。 IP协议安全性&#xff1a;IP协议不能保证数据就是从数据包中给定的源地址发出的&am…

高速 AD/DA 实验

目录 高速 AD/DA 实验 1、简介 1.1、AD9708 芯片 1.2、AD9280 芯片 2、实验任务 3、硬件设计 4、程序设计 4.1、AD/DA 顶层模块代码 4.2、创建一个 ​​​​​​​ILA IP 核 4.3、创建一个ROM IP核&#xff0c;将 .coe 文件保存到生成的 Rom IP 核中 4.4、DA 数据发…

人工智能基础实验报告

蒙特卡洛算法 目 录 蒙特卡洛算法 1 概述&#xff1a; 1 思考步骤: 1 应用&#xff1a; 1 特点: 2 参 考 资 料 3 概述&#xff1a; 蒙特卡罗法&#xff08;Monte Carlo method&#xff09;也称统计模拟法、统计试验法。是把概率现象作为研究对象的数值模拟方法。是按抽样调…

【操作系统】CPU调度

目录 1.什么叫调度 2.调度的目标 3.进程调度方式 4.闲逛进程 5.典型的调度算法 5.1先来先服务(FCFS)调度算法 5.2短作业优先(SJF) 调度算法 5.3优先级调度算法 5.4高响应比优先调度算法 5.5时间片轮转调度算法 5.6多级队列调度算法 5.7多级反馈队列调度算法(融合了前…

Qgis基本操作之图层符号化和标注实战

目录 前言 一、基础数据 1、公共预算收入数据简介 2、省份数据简介 二、地图标注 1、百强县公共预算收入地图标注 2、省信息标注 三、地图符号化 1、百强县公共预算收入符号化 2、省数据符号化 总结 前言 在之前的Qgis中进行Shp和Excel属性连接实现百强县公共预算空间分…

MATLAB 之 图形对象及其句柄和图形窗口与坐标轴

这里写目录标题 一、图形对象及其句柄1. 图形对象2. 图形对象句柄的使用3. 图形对象属性3.1 属性名与属性值3.2 属性的操作3.3 图形对象的公共属性 二、图形窗口与坐标轴1. 图形窗口对象2. 坐标轴对象 一、图形对象及其句柄 MATLAB 的图形系统是面向图形对象的。图形对象是 MA…

Redis新功能

Redis 新功能 ACL 参考官网&#xff1a;https://redis.io/topics/acl 基本介绍 1、Redis ACL 是Access Control List&#xff08;访问控制列表&#xff09;的缩写&#xff0c;该功能根据可以执行的命令和可以访问的键来限制某些连接 2、在Redis 5 版本之前&#xff0c;Red…

使用python做一个批量重命名文件的小工具

&#x1f6f4; 放松 端午放假前的下午&#x1f644; 没事儿可做&#xff0c;一个准备开始弄的项目里面有大量的图片&#xff0c;但是名字都乱七八糟的&#xff0c;作为一个稍微带点强迫症的人看不下去。 既然如此&#xff0c;想直接重命名&#xff0c;可是Windows的重命名效果…

《XrayGLM:基于VisualGLM-6B微调训练对X光胸片进行医学诊断》学习分享与本地项目微调部署实践

XrayGLM据说是首个会看胸部X光片的中文多模态医学大模型&#xff0c;我最近也是因为关注这个所以就找时间学习了一下&#xff0c;顺便把学习资料对应记录分享一下。 官方提供了开源的项目&#xff0c;地址在这里&#xff0c;如下所示&#xff1a; 最近&#xff0c;通用领域的大…

MySQL - 第6节 - MySQL表的增删查改

1.MySQL表的增删查改概述 • 表的增删查改简称CRUD&#xff1a;Create&#xff08;新增&#xff09;&#xff0c;Retrieve&#xff08;查找&#xff09;&#xff0c;Update&#xff08;修改&#xff09;&#xff0c;Delete&#xff08;删除&#xff09;。 • CRUD的操作对象是对…

抖音小店有哪些常见扣分原因?如何避免在抖音小店中被扣分?

抖音小店现在已经成为了很多商家的首选电商平台&#xff0c;但是在使用抖音小店的过程中&#xff0c;也会出现一些扣分的情况。接下来&#xff0c;四川不若与众将为大家介绍抖音小店扣分的原因和避免办法。 一、抖音小店扣分原因 1. 服务不到位&#xff1a;商家没有及时回复用户…

2023-01-06 VMWare桥接网络配置.md

VMWare16 桥接网络配置 一 环境清单 VMWare 16虚拟机&#xff1a;Centos7宿主机&#xff1a;Windows 10 二 配置过程 查看宿主机的IP相关信息 ipconfig -all 配置虚拟网络编辑器 2.1 打开VMware Workstation Pro&#xff0c;点击左上角编辑-->虚拟网络编辑器 2.2 点击更改配…

CRM商机管理:提升客户体验和销售效率

如何利用CRM系统提升商机管理&#xff1f; 花点时间思考一下你的企业管理商机的方法&#xff0c;是否有以下情况&#xff1a; ● 不知道渠道中的商机是否可行。 ● 不知道应该关注哪些商机。 ● 花了几个小时或几天的时间来跟进商机。 ● 不知道赢得商机与失去商机的比例。 如…

【Kafka】Suppressed: java.nio.file.AccessDeniedException问题的解决

【Kafka】Suppressed: java.nio.file.AccessDeniedException问题的解决 目录 前言 一、错误发生的原因 二、问题如何解决 前言 今天在运行kafka时&#xff0c;出现了如下图的报错Suppressed: java.nio.file.AccessDeniedException&#xff0c;怎么启动也启动不起来。那此问…

C/C++的命令执行分析

背景 最近发现一个命令执行风险&#xff1b; 一开始提供修复建议&#xff0c;是对特殊字符进行过滤&#xff0c;但是业务侧没有办法过滤&#xff0c;因为输入点是没有办法限制的&#xff0c;然后提供另一个方案是将用户的输入写到配置文件中&#xff0c;然后再进行操作&#x…

LeetCode24. 两两交换链表中的节点+19. 删除链表的倒数第 N 个结点

24. 两两交换链表中的节点 题目描述&#xff1a; 给你一个链表&#xff0c;两两交换其中相邻的节点&#xff0c;并返回交换后链表的头节点。你必须在不修改节点内部的值的情况下完成本题&#xff08;即&#xff0c;只能进行节点交换&#xff09;。 输入&#xff1a;head [1…

蓝牙 - 抓包工具BPA600介绍

BPA 600开箱后&#xff0c;先把天线(antenna)装在后面的SMA接口上。 SMA connectors: SMA&#xff08;SubMiniature version A&#xff09;连接器是在20世纪60年代开发的半精密同轴射频连接器&#xff0c;是一种用于同轴电缆的最小连接器接口&#xff0c;具有螺旋式耦合机制。…