当前位置: 首页 > news >正文

哪里有网站建设北京今日重大新闻

哪里有网站建设,北京今日重大新闻,绍兴百度seo,学校网站建立Flutter实现倒计时功能 发布时间:2023/05/12 本文实例为大家分享了Flutter实现倒计时功能的具体代码,供大家参考,具体内容如下 有一个需求,需要在页面进行显示倒计时,倒计时结束后,做相应的逻辑处理。 实…

Flutter实现倒计时功能
发布时间:2023/05/12
本文实例为大家分享了Flutter实现倒计时功能的具体代码,供大家参考,具体内容如下

有一个需求,需要在页面进行显示倒计时,倒计时结束后,做相应的逻辑处理。

实现思路:在Flutter中,Timer.periodic提供了循环功能,查看函数定义:

factory Timer.periodic(Duration duration, void callback(Timer timer))

第一个参数就是时间间隔,第二个参数就是事件处理回调。

由于后台返回的是秒数,所以需要根据总秒数计算小时,分钟,秒。同时,当不满一个小时时,只显示分钟和秒数,当分钟和秒数只有一个数时(比如1分8秒,显示为01:08)前面加“0”处理。

完整代码:

import 'package:flutter/material.dart';
import 'dart:async';class CounterDownPage extends StatefulWidget {@override_CounterDownPageState createState() => _CounterDownPageState();
}class _CounterDownPageState extends State<CounterDownPage> {// 用来在布局中显示相应的剩余时间String remainTimeStr = '';Timer _timer;//倒计时 void startCountDown(int time) {// 重新计时的时候要把之前的清除掉if (_timer != null) {if (_timer.isActive) {_timer.cancel();_timer = null;}}if (time <= 0) {return;}var countTime = time;const repeatPeriod = const Duration(seconds: 1);_timer = Timer.periodic(repeatPeriod, (timer) { if (countTime <= 0) {timer.cancel();timer = null;//待付款倒计时结束,可以在这里做相应的操作return;}countTime--;//外面传进来的单位是秒,所以需要根据总秒数,计算小时,分钟,秒int hour = (countTime ~/ 3600) % 24;//如果不止24小时的就不用%24int minute = countTime % 3600 ~/60;int second = countTime % 60;var str = '';if (hour > 0) {str = str + hour.toString()+':';}if (minute / 10 < 1) {//当只有个位数时,给前面加“0”,实现效果:“:01”,":02"str = str + '0' + minute.toString() + ":";} else {str = str + minute.toString() + ":";}if (second / 10 < 1) {str = str + '0' + second.toString();} else {str = str + second.toString();}setState(() {remainTimeStr = str;});});}@overridevoid initState() {super.initState();//开始倒计时,这里传入的是秒数startCountDown(5000);}@overridevoid dispose() {super.dispose();if (_timer != null) {if (_timer.isActive) {_timer.cancel();_timer = null;}}}@overrideWidget build(BuildContext context) {return Scaffold(appBar: AppBar(title: Text("倒计时"),),body: Center(child: Row(mainAxisAlignment: MainAxisAlignment.center,children: [Text("剩余", style: TextStyle(fontSize: 18,color: Color.fromRGBO(255, 111, 50, 1),fontWeight: FontWeight.bold),),Text(remainTimeStr.length > 0 ? remainTimeStr: "--", style: TextStyle(fontSize: 18,color: Color.fromRGBO(255, 111, 50, 1),fontWeight: FontWeight.bold),),],),),);}
}

在这里插入图片描述
服务器返回的时间戳87392,现在的时间戳+87392 现在的时间戳,两者的时间戳相差二十多个小时,也就是说87392就是秒数,直接传秒数到上面的startCountDown方法即可。

http://www.rdtb.cn/news/17502.html

相关文章:

  • 适合做推广的平台seo搜索引擎工具
  • 哈尔滨网站建设报价百度经验手机版官网
  • 做网站需要几步怎么推广引流客户
  • 做音乐的网站网络营销推广工作内容
  • 网站模板如何使用宁波网站建设与维护
  • 邯郸设计公司有哪些中国十大seo
  • 行业网站联盟宁波seo推荐优化
  • 如何实现网站的伪静态今天新闻头条
  • 网站链接提交收录全网搜索引擎优化
  • 国外一个做同人动漫的网站产品运营方案
  • 魏县做网站厦门百度seo排名
  • 安全联盟这种网站建设百度seo怎么做网站内容优化
  • asia域名网站可靠吗百度宣传推广费用
  • 用手机做网站的流程郑州百度关键词seo
  • html网站建设宁波seo整站优化软件
  • 北京西路做网站的公司手游推广渠道和推广方式
  • 如何做购物网站的限购功能代码网络营销策划方案怎么做
  • 域名服务网站全媒体广告加盟
  • 天津建站管理系统价格深圳关键词优化软件
  • 河北保定疫情最新消息落实好疫情防控优化措施
  • 洛阳 网站建设公司网站推广服务外包
  • 自己 做网站学什么 平面设计东莞有限公司seo
  • 做网站建设有前景吗搜索百度app下载
  • 做网站赚钱但又不想开公司外贸网站平台
  • 西部数据网站建设国内搜索引擎排名第一的是
  • 温州手机网站推广知识营销案例
  • 公司网站建设组织架构cps广告联盟
  • 水利建设工程网站站长seo查询工具
  • 大城网站制作站长工具官网域名查询
  • 网站开发公司不干了app代理推广合作50元