Przeglądaj źródła

add: 完善air780epvh的演示demo,对接irtu-gps网站和小程序

Wendal Chen 1 rok temu
rodzic
commit
a1cfc4484c

+ 6 - 0
demo/air780epvh_gnsstest/README.md

@@ -14,3 +14,9 @@
 
 本demo完全没有优化流量, 会上报**全部**GNSS数据, 以便分析!!!
 
+## demo说明
+
+1. 开启 testGnss 是定位功能演示, 含开启GNSS功能, 获取GNSS数据, 注入辅助定位信息(AGPS)
+2. 开启 testMqtt 是上报定位信息到MQTT服务器, 对应的演示网页是 https://iot.openluat.com/iot/device-gnss
+3. 开启 testGpio 是演示GPIO功能, 定位成功后切换GPIO输出
+4. 开启 testTcp 是演示上传数据到TCP服务器, 对应的网页是 https://gps.nutz.cn 微信小程序 iRTU寻物

+ 13 - 4
demo/air780epvh_gnsstest/main.lua

@@ -1,13 +1,11 @@
 -- LuaTools需要PROJECT和VERSION这两个信息
 PROJECT = "gnsstest"
 VERSION = "1.0.1"
-PRODUCT_KEY = ""
+PRODUCT_KEY = "" -- 基站定位需要用到
 
 --[[
 本demo需要很多流量!!!
 注意: 室内无信号!! 无法定位!!!
-
-本demo对应的网页是 https://iot.openluat.com/iot/device-gnss
 ]]
 
 -- sys库是标配
@@ -16,10 +14,21 @@ require("sysplus")
 
 _G.gps_uart_id = 2
 
+-- 演示GNSS定位, 含AGPS
 require "testGnss"
-require "testMqtt"
+
+-- 演示上报到MQTT服务器 对应的网页是 https://iot.openluat.com/iot/device-gnss
+-- require "testMqtt"
+
+-- 演示定位成功后切换GPIO高低电平
 -- require "testGpio"
 
+-- 本TCP演示是连接到 gps.nutz.cn 19002 端口, irtu的自定义包格式
+-- 网页是 https://gps.nutz.cn/ 输入IMEI号可参考当前位置
+-- 微信小程序是 irtu寻物, 点击IMEI号, 扫描模块的二维码可查看当前位置和历史轨迹
+-- 服务器源码地址: https://gitee.com/wendal/irtu-gps
+require "testTcp"
+
 -- 用户代码已结束---------------------------------------------
 -- 结尾总是这一句
 sys.run()

+ 0 - 1
demo/air780epvh_gnsstest/testGpio.lua

@@ -3,7 +3,6 @@
 LED_VBAT = 26
 gpio.setup(LED_VBAT, 0) -- 低电压警告灯
 
-adc.open(adc.CH_VBAT)
 adc.open(adc.CH_CPU)
 
 -- 适配GNSS测试设备的GPIO

+ 190 - 0
demo/air780epvh_gnsstest/testTcp.lua

@@ -0,0 +1,190 @@
+--[[
+连到gps.nutz.cn 19002 端口, irtu的自定义包格式
+]]
+
+-- LuaTools需要PROJECT和VERSION这两个信息
+PROJECT = "scdemo"
+VERSION = "1.0.0"
+
+log.info("main", PROJECT, VERSION)
+
+-- 一定要添加sys.lua !!!!
+sys = require("sys")
+sysplus = require("sysplus")
+libnet = require "libnet"
+
+if pm and pm.PWK_MODE then
+    pm.power(pm.PWK_MODE, false)
+end
+
+if wdt then
+    --添加硬狗防止程序卡死,在支持的设备上启用这个功能
+    wdt.init(9000)--初始化watchdog设置为9s
+    sys.timerLoopStart(wdt.feed, 3000)--3s喂一次狗
+end
+
+adc.open(adc.CH_VBAT)
+
+--=============================================================
+-- 本TCP演示是连接到 gps.nutz.cn 19002 端口, irtu的自定义包格式
+-- 网页是 https://gps.nutz.cn/ 输入IMEI号可参考当前位置
+-- 微信小程序是 irtu寻物, 点击IMEI号, 扫描模块的二维码可查看当前位置和历史轨迹
+local host = "gps.nutz.cn"  -- 服务器ip或者域名, 都可以的
+local port = 19002          -- 服务器端口号
+local is_udp = false        -- 如果是UDP, 要改成true, false就是TCP
+local is_tls = false        -- 加密与否, 要看服务器的实际情况
+--=============================================================
+
+-- 处理未识别的网络消息
+local function netCB(msg)
+	log.info("未处理消息", msg[1], msg[2], msg[3], msg[4])
+end
+
+local socket_ready = false
+local taskName = "sc"
+local topic = taskName .. "_txrx"
+log.info("socket", "event topic", topic)
+
+-- 演示task
+local function sockettest()
+    sys.waitUntil("IP_READY")
+
+    -- 开始正在的逻辑, 发起socket链接,等待数据/上报心跳
+    local txqueue = {}
+    sysplus.taskInitEx(sockettask, taskName, netCB, taskName, txqueue, topic)
+    while 1 do
+        local result, tp, data = sys.waitUntil(topic, 30000)
+        -- log.info("event", result, tp, data)
+        if not result then
+            -- 等很久了,没数据上传/下发, 发个日期心跳包吧
+            table.insert(txqueue, string.char(0))
+            sys_send(taskName, socket.EVENT, 0)
+        elseif tp == "uplink" then
+            -- 上行数据, 主动上报的数据,那就发送呀
+            table.insert(txqueue, data)
+            sys_send(taskName, socket.EVENT, 0)
+        elseif tp == "downlink" then
+            -- 下行数据,接收的数据, 从ipv6task来的
+            -- 其他代码可以通过 sys.publish()
+            log.info("socket", "收到下发的数据了", #data)
+        end
+    end
+end
+
+
+
+function sockettask(d1Name, txqueue, rxtopic)
+    -- 打印准备连接的服务器信息
+    log.info("socket", host, port, is_udp and "UDP" or "TCP", is_tls and "TLS" or "RAW")
+
+    -- 准备好所需要的接收缓冲区
+    local rx_buff = zbuff.create(1024)
+    local netc = socket.create(nil, d1Name)
+    socket.config(netc, nil, is_udp, is_tls)
+    log.info("任务id", d1Name)
+
+    while true do
+        -- 连接服务器, 15秒超时
+        log.info("socket", "开始连接服务器")
+        sysplus.cleanMsg(d1Name)
+        local result = libnet.connect(d1Name, 15000, netc, host, port)
+        if result then
+			log.info("socket", "服务器连上了")
+            local tmp = {imei=mobile.imei(),iccid=mobile.iccid()}
+			libnet.tx(d1Name, 0, netc, json.encode(tmp))
+            socket_ready = true
+        else
+            log.info("socket", "服务器没连上了!!!")
+		end
+		while result do
+            -- 连接成功之后, 先尝试接收
+            -- log.info("socket", "调用rx接收数据")
+			local succ, param = socket.rx(netc, rx_buff)
+			if not succ then
+				log.info("服务器断开了", succ, param, ip, port)
+				break
+			end
+            -- 如果服务器有下发数据, used()就必然大于0, 进行处理
+			if rx_buff:used() > 0 then
+				log.info("socket", "收到服务器数据,长度", rx_buff:used())
+                local data = rx_buff:query() -- 获取数据
+                sys.publish(rxtopic, "downlink", data)
+				rx_buff:del()
+			end
+            -- log.info("libnet", "调用wait开始等待消息")
+            -- 等待事件, 例如: 服务器下发数据, 有数据准备上报, 服务器断开连接
+			result, param, param2 = libnet.wait(d1Name, 15000, netc)
+            log.info("libnet", "wait", result, param, param2)
+			if not result then
+                -- 网络异常了, 那就断开了, 执行清理工作
+				log.info("socket", "服务器断开了", result, param)
+				break
+            elseif #txqueue > 0 then
+                -- 有待上报的数据,处理之
+                while #txqueue > 0 do
+                    local data = table.remove(txqueue, 1)
+                    if not data then
+                        break
+                    end
+                    result,param = libnet.tx(d1Name, 15000, netc,data)
+                    -- log.info("libnet", "发送数据的结果", result, param)
+                    if not result then
+                        log.info("socket", "数据发送异常", result, param)
+                        break
+                    end
+                end
+            end
+            -- 循环尾部, 继续下一轮循环
+		end
+        socket_ready = false
+        -- 能到这里, 要么服务器断开连接, 要么上报(tx)失败, 或者是主动退出
+		libnet.close(d1Name, 5000, netc)
+		-- log.info(rtos.meminfo("sys"))
+		sys.wait(3000) -- 这是重连时长, 自行调整
+    end
+end
+
+sys.taskInit(sockettest)
+
+
+sys.taskInit(function()
+    sys.waitUntil("IP_READY")
+    local stat_t = 0
+    local buff = zbuff.create(64)
+    while true do
+        if socket_ready then
+            -- 发送设备状态  >b7IHb  ==  1*7+4+2+1 = 14
+            if os.time() - stat_t > 30 then
+                -- 30秒上报一次
+                local vbat = adc.get(adc.CH_VBAT)
+                buff:seek(0)
+                buff:pack(">b7IHb", 0x55, 0, 0, 0, 0, 0, 0, 0, vbat, mobile.csq())
+                sys.publish(topic, "uplink", buff:query())
+                stat_t = os.time()
+                sys.wait(100)
+            end
+            -- 发送位置信息 >b2i3H2b3 == 1*2+4*3+2*2+1*3 == 2+12+4+3 = 21
+            if true then
+                local rmc = libgnss.getRmc(1)
+                local gsa = libgnss.getGsa()
+                local gsv = libgnss.getGsv()
+                -- log.info("socket", "rmc", rmc.lat, rmc.lng, rmc.alt, rmc.course, rmc.speed)
+                buff:seek(0)
+                buff:pack(">b2i3H2b3", 0xAA, libgnss.isFix() and 1 or 0,
+                        os.time(),
+                        rmc and rmc.lng or 0,
+                        rmc and rmc.lat or 0,
+                        0, -- rmc and rmc.alt or 0,
+                        math.floor(rmc and rmc.course or 0),
+                        math.floor(rmc and rmc.speed or 0),
+                        gsa and #gsa.sats or 0, -- msg.sateCno
+                        gsv and gsv.total_sats or 0 -- msg.sateCnt
+                )
+                sys.publish(topic, "uplink", buff:query())
+            end
+            sys.wait(1000)
+        else
+            sys.wait(100)
+        end
+    end
+end)