Flutter自定义年月日倒计时

 更新时间:2022年03月24日 09:17:26   作者:xudailong_blog  
这篇文章主要为大家详细介绍了Flutter自定义年月日倒计时,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了Flutter自定义年月日倒计时的具体代码,供大家参考,具体内容如下

因项目中的订单页需要一个定时器,比如下单后需要进行倒计时,等倒计时完后,订单状态自动关闭。

如图:

这里显示等17分25秒就是我们所需要做的功能。

项目里还有其他倒计时类型,比如年月日,天之类的,

先上一个工具类:

//时间格式化,根据总秒数转换为对应的 hh:mm:ss 格式
  static String constructTime(int seconds) {
    int day = seconds ~/3600 ~/24;
    int hour = seconds ~/ 3600;
    int minute = seconds % 3600 ~/ 60;
    int second = seconds % 60;
    if(day != 0){
      return '$day天$hour小时$minute分$second秒后自动取消';
    }else if(hour != 0){
      return '$hour小时$minute分$second秒后自动取消';
    }else if(minute !=0){
      return '$minute分$second秒后自动取消';
    }else if(second!=0){
      return '$second秒后自动取消';
    }else {
      return '';
    }
//    return formatTime(day)+'天'+formatTime(hour) + "小时" + formatTime(minute) + "分" + formatTime(second)+'秒后自动取消';
  }

  static String constructVipTime(int seconds) {
    int day = seconds ~/3600 ~/ 24;
    int hour = seconds ~/ 3600;
    int minute = seconds % 3600 ~/ 60;
    int second = seconds % 60;
    if(day!= 0){
      return '剩$day天$hour小时$minute分';
    }else if(hour!= 0){
      return '剩$hour小时$minute分';
    }else if(minute!=0){
      return '剩$minute分';
    }else {
      return '';
    }
//    return formatTime(day)+'天'+formatTime(hour) + "小时" + formatTime(minute) + "分" + formatTime(second)+'秒后自动取消';
  }
  //数字格式化,将 0~9 的时间转换为 00~09
  static String formatTime(int timeNum) {
    return timeNum < 10 ? "0" + timeNum.toString() : timeNum.toString();
  }

再看一下如何使用:

class OrderPageState extends State<OrderPage> {

  String countContent ; // 倒计时内容

  Timer _timer;
  int seconds = 0;

  ///.......

   @override
  Widget build(BuildContext context) {

    countContent = Util.constructTime(seconds);

    return new Scaffold(
        appBar: HeadTitleBar(
          text: '订单详情',
          rightShow: true,
          rightIcPath: ImageConstant.icon_talk_black,
          callback: (){
            RouteUtil.jump2ChatPage(context);
          },),
        body: _buildRoot());
  }

  
    void cancelTimer() {
    if (_timer != null) {
      _timer.cancel();
      _timer = null;
    }
  }

  void startTimer() {
    //设置 1 秒回调一次
    const period = const Duration(seconds: 1);
    _timer = Timer.periodic(period, (timer) {

      //更新界面
      setState(() {
        //秒数减一,因为一秒回调一次
        seconds --;
//        print('我在更新界面>>>>>>>>>>>>>> $seconds');
      });
      if (seconds == 0) {
        //倒计时秒数为0,取消定时器
        print('我被取消了  ');
        cancelTimer();
        getData();
      }
    });
  }

    void getData() async{

    await DioUtil.request("xxx",
      method: DioUtil.GET,
      ).then((res) {
        var time = res.orderExprieTime;
        if(time !=null){
          try{
            var _diffDate = DateTime.parse(time.toString());
            //获取当期时间
            var now = DateTime.now();
            var twoHours = _diffDate.difference(now);
            //获取总秒数,2 分钟为 120 秒
            seconds = twoHours.inSeconds;
            startTimer();
          }catch(e){
            seconds = 0;
          }
        }
      }
      loading = true;
      if(!mounted)return;
      setState(() {
      });
    }).catchError((e){
    });
  }
  
 @override
  void dispose() {
    super.dispose();
    cancelTimer();
  }
}

注意:一定要在dispose方法中销毁该定时器,不然会一只走下去的,其中countContent可以写在具体的text中,大概就是这样。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • Android Studio升级到3.0后遇到的坑

    Android Studio升级到3.0后遇到的坑

    自从谷歌发布Android Studio 3.0版本后,一直心向往之,终于抽时间做了下升级处理,现在把升级过程中遇到的一些问题以及解决方案分享给大家,希望对大家能给有事帮助
    2017-11-11
  • Android开发中requestfocus()无效的原因及解决办法

    Android开发中requestfocus()无效的原因及解决办法

    这篇文章主要介绍了Android开发中requestfocus()无效的原因及解决办法,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2016-08-08
  • Android实现欢迎页快速启动的方法

    Android实现欢迎页快速启动的方法

    这篇文章主要给大家介绍了Android实现欢迎页快速启动的方法,文中给出了详细的方法介绍,对大家具有一定的参考价值,需要的朋友们可以一起来学习学习。
    2017-02-02
  • 详解Android中AIDL的使用

    详解Android中AIDL的使用

    AIDL是Android Interface definition language的缩写,对于小白来说,AIDL的作用是让你可以在自己的APP里绑定一个其他APP的service,这样你的APP可以和其他APP交互,接下来通过本文给大家分享Android AIDL使用,需要的朋友参考下吧
    2021-07-07
  • 基于Android实现保存图片到本地并可以在相册中显示出来

    基于Android实现保存图片到本地并可以在相册中显示出来

    App应用越来越人性化,不仅界面优美而且服务也很多样化,操作也非常方便。通过本篇文章给大家介绍基于Android实现保存图片到本地并可以在相册中显示出来,对android保存图片相关知识感兴趣的朋友一起学习吧
    2015-12-12
  • Android微信右滑退出功能的实现代码

    Android微信右滑退出功能的实现代码

    这篇文章主要介绍了Android微信右滑退出功能的实现代码,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2018-01-01
  • Android开发调用WebService的方法示例

    Android开发调用WebService的方法示例

    这篇文章主要介绍了Android开发调用WebService的方法,结合实例形式较为详细的分析了Android调用WebService的原理、实现方法与相关操作注意事项,需要的朋友可以参考下
    2017-10-10
  • Android实现跑马灯效果的方法

    Android实现跑马灯效果的方法

    这篇文章主要介绍了Android实现跑马灯效果的方法,通过页面XML布局设置实现带有跑马灯效果的文字滚动显示功能,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-10-10
  • 一款适用于Android平台的俄罗斯方块

    一款适用于Android平台的俄罗斯方块

    这篇文章主要为大家详细介绍了一款适用于Android平台的俄罗斯方块,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-06-06
  • Android获取移动网络信号强度的方法

    Android获取移动网络信号强度的方法

    这篇文章主要介绍了Android获取移动网络信号强度的方法,帮助大家更好的理解和学习使用Android,感兴趣的朋友可以了解下
    2021-04-04

最新评论