亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Flutter定時器、倒計(jì)時的快速上手及實(shí)戰(zhàn)講解

 更新時間:2019年06月10日 11:01:47   作者:AndroidTraveler  
這篇文章主要給大家介紹了關(guān)于Flutter定時器、倒計(jì)時的快速上手及實(shí)戰(zhàn)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用Flutter具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧

今天給大家講講 Flutter 里面定時器/倒計(jì)時的實(shí)現(xiàn)。

一般有兩種場景:

  • 我只需要你在指定時間結(jié)束后回調(diào)告訴我?;卣{(diào)只需要一次。
  • 我需要你在指定時間結(jié)束后回調(diào)告訴我?;卣{(diào)可能多次。

下面針對這兩種場景,我們來說下如何在 Flutter 里面使用。

回調(diào)一次的定時器

const timeout = const Duration(seconds: 5);
print('currentTime='+DateTime.now().toString());
Timer(timeout, () {
 //到時回調(diào)
 print('afterTimer='+DateTime.now().toString());
});

這里我們設(shè)置了超時時間為 5 秒。然后啟動一個定時器,等到 5 秒時候到了,就會執(zhí)行回調(diào)方法。

我們在定時器啟動之前和之后都加上了打印日志,控制臺打印輸出如下:

flutter: currentTime=2019-06-08 13:56:35.347493
flutter: afterTimer=2019-06-08 13:56:40.350412

用法總結(jié)起來就是:

1.設(shè)置超時時間 timeout

2.啟動定時器 Timer(timeout, callback)

3.處理回調(diào) callback

回調(diào)多次的定時器

回調(diào)多次的定時器用法和回調(diào)一次的差不多,區(qū)別有下面兩點(diǎn):

  • API 調(diào)用不同
  • 需要手動取消,否則會一直回調(diào),因?yàn)槭侵芷谛缘?/li>

一樣的我們通過一個簡單的小例子來說明:

int count = 0;
const period = const Duration(seconds: 1);
print('currentTime='+DateTime.now().toString());
Timer.periodic(period, (timer) {
 //到時回調(diào)
 print('afterTimer='+DateTime.now().toString());
 count++;
 if (count >= 5) {
  //取消定時器,避免無限回調(diào)
  timer.cancel();
  timer = null;
 }
});

這里我們的功能是每秒回調(diào)一次,當(dāng)達(dá)到 5 秒后取消定時器,一共 回調(diào)了 5 次。

控制臺輸出如下:

flutter: currentTime=2019-06-08 14:16:02.906858
flutter: afterTimer=2019-06-08 14:16:03.909963
flutter: afterTimer=2019-06-08 14:16:04.910538
flutter: afterTimer=2019-06-08 14:16:05.911942
flutter: afterTimer=2019-06-08 14:16:06.911741
flutter: afterTimer=2019-06-08 14:16:07.910227

用法總結(jié)起來就是:

1.設(shè)置周期回調(diào)時間 period

2.啟動定時器 Timer.periodic(period, callback(timer))

3.處理回調(diào) callback(timer)

4.記得在合適時機(jī)取消定時器,否則會一直回調(diào)

好了,有了上面的知識儲備,接下來,讓我們進(jìn)入實(shí)戰(zhàn)講解環(huán)節(jié)。

實(shí)戰(zhàn)講解

業(yè)務(wù)場景

服務(wù)器返回一個時間,你根據(jù)服務(wù)器的時間和當(dāng)前時間的對比,顯示倒計(jì)時,倒計(jì)時的時間在一天之內(nèi),超過一天顯示默認(rèn)文案即可。

場景分析

這個業(yè)務(wù)場景在倒計(jì)時這一塊就需要使用到我們上面的知識了。由于限定了倒計(jì)時是在一天之內(nèi),所以顯示的文案就是從 00:00:00 到 23:59:59。

具體代碼操作

基本思路:首先我們需要獲得剩余時間,接著啟動一個 1 秒的周期性定時器,然后每隔一秒更新一下文案。

直接上代碼:

//時間格式化,根據(jù)總秒數(shù)轉(zhuǎn)換為對應(yīng)的 hh:mm:ss 格式
String constructTime(int seconds) {
 int hour = seconds ~/ 3600;
 int minute = seconds % 3600 ~/ 60;
 int second = seconds % 60;
 return formatTime(hour) + ":" + formatTime(minute) + ":" + formatTime(second);
}

//數(shù)字格式化,將 0~9 的時間轉(zhuǎn)換為 00~09
String formatTime(int timeNum) {
 return timeNum < 10 ? "0" + timeNum.toString() : timeNum.toString();
}

//獲取當(dāng)期時間
var now = DateTime.now();
//獲取 2 分鐘的時間間隔
var twoHours = now.add(Duration(minutes: 2)).difference(now);
//獲取總秒數(shù),2 分鐘為 120 秒
var seconds = twoHours.inSeconds;
//設(shè)置 1 秒回調(diào)一次
const period = const Duration(seconds: 1);
//打印一開始的時間格式,為 00:02:00
print(constructTime(seconds));
Timer.periodic(period, (timer) {
 //秒數(shù)減一,因?yàn)橐幻牖卣{(diào)一次
 seconds--;
 //打印減一后的時間
 print(constructTime(seconds));
 if (seconds == 0) {
  //倒計(jì)時秒數(shù)為0,取消定時器
  timer.cancel();
  timer = null;
 }
});

其實(shí)注釋也寫的很清楚了,就是基本思路的基礎(chǔ)上增加了一些細(xì)節(jié)處理,這里演示是自己構(gòu)造了一個兩分鐘的倒計(jì)時。

好了,基本到這里已經(jīng)說完了,但是可能 Flutter 具體一些細(xì)節(jié)還不一樣,這邊直接給下一個倒計(jì)時的完整代碼吧。

import 'dart:async';

import 'package:flutter/material.dart';

class Countdown extends StatefulWidget {
 @override
 _CountdownState createState() => _CountdownState();
}

class _CountdownState extends State<Countdown> {

 Timer _timer;
 int seconds;

 @override
 Widget build(BuildContext context) {
  return Center(
   child: Text(constructTime(seconds)),
  );
 }

 //時間格式化,根據(jù)總秒數(shù)轉(zhuǎn)換為對應(yīng)的 hh:mm:ss 格式
 String constructTime(int seconds) {
  int hour = seconds ~/ 3600;
  int minute = seconds % 3600 ~/ 60;
  int second = seconds % 60;
  return formatTime(hour) + ":" + formatTime(minute) + ":" + formatTime(second);
 }

 //數(shù)字格式化,將 0~9 的時間轉(zhuǎn)換為 00~09
 String formatTime(int timeNum) {
  return timeNum < 10 ? "0" + timeNum.toString() : timeNum.toString();
 }

 @override
 void initState() {
  super.initState();
  //獲取當(dāng)期時間
  var now = DateTime.now();
  //獲取 2 分鐘的時間間隔
  var twoHours = now.add(Duration(minutes: 2)).difference(now);
  //獲取總秒數(shù),2 分鐘為 120 秒
  seconds = twoHours.inSeconds;
  startTimer();
 }

 void startTimer() {
  //設(shè)置 1 秒回調(diào)一次
  const period = const Duration(seconds: 1);
  _timer = Timer.periodic(period, (timer) {
   //更新界面
   setState(() {
    //秒數(shù)減一,因?yàn)橐幻牖卣{(diào)一次
    seconds--;
   });
   if (seconds == 0) {
    //倒計(jì)時秒數(shù)為0,取消定時器
    cancelTimer();
   }
  });
 }

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

 @override
 void dispose() {
  super.dispose();
  cancelTimer();
 }
}

效果如下:


后續(xù)打算寫一個 FlutterApp 涵蓋我之前博客的例子,方便大家結(jié)合代碼查看實(shí)際運(yùn)行效果,敬請期待。

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對腳本之家的支持。

相關(guān)文章

  • Android實(shí)現(xiàn)畫板功能(一)

    Android實(shí)現(xiàn)畫板功能(一)

    這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)畫板功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-05-05
  • android自定義imageview實(shí)現(xiàn)圓角圖片

    android自定義imageview實(shí)現(xiàn)圓角圖片

    這篇文章主要為大家詳細(xì)介紹了android自定義imageview實(shí)現(xiàn)圓角圖片,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-02-02
  • android ViewPager實(shí)現(xiàn)滑動翻頁效果實(shí)例代碼

    android ViewPager實(shí)現(xiàn)滑動翻頁效果實(shí)例代碼

    本篇文章主要介紹了android ViewPager實(shí)現(xiàn)滑動翻頁效果實(shí)例代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。
    2017-03-03
  • Android 擴(kuò)大 View 的點(diǎn)擊區(qū)域的方法

    Android 擴(kuò)大 View 的點(diǎn)擊區(qū)域的方法

    這篇文章主要介紹了Android 擴(kuò)大 View 的點(diǎn)擊區(qū)域的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-04-04
  • Android開發(fā)筆記之: 數(shù)據(jù)存儲方式詳解

    Android開發(fā)筆記之: 數(shù)據(jù)存儲方式詳解

    本篇文章是對Android中數(shù)據(jù)存儲方式進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-05-05
  • Android獲取LinearLayout的寬度和高度示例代碼

    Android獲取LinearLayout的寬度和高度示例代碼

    這篇文章主要介紹了android獲取LinearLayout的寬度和高度,如果想直接獲取在布局文件中定義的組件的寬度和高度,可以直接使用View.getLayoutParams().width和View.getLayoutParams().height,本文結(jié)合示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-08-08
  • Flutter最小刷新范圍探索ValueListenableBuilder使用詳解

    Flutter最小刷新范圍探索ValueListenableBuilder使用詳解

    這篇文章主要為大家介紹了Flutter最小刷新范圍探索ValueListenableBuilder使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-12-12
  • Android Activity的啟動過程源碼解析

    Android Activity的啟動過程源碼解析

    這篇文章主要介紹了Android Activity的啟動過程源碼解析,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-05-05
  • Android視圖綁定viewBinding的使用介紹

    Android視圖綁定viewBinding的使用介紹

    最近這段時間在學(xué)習(xí)Kotlin,突然發(fā)現(xiàn)谷歌已經(jīng)把kotlin-android-extensions插件廢棄,目前推薦使用ViewBinding來進(jìn)行替代,接下來通過本文給大家分享Android使用ViewBinding的詳細(xì)步驟,感興趣的朋友一起學(xué)習(xí)吧
    2023-01-01
  • Android ListView萬能適配器實(shí)例代碼

    Android ListView萬能適配器實(shí)例代碼

    本文主要介紹Android ListView萬能適配器,這里整理了詳細(xì)的資料及實(shí)現(xiàn)代碼,以及實(shí)現(xiàn)效果圖,有需要的小伙伴可以參考下
    2016-09-09

最新評論