首頁 > 軟體

Flutter自定義年月日倒計時

2022-03-24 10:00:14

本文範例為大家分享了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中,大概就是這樣。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援it145.com。


IT145.com E-mail:sddin#qq.com