Flutter实现倒计时秒数转时分秒然后倒计时功能
Flutter实现倒计时功能
发布时间:2023/05/12本文实例为大家分享了Flutter实现倒计时功能的具体代码,供大家参考,具体内容如下
有一个需求,需要在页面进行显示倒计时,倒计时结束后,做相应的逻辑处理。
实现思路:在Flutter中,Timer.periodic提供了循环功能,查看函数定义:
factory Timer.periodic(Duration duration, void callback(Timer timer))
第一个参数就是时间间隔,第二个参数就是事件处理回调。
由于后台返回的是秒数,所以需要根据总秒数计算小时,分钟,秒。同时,当不满一个小时时,只显示分钟和秒数,当分钟和秒数只有一个数时(比如1分8秒,显示为01:08)前面加“0”处理。
完整代码:
import 'package:flutter/material.dart'; import 'dart:async'; class CounterDownPage extends StatefulWidget { @override _CounterDownPageState createState() => _CounterDownPageState(); } class _CounterDownPageState extends State<CounterDownPage> { // 用来在布局中显示相应的剩余时间 String remainTimeStr = ''; Timer _timer; //倒计时 void startCountDown(int time) { // 重新计时的时候要把之前的清除掉 if (_timer != null) { if (_timer.isActive) { _timer.cancel(); _timer = null; } } if (time <= 0) { return; } var countTime = time; const repeatPeriod = const Duration(seconds: 1); _timer = Timer.periodic(repeatPeriod, (timer) { if (countTime <= 0) { timer.cancel(); timer = null; //待付款倒计时结束,可以在这里做相应的操作 return; } countTime--; //外面传进来的单位是秒,所以需要根据总秒数,计算小时,分钟,秒 int hour = (countTime ~/ 3600) % 24;//如果不止24小时的就不用%24 int minute = countTime % 3600 ~/60; int second = countTime % 60; var str = ''; if (hour > 0) { str = str + hour.toString()+':'; } if (minute / 10 < 1) {//当只有个位数时,给前面加“0”,实现效果:“:01”,":02" str = str + '0' + minute.toString() + ":"; } else { str = str + minute.toString() + ":"; } if (second / 10 < 1) { str = str + '0' + second.toString(); } else { str = str + second.toString(); } setState(() { remainTimeStr = str; }); }); } @override void initState() { super.initState(); //开始倒计时,这里传入的是秒数 startCountDown(5000); } @override void dispose() { super.dispose(); if (_timer != null) { if (_timer.isActive) { _timer.cancel(); _timer = null; } } } @override Widget build(BuildContext context) { return Scaffold( appBar: AppBar( title: Text("倒计时"), ), body: Center( child: Row( mainAxisAlignment: MainAxisAlignment.center, children: [ Text("剩余", style: TextStyle( fontSize: 18, color: Color.fromRGBO(255, 111, 50, 1), fontWeight: FontWeight.bold ),), Text(remainTimeStr.length > 0 ? remainTimeStr: "--", style: TextStyle( fontSize: 18, color: Color.fromRGBO(255, 111, 50, 1), fontWeight: FontWeight.bold ),), ], ), ), ); } }
服务器返回的时间戳87392,现在的时间戳+87392 现在的时间戳,两者的时间戳相差二十多个小时,也就是说87392就是秒数,直接传秒数到上面的startCountDown方法即可。
到此这篇关于Flutter实现倒计时功能,秒数转时分秒,然后倒计时的文章就介绍到这了,更多相关Flutter倒计时内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
Android开启闪光灯的方法 Android打开手电筒功能
这篇文章主要为大家详细介绍了Android开启闪光灯的方法,Android打开手电筒功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下2017-07-07android中使用Activity实现监听手指上下左右滑动
这篇文章主要介绍了android中使用Activity实现监听手指上下左右滑动,本文使用了Activity的ontouchEvent方法监听手指点击事件,并给出代码实例,需要的朋友可以参考下2015-05-05解决android studio android monitor打不开的问题
下面小编就为大家分享一篇解决android studio android monitor打不开的问题,具有很的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2018-01-01Android RecyclerView添加搜索过滤器的示例代码
本篇文章主要介绍了Android RecyclerView添加搜索过滤器的示例代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧2018-01-01Android涨姿势知识点之你没用过的BadgeDrawable
现在Android中有许多的应用仿苹果的在应用图标上显示小红点,下面这篇文章主要给大家介绍了关于Android涨姿势知识点之你没用过的BadgeDrawable的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考下2022-09-09
最新评论