经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 移动开发 » iOS » 查看文章
IOS小组件(6):小组件实现时钟按秒刷新
来源:cnblogs  作者:popfisher  时间:2021/5/17 9:19:29  对本文有异议

引言

上一节中我们了解了IOS小组件的刷新机制,发现根本没法实现按秒刷新,但是看别的App里面有做到,以为用了什么黑科技,原来是因为系统提供了一个额外的机制实现时间的动态更新,不用走小组件的刷新机制。

Text控件支持显示日期时间,下面是来自官网的代码

计算时间差

  1. let components = DateComponents(minute: 11, second: 14)
  2. let futureDate = Calendar.current.date(byAdding: components, to: Date())!
  3. Text(futureDate, style: .relative)
  4. // Displays:
  5. // 11 min, 14 sec
  6. Text(futureDate, style: .offset)
  7. // Displays:
  8. // -11 minutes

使用relative样式可以显示当前日期和时间与指定日期之间的差值(绝对值),而不管该日期是将来的还是过去的日期。使用offset样式显示当前日期和时间与指定日期之间的时差,表示将来的日期带有减号(-)前缀,而过去的日期带有加号(+)前缀。

倒计时和计时器

  1. let components = DateComponents(minute: 15)
  2. let futureDate = Calendar.current.date(byAdding: components, to: Date())!
  3. Text(futureDate, style: .timer)
  4. // Displays:
  5. // 15:00

对于将来的日期,timer样式将递减计数(倒计时),直到当前时间达到指定的日期和时间为止,并在日期经过时递增计数(计时器)。

显示绝对日期或时间

  1. // Absolute Date or Time
  2. let components = DateComponents(year: 2020, month: 4, day: 1, hour: 9, minute: 41)
  3. let aprilFirstDate = Calendar.current(components)!
  4. Text(aprilFirstDate, style: .date)
  5. Text("Date: \(aprilFirstDate, style: .date)")
  6. Text("Time: \(aprilFirstDate, style: .time)")
  7. // Displays:
  8. // April 1, 2020
  9. // Date: April 1, 2020
  10. // Time: 9:41AM

显示两个日期之间的时间间隔

  1. let startComponents = DateComponents(hour: 9, minute: 30)
  2. let startDate = Calendar.current.date(from: startComponents)!
  3. let endComponents = DateComponents(hour: 14, minute: 45)
  4. let endDate = Calendar.current.date(from: endComponents)!
  5. Text(startDate ... endDate)
  6. Text("The meeting will take place: \(startDate ... endDate)")
  7. // Displays:
  8. // 9:30AM-2:45PM
  9. // The meeting will take place: 9:30AM-2:45PM

实现一天时间的计时器

使用 style: .time样式,如果当前的时间比指定的时间大,则时间就会累计。基于这个原理,我们只需要把时间起点定在每天的0点即可,根据当前的时间计算出今天的开始时间。以下方法可以根据12,24小时制度,获取当天起点时间。

  1.  //获取当天开始的日期,给Date增加一个拓展方法
  2. extension Date {
  3. func getCurrentDayStart(_ isDayOf24Hours: Bool)-> Date {
  4.     let calendar:Calendar = Calendar.current;
  5.     let year = calendar.component(.year, from: self);
  6.     let month = calendar.component(.month, from: self);
  7.     let day = calendar.component(.day, from: self);
  8.     let components = DateComponents(year: year, month: month, day: day, hour: 0, minute: 0, second: 0)
  9.     return Calendar.current.date(from: components)!
  10. }
  11. }
  12. // 实现一天内的计时器
  13. Text(Date().getCurrentDayStart(true), style: .timer)

结语

通过IOS Text控件我们实现了按秒刷新的计时器,所以数字时钟的按秒刷新算是解决了,但是怎么实现表盘时钟的秒针360度旋转呢?如果让秒针精确的对应当前的时间,应该做不到了。后面再继续研究,如果有解决方案的可以贡献一下,感谢。

原文链接:http://www.cnblogs.com/popfisher/p/14767333.html

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号