main.lua 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142
  1. -- LuaTools需要PROJECT和VERSION这两个信息
  2. PROJECT = "mobiledemo"
  3. VERSION = "1.0.0"
  4. log.info("main", PROJECT, VERSION)
  5. -- sys库是标配
  6. _G.sys = require("sys")
  7. -- Air780E的AT固件默认会为开机键防抖, 导致部分用户刷机很麻烦
  8. if rtos.bsp() == "EC618" and pm and pm.PWK_MODE then
  9. pm.power(pm.PWK_MODE, false)
  10. end
  11. -- 对于双卡的设备, 可以设置为自动选sim卡
  12. -- 但是, 这样SIM1所在管脚就强制复用为SIM功能, 不可以再复用为GPIO
  13. -- mobile.simid(2)
  14. mobile.simid(2,true)--优先用SIM0
  15. sys.taskInit(function()
  16. if rtos.bsp() == "UIS8850BM" then
  17. sys.wait(2000)
  18. end
  19. log.info("status", mobile.status())
  20. local band = zbuff.create(40)
  21. local band1 = zbuff.create(40)
  22. mobile.getBand(band)
  23. log.info("当前使用的band:")
  24. for i=0,band:used()-1 do
  25. log.info("band", band[i])
  26. end
  27. band1[0] = 38
  28. band1[1] = 39
  29. band1[2] = 40
  30. mobile.setBand(band1, 3) --改成使用38,39,40
  31. band1:clear()
  32. mobile.getBand(band1)
  33. log.info("修改后使用的band:")
  34. for i=0,band1:used()-1 do
  35. log.info("band", band1[i])
  36. end
  37. mobile.setBand(band, band:used()) --改回原先使用的band,也可以下载的时候选择清除fs
  38. mobile.getBand(band1)
  39. log.info("修改回默认使用的band:")
  40. for i=0,band1:used()-1 do
  41. log.info("band", band1[i])
  42. end
  43. -- mobile.vsimInit()
  44. -- mobile.flymode(nil,true)
  45. -- mobile.vsimOnOff(true)
  46. -- mobile.flymode(nil,false)
  47. -- mobile.apn(0,2,"") -- 使用默认APN激活CID2
  48. -- mobile.rtime(3) -- 在无数据交互时,RRC 3秒后自动释放
  49. -- 下面是配置自动搜索小区间隔,和轮询搜索冲突,开启1个就可以了
  50. -- mobile.setAuto(10000,30000, 5) -- SIM暂时脱离后自动恢复,30秒搜索一次周围小区信息
  51. log.info("status", mobile.status())
  52. sys.wait(2000)
  53. while 1 do
  54. log.info("imei", mobile.imei())
  55. log.info("imsi", mobile.imsi())
  56. local sn = mobile.sn()
  57. if sn then
  58. log.info("sn", sn:toHex())
  59. end
  60. log.info("status", mobile.status())
  61. log.info("iccid", mobile.iccid())
  62. log.info("csq", mobile.csq()) -- 4G模块的CSQ并不能完全代表强度
  63. log.info("rssi", mobile.rssi()) -- 需要综合rssi/rsrq/rsrp/snr一起判断
  64. log.info("rsrq", mobile.rsrq())
  65. log.info("rsrp", mobile.rsrp())
  66. log.info("snr", mobile.snr())
  67. log.info("simid", mobile.simid()) -- 这里是获取当前SIM卡槽
  68. log.info("apn", mobile.apn(0,1))
  69. log.info("ip", socket.localIP())
  70. log.info("lua", rtos.meminfo())
  71. -- sys内存
  72. log.info("sys", rtos.meminfo("sys"))
  73. sys.wait(15000)
  74. end
  75. end)
  76. -- 订阅式, 模块本身会周期性查询基站信息,但通常不包含临近小区
  77. sys.subscribe("SCELL_INFO", function()
  78. log.info("cell", json.encode(mobile.scell()))
  79. end)
  80. -- 基站数据的查询
  81. -- 订阅式, 模块本身会周期性查询基站信息,但通常不包含临近小区
  82. sys.subscribe("CELL_INFO_UPDATE", function()
  83. log.info("cell", json.encode(mobile.getCellInfo()))
  84. end)
  85. -- 轮询式, 包含临近小区信息,这是手动搜索,和上面的自动搜索冲突,开启一个就行
  86. sys.taskInit(function()
  87. sys.wait(5000)
  88. mobile.config(mobile.CONF_SIM_WC_MODE, 2)
  89. while 1 do
  90. mobile.reqCellInfo(10)
  91. sys.wait(11000)
  92. log.info("cell", json.encode(mobile.getCellInfo()))
  93. mobile.config(mobile.CONF_SIM_WC_MODE, 2)
  94. end
  95. end)
  96. -- 获取sim卡的状态
  97. sys.subscribe("SIM_IND", function(status, value)
  98. log.info("sim status", status)
  99. if status == 'GET_NUMBER' then
  100. log.info("number", mobile.number(0))
  101. end
  102. if status == "SIM_WC" then
  103. log.info("sim", "write counter", value)
  104. end
  105. end)
  106. sys.subscribe("RRC_IND", function(event, v1, v2, v3, v4)
  107. log.info("rrc status", event)
  108. if event == "DRX" then
  109. log.info("drx周期", v1, "ms")
  110. end
  111. if event == "IDLE_MEAS_THRESHOLD" then
  112. log.info("sIntraSearchP", v1)
  113. log.info("sNonIntraSearchP", v2)
  114. log.info("sIntraSearchQ", v3)
  115. log.info("sNonIntraSearchQ", v4)
  116. end
  117. end)
  118. -- 用户代码已结束---------------------------------------------
  119. -- 结尾总是这一句
  120. sys.run()
  121. -- sys.run()之后后面不要加任何语句!!!!!