rtc_app.lua 3.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. --[[
  2. @module rtc_app
  3. @summary rtc时钟驱动模块
  4. @version 1.0
  5. @date 2025.10.28
  6. @author 王城钧
  7. @usage
  8. 本文件为rtc时钟驱动模块,核心业务逻辑为:
  9. 1、初始化RTC时钟,设置RTC时钟日期和时间,时区以及基准年;
  10. 2、获取RTC时钟时间;
  11. 3、每秒打印RTC时钟时间;
  12. 本文件没有对外接口,直接在其他功能模块中require "rtc_app"就可以加载运行;
  13. ]]
  14. --[[
  15. -- 本地时间是指:当前时区的时间,默认是东八区北京时间,可以通过rtc.timezone接口查询或者设置时区
  16. -- UTC/RTC时间是指:0时区的时间
  17. -- 东八区的时间是在UTC时间的基础上增加8个小时
  18. -- 本文件中的两段代码演示的是东八区和RTC时间的区别
  19. ]]
  20. -- RTC时钟演示(测试环境为无网络环境)
  21. local function rtc_task1()
  22. rtc.setBaseYear(1900) -- 设置基准年为1900年
  23. local result = rtc.timezone(32) -- 设置时区为东八区
  24. log.info("rtc.timezone()", result) -- 打印时区信息
  25. -- rtc.set({ year = 2025, mon = 10, day = 28, hour = 8, min = 10, sec = 53 }) -- 设置日期和时间
  26. rtc.set(1761639053) -- 设置时间戳(与上一行的设置效果相同,二选一即可)
  27. local t1 = rtc.get()
  28. log.info("rtc初始时间", json.encode(t1)) -- 打印当前日期和时间
  29. log.info("rtc设置后的本地时间", os.date()) -- 打印当前日期和时间
  30. while 1 do
  31. log.info("os.date()", os.date()) -- 打印RTC时钟时间
  32. local t = rtc.get() -- 获取rtc时间
  33. log.info("循环rtc时间", json.encode(t)) -- 打印当前rtc时间
  34. sys.wait(1000) -- 等待1s,然后再次获取rtc时间和实时时间
  35. end
  36. end
  37. -- 获取基站和 NTP授时成功后的rtc时间
  38. local function rtc_task2()
  39. rtc.setBaseYear(1900) -- 设置基准年为1900年
  40. local result = rtc.timezone(32) -- 设置时区为东八区
  41. log.info("rtc.timezone()", result) -- 打印时区信息
  42. -- rtc.set({ year = 2025, mon = 10, day = 28, hour = 19, min = 10, sec = 53 }) -- 设置日期和时间
  43. rtc.set(1761678653) -- 设置时间戳(与上一行的设置效果相同,二选一即可)
  44. log.info("rtc设置后时间", os.date()) -- 打印当前日期和时间
  45. while not socket.adapter(socket.dft()) do
  46. log.warn("sntp_task_func", "wait IP_READY", socket.dft())
  47. -- 在此处阻塞等待默认网卡连接成功的消息"IP_READY"
  48. -- 或者等待1秒超时退出阻塞等待状态;
  49. -- 注意:此处的1000毫秒超时不要修改的更长;
  50. -- 因为当使用exnetif.set_priority_order配置多个网卡连接外网的优先级时,会隐式的修改默认使用的网卡
  51. -- 当exnetif.set_priority_order的调用时序和此处的socket.adapter(socket.dft())判断时序有可能不匹配
  52. -- 此处的1秒,能够保证,即使时序不匹配,也能1秒钟退出阻塞状态,再去判断socket.adapter(socket.dft())
  53. sys.waitUntil("IP_READY", 1000)
  54. end
  55. socket.sntp()
  56. sys.waitUntil("NTP_UPDATE", 5000)
  57. while 1 do
  58. log.info("os.date()", os.date()) -- 打印实时时间
  59. local t = rtc.get() -- 获取rtc时间
  60. log.info("循环rtc时间", json.encode(t))
  61. -- 打印当前rtc时间,当收到基站和 NTP授时的时候,rtc时间会自动更新为当前UTC时间(零时区),于北京时间(东八区)相差8小时
  62. sys.wait(1000) -- 等待1s,然后再次获取rtc时间和实时时间
  63. end
  64. end
  65. -- 注意:以下两个任务每次测试时只能选择其一进行测试
  66. -- 无网络情况下的rtc时间演示
  67. sys.taskInit(rtc_task1)
  68. -- 获取基站和 NTP授时成功后的rtc时间
  69. -- sys.taskInit(rtc_task2)