Flutter自定義年月日倒計(jì)時(shí)
本文實(shí)例為大家分享了Flutter自定義年月日倒計(jì)時(shí)的具體代碼,供大家參考,具體內(nèi)容如下
因項(xiàng)目中的訂單頁需要一個(gè)定時(shí)器,比如下單后需要進(jìn)行倒計(jì)時(shí),等倒計(jì)時(shí)完后,訂單狀態(tài)自動(dòng)關(guān)閉。
如圖:
這里顯示等17分25秒就是我們所需要做的功能。
項(xiàng)目里還有其他倒計(jì)時(shí)類型,比如年月日,天之類的,
先上一個(gè)工具類:
//時(shí)間格式化,根據(jù)總秒數(shù)轉(zhuǎn)換為對(duì)應(yīng)的 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小時(shí)$minute分$second秒后自動(dòng)取消'; ? ? }else if(hour != 0){ ? ? ? return '$hour小時(shí)$minute分$second秒后自動(dòng)取消'; ? ? }else if(minute !=0){ ? ? ? return '$minute分$second秒后自動(dòng)取消'; ? ? }else if(second!=0){ ? ? ? return '$second秒后自動(dòng)取消'; ? ? }else { ? ? ? return ''; ? ? } // ? ?return formatTime(day)+'天'+formatTime(hour) + "小時(shí)" + formatTime(minute) + "分" + formatTime(second)+'秒后自動(dòng)取消'; ? } ? 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小時(shí)$minute分'; ? ? }else if(hour!= 0){ ? ? ? return '剩$hour小時(shí)$minute分'; ? ? }else if(minute!=0){ ? ? ? return '剩$minute分'; ? ? }else { ? ? ? return ''; ? ? } // ? ?return formatTime(day)+'天'+formatTime(hour) + "小時(shí)" + formatTime(minute) + "分" + formatTime(second)+'秒后自動(dòng)取消'; ? } ? //數(shù)字格式化,將 0~9 的時(shí)間轉(zhuǎn)換為 00~09 ? static String formatTime(int timeNum) { ? ? return timeNum < 10 ? "0" + timeNum.toString() : timeNum.toString(); ? }
再看一下如何使用:
class OrderPageState extends State<OrderPage> { ? String countContent ; // 倒計(jì)時(shí)內(nèi)容 ? 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() { ? ? //設(shè)置 1 秒回調(diào)一次 ? ? const period = const Duration(seconds: 1); ? ? _timer = Timer.periodic(period, (timer) { ? ? ? //更新界面 ? ? ? setState(() { ? ? ? ? //秒數(shù)減一,因?yàn)橐幻牖卣{(diào)一次 ? ? ? ? seconds --; // ? ? ? ?print('我在更新界面>>>>>>>>>>>>>> $seconds'); ? ? ? }); ? ? ? if (seconds == 0) { ? ? ? ? //倒計(jì)時(shí)秒數(shù)為0,取消定時(shí)器 ? ? ? ? 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()); ? ? ? ? ? ? //獲取當(dāng)期時(shí)間 ? ? ? ? ? ? var now = DateTime.now(); ? ? ? ? ? ? var twoHours = _diffDate.difference(now); ? ? ? ? ? ? //獲取總秒數(shù),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方法中銷毀該定時(shí)器,不然會(huì)一只走下去的,其中countContent
可以寫在具體的text中,大概就是這樣。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Android開發(fā)中requestfocus()無效的原因及解決辦法
這篇文章主要介紹了Android開發(fā)中requestfocus()無效的原因及解決辦法,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-08-08Android實(shí)現(xiàn)歡迎頁快速啟動(dòng)的方法
這篇文章主要給大家介紹了Android實(shí)現(xiàn)歡迎頁快速啟動(dòng)的方法,文中給出了詳細(xì)的方法介紹,對(duì)大家具有一定的參考價(jià)值,需要的朋友們可以一起來學(xué)習(xí)學(xué)習(xí)。2017-02-02基于Android實(shí)現(xiàn)保存圖片到本地并可以在相冊(cè)中顯示出來
App應(yīng)用越來越人性化,不僅界面優(yōu)美而且服務(wù)也很多樣化,操作也非常方便。通過本篇文章給大家介紹基于Android實(shí)現(xiàn)保存圖片到本地并可以在相冊(cè)中顯示出來,對(duì)android保存圖片相關(guān)知識(shí)感興趣的朋友一起學(xué)習(xí)吧2015-12-12Android微信右滑退出功能的實(shí)現(xiàn)代碼
這篇文章主要介紹了Android微信右滑退出功能的實(shí)現(xiàn)代碼,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2018-01-01Android開發(fā)調(diào)用WebService的方法示例
這篇文章主要介紹了Android開發(fā)調(diào)用WebService的方法,結(jié)合實(shí)例形式較為詳細(xì)的分析了Android調(diào)用WebService的原理、實(shí)現(xiàn)方法與相關(guān)操作注意事項(xiàng),需要的朋友可以參考下2017-10-10Android獲取移動(dòng)網(wǎng)絡(luò)信號(hào)強(qiáng)度的方法
這篇文章主要介紹了Android獲取移動(dòng)網(wǎng)絡(luò)信號(hào)強(qiáng)度的方法,幫助大家更好的理解和學(xué)習(xí)使用Android,感興趣的朋友可以了解下2021-04-04