news 2026/6/14 7:20:22

FlutterOpenHarmony进度指示器组件开发

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
FlutterOpenHarmony进度指示器组件开发

前言

进度指示器是应用中反馈操作状态的重要组件,它告诉用户当前正在进行的操作以及完成进度。在笔记应用中,文件上传、数据同步、批量操作等场景都需要使用进度指示器。一个设计良好的进度指示器应该清晰地传达进度信息,同时不过度干扰用户的操作。本文将详细介绍如何在Flutter和OpenHarmony平台上实现各种进度指示器组件。

Flutter CircularProgressIndicator

Flutter提供了圆形进度指示器组件。

classLoadingWidgetextendsStatelessWidget{@overrideWidgetbuild(BuildContext context){returnCenter(child:CircularProgressIndicator(strokeWidth:3,valueColor:AlwaysStoppedAnimation<Color>(Colors.blue),),);}}

CircularProgressIndicator是Material风格的圆形加载指示器。不设置value属性时显示为不确定进度的旋转动画,适合不知道具体进度的加载场景。strokeWidth设置圆环的宽度,valueColor设置颜色。AlwaysStoppedAnimation用于设置固定颜色,也可以使用动画颜色。这种简洁的加载指示器适合大多数加载场景。

CircularProgressIndicator(value:_progress,strokeWidth:4,backgroundColor:Colors.grey.shade200,valueColor:AlwaysStoppedAnimation<Color>(Colors.green),)

设置value属性后显示确定进度,value范围是0.0到1.0。backgroundColor设置背景圆环的颜色,与进度颜色形成对比。确定进度的指示器适合文件上传、下载等可以计算进度的场景。用户可以清楚地看到操作完成了多少,还需要等待多久。

Flutter LinearProgressIndicator

线性进度指示器以条形显示进度。

Column(children:[Text('同步中...'),SizedBox(height:8),LinearProgressIndicator(value:_syncProgress,backgroundColor:Colors.grey.shade200,valueColor:AlwaysStoppedAnimation<Color>(Colors.blue),minHeight:6,),SizedBox(height:4),Text('${(_syncProgress * 100).toInt()}%'),],)

LinearProgressIndicator是线性进度条,适合在有限宽度内显示进度。minHeight设置进度条的高度。配合文字说明和百分比显示,可以提供完整的进度信息。线性进度条常用于页面顶部或对话框中,不会占用太多空间。

LinearProgressIndicator(borderRadius:BorderRadius.circular(4),minHeight:8,value:_progress,backgroundColor:Colors.grey.shade300,valueColor:AlwaysStoppedAnimation<Color>(_progress<0.3?Colors.red:_progress<0.7?Colors.orange:Colors.green,),)

进度条可以根据进度值显示不同的颜色,低进度显示红色,中等进度显示橙色,高进度显示绿色。borderRadius设置圆角使进度条更加美观。这种动态颜色变化可以直观地传达进度状态,让用户对完成情况有更清晰的认知。

OpenHarmony进度指示器

OpenHarmony提供了Progress组件实现进度显示。

@Entry @Component struct LoadingPage{@State isLoading:boolean=truebuild(){Column(){if(this.isLoading){LoadingProgress().width(50).height(50).color('#1890FF')Text('加载中...').fontSize(14).fontColor('#666666').margin({top:12})}}.width('100%').height('100%').justifyContent(FlexAlign.Center)}}

LoadingProgress是OpenHarmony提供的加载动画组件,显示为旋转的圆形指示器。width和height设置尺寸,color设置颜色。配合条件渲染,可以在加载完成后隐藏指示器。这种不确定进度的指示器适合网络请求、数据加载等场景。

Progress({value:this.currentProgress,total:100,type:ProgressType.Linear}).width('100%').height(8).color('#1890FF').backgroundColor('#E0E0E0').style({strokeWidth:8})

Progress组件支持多种类型的进度显示。value是当前进度值,total是总进度值,type指定进度条类型。ProgressType.Linear是线性进度条,还支持Ring环形、Eclipse月食形等类型。style属性可以进一步自定义样式。这种声明式的API使得进度条的配置非常直观。

Progress({value:this.progress,total:100,type:ProgressType.Ring}).width(100).height(100).color('#52C41A').backgroundColor('#F0F0F0').style({strokeWidth:10})Text(this.progress+'%').fontSize(20).fontWeight(FontWeight.Bold)

环形进度条适合在中心显示百分比数字。ProgressType.Ring创建环形进度条,strokeWidth设置环的宽度。将Text组件叠加在Progress上方可以显示具体的百分比数值。这种设计在文件上传、任务完成度等场景中非常常见。

自定义进度指示器

有时需要自定义进度指示器以匹配应用风格。

classCustomProgressBarextendsStatelessWidget{finaldouble progress;finalColor backgroundColor;finalColor progressColor;finaldouble height;constCustomProgressBar({requiredthis.progress,this.backgroundColor=Colors.grey,this.progressColor=Colors.blue,this.height=8,});@overrideWidgetbuild(BuildContext context){returnContainer(height:height,decoration:BoxDecoration(color:backgroundColor,borderRadius:BorderRadius.circular(height/2),),child:FractionallySizedBox(alignment:Alignment.centerLeft,widthFactor:progress.clamp(0.0,1.0),child:Container(decoration:BoxDecoration(color:progressColor,borderRadius:BorderRadius.circular(height/2),),),),);}}

自定义进度条使用Container和FractionallySizedBox实现。外层Container作为背景,FractionallySizedBox根据progress值控制内层Container的宽度比例。clamp确保进度值在有效范围内。圆角设置为高度的一半形成胶囊形状。这种自定义方式可以完全控制进度条的外观。

classStepProgressIndicatorextendsStatelessWidget{finalint currentStep;finalint totalSteps;constStepProgressIndicator({requiredthis.currentStep,requiredthis.totalSteps,});@overrideWidgetbuild(BuildContext context){returnRow(children:List.generate(totalSteps,(index){finalisCompleted=index<currentStep;finalisCurrent=index==currentStep;returnExpanded(child:Container(height:4,margin:EdgeInsets.symmetric(horizontal:2),decoration:BoxDecoration(color:isCompleted?Colors.blue:isCurrent?Colors.blue.shade200:Colors.grey.shade300,borderRadius:BorderRadius.circular(2),),),);}),);}}

步骤进度指示器将进度分为多个步骤显示,适合多步骤流程的场景。List.generate根据总步骤数生成进度段,每段根据当前步骤显示不同的颜色。已完成的步骤显示主色,当前步骤显示浅色,未完成的步骤显示灰色。这种设计让用户清楚地知道当前处于哪个步骤。

带动画的进度更新

进度更新时添加动画可以提升视觉效果。

classAnimatedProgressBarextendsStatefulWidget{finaldouble progress;constAnimatedProgressBar({requiredthis.progress});@override_AnimatedProgressBarStatecreateState()=>_AnimatedProgressBarState();}class_AnimatedProgressBarStateextendsState<AnimatedProgressBar>withSingleTickerProviderStateMixin{late AnimationController _controller;late Animation<double>_animation;double _oldProgress=0;@overridevoidinitState(){super.initState();_controller=AnimationController(duration:Duration(milliseconds:300),vsync:this,);_animation=Tween<double>(begin:0,end:widget.progress).animate(_controller);_controller.forward();}@overridevoiddidUpdateWidget(AnimatedProgressBar oldWidget){super.didUpdateWidget(oldWidget);if(oldWidget.progress!=widget.progress){_oldProgress=oldWidget.progress;_animation=Tween<double>(begin:_oldProgress,end:widget.progress).animate(_controller);_controller.forward(from:0);}}@overrideWidgetbuild(BuildContext context){returnAnimatedBuilder(animation:_animation,builder:(context,child){returnCustomProgressBar(progress:_animation.value);},);}}

AnimatedProgressBar在进度值变化时添加平滑的过渡动画。didUpdateWidget检测progress属性的变化,创建从旧值到新值的动画。AnimatedBuilder监听动画并重建进度条。这种动画效果让进度更新更加流畅自然,提升用户体验。

总结

进度指示器是应用中反馈操作状态的重要组件。Flutter和OpenHarmony都提供了丰富的进度指示器组件,包括圆形、线性、环形等多种类型。开发者可以根据场景选择合适的类型,并通过自定义样式和动画效果提升视觉体验。良好的进度反馈可以减少用户的等待焦虑,提升应用的整体体验。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/12 1:13:06

从0到1掌握社交网络分析:大数据技术实战指南

从0到1掌握社交网络分析&#xff1a;大数据技术实战指南 关键词&#xff1a;社交网络分析、大数据技术、图论、数据挖掘、网络结构、节点分析、链路预测 摘要&#xff1a;本文旨在为读者提供一份从基础概念到实战应用的社交网络分析与大数据技术结合的全面指南。首先介绍社交网…

作者头像 李华
网站建设 2026/6/14 0:10:43

Excalidraw呈现大模型推理流程:Token生成路径图

Excalidraw呈现大模型推理流程&#xff1a;Token生成路径图 在一场紧急的技术评审会上&#xff0c;团队正围绕一个新上线的大语言模型&#xff08;LLM&#xff09;的推理延迟问题展开讨论。有人提到“KV Cache复用似乎没有生效”&#xff0c;但不同成员对这一机制的理解存在偏差…

作者头像 李华
网站建设 2026/6/13 9:06:22

41、Windows 7 数据权限管理与共享全解析

Windows 7 数据权限管理与共享全解析 1. 继承权限 在 Windows 系统中,文件夹内的所有文件和文件夹默认会继承在安装时分配的权限,或者在修改文件夹权限时由用户分配的权限。对于磁盘或其他存储设备,继承权限的顶级文件夹是根文件夹。例如,C 盘的顶级文件夹是 C:\ ,分配给…

作者头像 李华
网站建设 2026/6/13 20:45:26

MiniMax通过上市聆讯:持有现金超10亿美元 阿里米哈游腾讯加持

雷递网 雷建平 12月21日通用人工智能&#xff08;AGI&#xff09;公司MiniMax&#xff08;稀宇科技&#xff09;今日通过上市聆讯&#xff0c;有望刷新记录&#xff0c;成为从成立到IPO历时最短的AI公司。截至2025年9月30日&#xff0c;MiniMax持有的现金结余10.46亿美元。Mini…

作者头像 李华
网站建设 2026/6/11 23:46:14

Excalidraw构建边缘计算拓扑:端边云协同模型

Excalidraw构建边缘计算拓扑&#xff1a;端边云协同模型 在智能制造工厂的一次架构评审会上&#xff0c;团队成员围坐在屏幕前——不是对着冷冰冰的UML图&#xff0c;而是一幅略带“手绘感”的系统拓扑草图。车间主管指着画布一角说&#xff1a;“这个边缘节点应该直接连PLC&am…

作者头像 李华
网站建设 2026/6/13 3:14:23

Gartner报告解读:Agentic AI将成2025智能制造主流,提示工程架构师如何布局?

Gartner报告解读:Agentic AI将成2025智能制造主流,提示工程架构师如何布局? 摘要/引言 在科技飞速发展的当下,智能制造领域正经历着前所未有的变革。Gartner报告指出,到2025年,Agentic AI将成为智能制造的主流技术。这一趋势对工程架构师而言,既带来了巨大的机遇,也提…

作者头像 李华