Flutter自定義年月日倒計(jì)時(shí)
本文實(shí)例為大家分享了Flutter自定義年月日倒計(jì)時(shí)的具體代碼,供大家參考,具體內(nèi)容如下
因項(xiàng)目中的訂單頁(yè)需要一個(gè)定時(shí)器,比如下單后需要進(jìn)行倒計(jì)時(shí),等倒計(jì)時(shí)完后,訂單狀態(tài)自動(dòng)關(guān)閉。
如圖:

這里顯示等17分25秒就是我們所需要做的功能。
項(xiàng)目里還有其他倒計(jì)時(shí)類(lèi)型,比如年月日,天之類(lèi)的,
先上一個(gè)工具類(lèi):
//時(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方法中銷(xiāo)毀該定時(shí)器,不然會(huì)一只走下去的,其中countContent可以寫(xiě)在具體的text中,大概就是這樣。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- flutter實(shí)現(xiàn)倒計(jì)時(shí)加載頁(yè)面
- Flutter實(shí)現(xiàn)倒計(jì)時(shí)功能
- Flutter之Timer實(shí)現(xiàn)短信驗(yàn)證碼獲取60s倒計(jì)時(shí)功能的代碼
- Flutter定時(shí)器、倒計(jì)時(shí)的快速上手及實(shí)戰(zhàn)講解
- Flutter倒計(jì)時(shí)/計(jì)時(shí)器的實(shí)現(xiàn)代碼
- Flutter實(shí)現(xiàn)倒計(jì)時(shí)秒數(shù)轉(zhuǎn)時(shí)分秒然后倒計(jì)時(shí)功能
相關(guān)文章
Android實(shí)現(xiàn)多次閃退清除數(shù)據(jù)
這篇文章主要介紹了Android實(shí)現(xiàn)多次閃退清除數(shù)據(jù)的相關(guān)資料,感興趣的小伙伴們可以參考一下2016-04-04
android listview 水平滾動(dòng)和垂直滾動(dòng)的小例子
android listview 水平滾動(dòng)和垂直滾動(dòng)的小例子,需要的朋友可以參考一下2013-05-05
android開(kāi)發(fā)實(shí)現(xiàn)文件讀寫(xiě)
這篇文章主要為大家詳細(xì)介紹了android開(kāi)發(fā)實(shí)現(xiàn)文件讀寫(xiě),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-07-07
Android RelativeLayout相對(duì)布局屬性簡(jiǎn)析
在Android應(yīng)用開(kāi)發(fā)過(guò)程中,為了界面的美觀考慮,經(jīng)常會(huì)使用到布局方面的屬性,本文就以此問(wèn)題深入解析,詳解一下Android RelativeLayout相對(duì)布局屬性在實(shí)際開(kāi)發(fā)中的應(yīng)用,需要的朋友可以參考下2012-11-11
Android ProgressBar 模擬進(jìn)度條效果的實(shí)現(xiàn)
這篇文章主要介紹了Android ProgressBar 模擬進(jìn)度條效果的實(shí)現(xiàn),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-04-04
Android Socket服務(wù)端與客戶端用字符串的方式互相傳遞圖片的方法
這篇文章主要介紹了Android Socket服務(wù)端與客戶端用字符串的方式互相傳遞圖片的方法的相關(guān)資料,需要的朋友可以參考下2016-05-05
使用Android Studio 開(kāi)發(fā)自己的SDK教程
很多時(shí)候我們要將自己開(kāi)發(fā)一個(gè)類(lèi)庫(kù)打包成jar包以供他調(diào)用,這個(gè)jar包也叫你自己的SDK或者叫l(wèi)ibrary。android studio生成jar包的方法與eclipse有所不同。在studio中l(wèi)ibrary其實(shí)是module的概念。2017-10-10
詳解android 用webview加載網(wǎng)頁(yè)(https和http)
這篇文章主要介紹了詳解android 用webview加載網(wǎng)頁(yè)(https和http),詳細(xì)的介紹了兩個(gè)錯(cuò)誤的解決方法,有興趣的可以了解一下2017-11-11
Android Naive與WebView的互相調(diào)用詳解
這篇文章主要介紹了Android Naive與WebView的互相調(diào)用詳解的相關(guān)資料,需要的朋友可以參考下2017-05-05

