| 1234567891011121314151617181920212223242526272829303132333435363738394041424344 |
- --[[
- @module normal
- @summary gnss正常测试功能模块
- @version 1.0
- @date 2025.07.27
- @author 李源龙
- @usage
- 使用Air8000核心板,外接GPS天线,起一个60s定位一次的定时器,模块60s一定位,然后定位成功获取到经纬度发送到服务器上面
- ]]
- -- gnss=require("gnss")
- tcp=require("tcp")
- local function mode1_cb(tag)
- log.info("TAGmode1_cb+++++++++",tag)
- local rmc=gnss.getRmc(0)
- log.info("nmea", "rmc", json.encode(gnss.getRmc(0)))
- tcp.latlngfnc(rmc.lat,rmc.lng)
- end
- local function timer1()
- gnss.open(gnss.TIMERORSUC,{tag="MODE1",val=60,cb=mode1_cb})
- end
- local function gnss_fnc()
- log.info("gnss_fnc111")
- local gnssotps={
- gnssmode=1, --1为卫星全定位,2为单北斗
- agps_enable=true, --是否使用AGPS,开启AGPS后定位速度更快,会访问服务器下载星历,星历时效性为北斗1小时,GPS4小时,默认下载星历的时间为1小时,即一小时内只会下载一次
- -- debug=true, --是否输出调试信息
- -- uart=2, --使用的串口,780EGH和8000默认串口2
- -- uartbaud=115200, --串口波特率,780EGH和8000默认115200
- -- bind=1, --绑定uart端口进行GNSS数据读取,是否设置串口转发,指定串口号
- -- rtc=false --定位成功后自动设置RTC true开启,flase关闭
- ----因为GNSS使用辅助定位的逻辑,是模块下载星历文件,然后把数据发送给GNSS芯片,
- ----芯片解析星历文件需要10-30s,默认GNSS会开启20s,该逻辑如果不执行,会导致下一次GNSS开启定位是冷启动,
- ----定位速度慢,大概35S左右,所以默认开启,如果可以接受下一次定位是冷启动,可以把agps_autoopen设置成false
- ----需要注意的是热启动在定位成功之后,需要再开启3s左右才能保证本次的星历获取完成,如果对定位速度有要求,建议这么处理
- -- agps_autoopen=false
- }
- gnss.setup(gnssotps)
- sys.timerLoopStart(timer1,60000)
- gnss.open(gnss.TIMERORSUC,{tag="MODE1",val=60,cb=mode1_cb})
- end
- sys.taskInit(gnss_fnc)
|