Flutter开发圆形计时进度条RingProgressBar
创始人
2024-05-28 17:12:17
0
  • 演示

        先看效果图:

        

        由于无法截取动态图,我就截过程中的两张图片表达了,我想应该能看得懂。

  • 功能

        1.设置进度条半径

        2.设置进度条宽度

        3.设置进度条最大值

        4.设置进度条背景色以及前景色

        5.是否显示进度条文字

        6.文字样式设置

        7.点击进度条和进度条计时完成回调

        8.进度条是倒计时还是正计时设置

  •  代码
import 'dart:async';
import 'dart:math';import 'package:flutter/material.dart';class RingProgressBar extends StatefulWidget {/// 半径final double radius;/// 环颜色final Color? ringColor;/// 环背景颜色final Color? ringBgColor;/// 环中间文字final Color? textColor;/// 环中间文字大小final double? textSize;/// 环宽度final double strokeWidth;/// 是否显示环中间文本final bool isShowText;/// 环是否是倒计时,true:是倒计时,false:顺计时final bool? isCountDown;/// 计时截至值final int? maxProgress;final VoidCallback? callback;const RingProgressBar({super.key,required this.radius,required this.strokeWidth,this.ringColor,this.ringBgColor,this.isShowText = false,this.textSize,this.textColor,this.isCountDown = true,this.maxProgress,this.callback});@overrideState createState() => _RingProgressBarState();
}class _RingProgressBarState extends State {/// 进度条当前进度值double _value = 0;/// 进度条当前进度文本String _text = "0";/// 计时器Timer? timer;@overridevoid initState() {super.initState();int count = 0;//计时器,每1毫秒执行一次const period = Duration(milliseconds: 1);timer = Timer.periodic(period, (timer) {count++;double max = (widget.maxProgress ?? 0) * 1000;//计时器结束条件if (widget.maxProgress == null ||widget.maxProgress == 0 ||count >= max) {timer.cancel();if (widget.callback != null) {//执行完成回调widget.callback!();}}//只有当widget状态为mounted时才执行setState防止内存泄露if (mounted) {setState(() {_value = count / max;_text = widget.isCountDown ?? true? ((widget.maxProgress ?? 0) - (count ~/ 1000)).toString(): (count ~/ 1000).toString();});}});}@overridevoid dispose() {//退出时关闭计时器防止内存泄露timer?.cancel();super.dispose();}@overrideWidget build(BuildContext context) {return InkWell(highlightColor: Colors.transparent,splashColor: Colors.transparent,onTap: () {if (widget.callback != null) {//点击控件回调widget.callback!();}},child: Container(width: widget.radius * 2,height: widget.radius * 2,color: Colors.transparent,child: Stack(alignment: Alignment.center,fit: StackFit.expand,children: [CustomPaint(size: Size(widget.radius * 2, widget.radius * 2),painter: _RingPrinter(this, _value),),Center(widthFactor: widget.radius * 2,heightFactor: widget.radius * 2,child: widget.isShowText? Text(_text,style: TextStyle(color: widget.textColor, fontSize: widget.textSize),): Container(),),],),));}
}class _RingPrinter extends CustomPainter {/// state对象final _RingProgressBarState state;/// 控制值:0.0->1.0,会控制绘制0.0*2*pi->1.0*2*pi即从0开始绘制一个完整的圆final double _value;_RingPrinter(this.state, this._value);@overridevoid paint(Canvas canvas, Size size) {//画笔Paint paint = Paint()..color = state.widget.ringColor ?? Colors.transparent..style = PaintingStyle.stroke..strokeWidth = state.widget.strokeWidth..isAntiAlias = true;//圆心偏移值double offset = state.widget.radius;//以offset为圆形,画半径减边线宽度一半为半径的圆Rect rect = Rect.fromCircle(center: Offset(offset, offset),radius: state.widget.radius - state.widget.strokeWidth / 2);paint.color = state.widget.ringBgColor ?? Colors.grey;//画圆背景canvas.drawCircle(Offset(offset, offset),state.widget.radius - state.widget.strokeWidth / 2, paint);paint.color = state.widget.ringColor ?? Colors.blueAccent;//让边界有弧形过渡paint.strokeCap = StrokeCap.round;//画进度条canvas.drawArc(rect, -0.5 * pi, _value * 2 * pi, false, paint);}@overridebool shouldRepaint(covariant CustomPainter oldDelegate) {return true;}
}

关键代码 ,该代码可以控制从0.0*2.pi->1.0*2*pi从0开始绘制一个完整的圆,-0.5*pi这个参数是让进度条从12点钟方向开始绘制,系统默认从3点钟方向开始绘制。

//画进度条
canvas.drawArc(rect, -0.5 * pi, _value * 2 * pi, false, paint);

代码可以直接复制下来使用,注释非常完善,欢迎指正。

相关内容

热门资讯

安卓系统能跑win吗,探索跨平... 你有没有想过,你的安卓手机里能不能装上Windows系统呢?这听起来是不是有点像科幻电影里的情节?别...
安卓车载系统蓝牙设置,畅享智能... 你有没有发现,现在开车的时候,手机和车载系统之间的互动越来越频繁了呢?这不,今天就来给你详细说说安卓...
奥利奥安卓系统,探索新一代智能... 你有没有想过,一块小小的奥利奥饼干竟然能和强大的安卓系统扯上关系?没错,今天就要来聊聊这个跨界组合,...
微信使用安卓系统,功能解析与操... 你有没有发现,现在用微信的人越来越多了呢?尤其是安卓系统的用户,简直就像潮水一样涌来。今天,就让我带...
体验最新原生安卓系统,极致体验... 你有没有想过,手机系统就像是我们生活的调味品,有时候换一种口味,生活都会变得有趣起来呢?最近,我体验...
安卓系统能玩原神,尽享奇幻冒险... 你有没有想过,在安卓系统上也能畅玩《原神》这样的热门游戏呢?没错,就是那个画面精美、角色丰富、玩法多...
安卓写手机银行系统,基于安卓平... 你有没有想过,手机银行系统在我们日常生活中扮演了多么重要的角色呢?每天刷刷手机,就能轻松管理账户,转...
僵尸之夜恐怖安卓系统,揭秘恐怖... 僵尸之夜,恐怖安卓系统来袭!想象一个寂静的夜晚,你正沉浸在美梦中,突然,一阵诡异的铃声打破了夜的宁静...
谷歌框架和安卓系统,构建智能移... 你有没有想过,为什么你的手机那么聪明,能帮你找到路线,还能帮你拍出美美的照片呢?这都要归功于一个超级...
安卓系统和oppo系统哪个流畅... 你有没有想过,手机系统哪个更流畅呢?安卓系统和OPPO系统,这两个名字听起来就让人心动。今天,咱们就...
安卓怎么用微软系统,利用微软系... 你是不是也和我一样,对安卓手机上的微软系统充满了好奇?想象那熟悉的Windows界面在你的安卓手机上...
安卓系统如何安装nfc,安卓系... 你有没有想过,用手机刷公交卡、支付账单,是不是比掏出钱包来得酷炫多了?这就得归功于NFC技术啦!今天...
ios系统可以转安卓,跨平台应... 你有没有想过,你的iPhone手机里的那些宝贝应用,能不能搬到安卓手机上继续使用呢?没错,今天就要来...
iOSapp移植到安卓系统,i... 你有没有想过,那些在iOS上让你爱不释手的app,是不是也能在安卓系统上大放异彩呢?今天,就让我带你...
现在安卓随便换系统,探索个性化... 你知道吗?现在安卓手机换系统简直就像换衣服一样简单!没错,就是那种随时随地、随心所欲的感觉。今天,就...
安卓系统安装按钮灰色,探究原因... 最近发现了一个让人头疼的小问题,那就是安卓手机的安装按钮突然变成了灰色,这可真是让人摸不着头脑。你知...
安卓7.1.1操作系统,系统特... 你知道吗?最近我在手机上发现了一个超级酷的新玩意儿——安卓7.1.1操作系统!这可不是什么小打小闹的...
安卓os系统怎么设置,并使用`... 你有没有发现,你的安卓手机有时候就像一个不听话的小孩子,有时候设置起来真是让人头疼呢?别急,今天就来...
安卓降低系统版本5.1,探索安... 你知道吗?最近安卓系统又来了一次大动作,竟然把系统版本给降到了5.1!这可真是让人有点摸不着头脑,不...
解放安卓系统被保护,解放安卓系... 你有没有想过,你的安卓手机其实可以更加自由地呼吸呢?是的,你没听错,我说的就是解放安卓系统被保护的束...