欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Flutter自定義年月日倒計時

 更新時間:2022年03月24日 09:17:26   作者:xudailong_blog  
這篇文章主要為大家詳細介紹了Flutter自定義年月日倒計時,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了Flutter自定義年月日倒計時的具體代碼,供大家參考,具體內(nèi)容如下

因項目中的訂單頁需要一個定時器,比如下單后需要進行倒計時,等倒計時完后,訂單狀態(tài)自動關(guān)閉。

如圖:

這里顯示等17分25秒就是我們所需要做的功能。

項目里還有其他倒計時類型,比如年月日,天之類的,

先上一個工具類:

//時間格式化,根據(jù)總秒數(shù)轉(zhuǎn)換為對應(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小時$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)+'秒后自動取消';
? }
? //數(shù)字格式化,將 0~9 的時間轉(zhuǎn)換為 00~09
? static String formatTime(int timeNum) {
? ? return timeNum < 10 ? "0" + timeNum.toString() : timeNum.toString();
? }

再看一下如何使用:

class OrderPageState extends State<OrderPage> {

? String countContent ; // 倒計時內(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ù)減一,因為一秒回調(diào)一次
? ? ? ? seconds --;
// ? ? ? ?print('我在更新界面>>>>>>>>>>>>>> $seconds');
? ? ? });
? ? ? if (seconds == 0) {
? ? ? ? //倒計時秒數(shù)為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);
? ? ? ? ? ? //獲取總秒數(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方法中銷毀該定時器,不然會一只走下去的,其中countContent可以寫在具體的text中,大概就是這樣。

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

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

    Android Studio升級到3.0后遇到的坑

    自從谷歌發(fā)布Android Studio 3.0版本后,一直心向往之,終于抽時間做了下升級處理,現(xiàn)在把升級過程中遇到的一些問題以及解決方案分享給大家,希望對大家能給有事幫助
    2017-11-11
  • Android開發(fā)中requestfocus()無效的原因及解決辦法

    Android開發(fā)中requestfocus()無效的原因及解決辦法

    這篇文章主要介紹了Android開發(fā)中requestfocus()無效的原因及解決辦法,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2016-08-08
  • Android實現(xiàn)歡迎頁快速啟動的方法

    Android實現(xiàn)歡迎頁快速啟動的方法

    這篇文章主要給大家介紹了Android實現(xiàn)歡迎頁快速啟動的方法,文中給出了詳細的方法介紹,對大家具有一定的參考價值,需要的朋友們可以一起來學習學習。
    2017-02-02
  • 詳解Android中AIDL的使用

    詳解Android中AIDL的使用

    AIDL是Android Interface definition language的縮寫,對于小白來說,AIDL的作用是讓你可以在自己的APP里綁定一個其他APP的service,這樣你的APP可以和其他APP交互,接下來通過本文給大家分享Android AIDL使用,需要的朋友參考下吧
    2021-07-07
  • 基于Android實現(xiàn)保存圖片到本地并可以在相冊中顯示出來

    基于Android實現(xiàn)保存圖片到本地并可以在相冊中顯示出來

    App應(yīng)用越來越人性化,不僅界面優(yōu)美而且服務(wù)也很多樣化,操作也非常方便。通過本篇文章給大家介紹基于Android實現(xiàn)保存圖片到本地并可以在相冊中顯示出來,對android保存圖片相關(guān)知識感興趣的朋友一起學習吧
    2015-12-12
  • Android微信右滑退出功能的實現(xiàn)代碼

    Android微信右滑退出功能的實現(xiàn)代碼

    這篇文章主要介紹了Android微信右滑退出功能的實現(xiàn)代碼,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2018-01-01
  • Android開發(fā)調(diào)用WebService的方法示例

    Android開發(fā)調(diào)用WebService的方法示例

    這篇文章主要介紹了Android開發(fā)調(diào)用WebService的方法,結(jié)合實例形式較為詳細的分析了Android調(diào)用WebService的原理、實現(xiàn)方法與相關(guān)操作注意事項,需要的朋友可以參考下
    2017-10-10
  • Android實現(xiàn)跑馬燈效果的方法

    Android實現(xiàn)跑馬燈效果的方法

    這篇文章主要介紹了Android實現(xiàn)跑馬燈效果的方法,通過頁面XML布局設(shè)置實現(xiàn)帶有跑馬燈效果的文字滾動顯示功能,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-10-10
  • 一款適用于Android平臺的俄羅斯方塊

    一款適用于Android平臺的俄羅斯方塊

    這篇文章主要為大家詳細介紹了一款適用于Android平臺的俄羅斯方塊,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-06-06
  • Android獲取移動網(wǎng)絡(luò)信號強度的方法

    Android獲取移動網(wǎng)絡(luò)信號強度的方法

    這篇文章主要介紹了Android獲取移動網(wǎng)絡(luò)信號強度的方法,幫助大家更好的理解和學習使用Android,感興趣的朋友可以了解下
    2021-04-04

最新評論