2023-06-01 09:10:00 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2023-06-17 10:26:40 +00:00
|
|
|
|
#include <board.h>
|
2023-05-04 08:35:14 +00:00
|
|
|
|
#include <rtthread.h>
|
|
|
|
|
//#include <../packages/webclient-v2.2.0/inc/webclient.h>
|
|
|
|
|
#include <webclient.h>
|
|
|
|
|
|
|
|
|
|
#define LOG_TAG "getinfo"
|
2023-06-11 08:32:09 +00:00
|
|
|
|
#define LOG_LVL LOG_LVL_INFO
|
2023-05-04 08:35:14 +00:00
|
|
|
|
#include <ulog.h>
|
|
|
|
|
|
2023-07-24 06:57:28 +00:00
|
|
|
|
#include <string.h>
|
2023-06-20 10:09:07 +00:00
|
|
|
|
#include <cJSON.h>
|
|
|
|
|
#include <usrcfg.h>
|
|
|
|
|
|
2023-05-04 08:35:14 +00:00
|
|
|
|
//#define HTTP_GET_URL "http://www.rt-thread.com/service/rt-thread.txt"
|
|
|
|
|
#ifndef TT_IP
|
2023-06-20 10:09:07 +00:00
|
|
|
|
#define TT_IP "http://" TTIP ":4005"
|
2023-05-04 08:35:14 +00:00
|
|
|
|
#endif
|
|
|
|
|
#define TT_SIM TT_IP "/action/webGetSIMState"//SIM
|
|
|
|
|
#define TT_XH TT_IP "/action/webGetTDSignal"//信号值
|
|
|
|
|
#define TT_RW TT_IP "/action/webGetTdState"//入网
|
|
|
|
|
#define TT_JH TT_IP "/action/webGetPSState"//激活
|
|
|
|
|
#define TT_DW TT_IP "/action/webGetBDGPS"//定位
|
|
|
|
|
//http://192.168.0.232:4005/action/webGetSIMState webGetBDGPS
|
2023-06-01 09:10:00 +00:00
|
|
|
|
#define MAX_LEN 15
|
2023-06-20 10:09:07 +00:00
|
|
|
|
|
2023-06-01 09:10:00 +00:00
|
|
|
|
//#include <stdio.h>
|
|
|
|
|
//#include <stdlib.h> //用于strtod函数
|
|
|
|
|
//#include <string.h>
|
2023-05-04 08:35:14 +00:00
|
|
|
|
|
|
|
|
|
char *infoH[] = { TT_SIM, TT_XH, TT_RW, TT_JH, TT_DW};
|
2023-06-17 10:26:40 +00:00
|
|
|
|
|
2023-05-04 08:35:14 +00:00
|
|
|
|
|
|
|
|
|
typedef struct
|
|
|
|
|
{
|
2023-06-01 09:10:00 +00:00
|
|
|
|
char sim[MAX_LEN]; // SIM
|
2023-06-06 07:45:13 +00:00
|
|
|
|
char xh[MAX_LEN]; // SIM
|
|
|
|
|
char rw[MAX_LEN]; // SIM
|
|
|
|
|
char jh[MAX_LEN]; // SIM
|
|
|
|
|
char jd[MAX_LEN]; // SIM
|
|
|
|
|
char wd[MAX_LEN]; // SIM
|
|
|
|
|
char ele[MAX_LEN]; // SIM
|
2023-08-04 10:13:59 +00:00
|
|
|
|
/**
|
|
|
|
|
在纬度相等的情况下:
|
|
|
|
|
经度每隔0.000001度,距离相差约1米
|
|
|
|
|
经度每隔0.00001度,距离相差约10米
|
|
|
|
|
经度每隔0.0001度,距离相差约100米
|
|
|
|
|
经度每隔0.001度,距离相差约1000米
|
|
|
|
|
经度每隔0.01度,距离相差约10000米
|
|
|
|
|
|
|
|
|
|
在经度相等的情况下:
|
|
|
|
|
纬度每隔0.000001度,距离相差约1.1米
|
|
|
|
|
纬度每隔0.00001度,距离相差约11米
|
|
|
|
|
纬度每隔0.0001度,距离相差约111米
|
|
|
|
|
纬度每隔0.001度,距离相差约1113米
|
|
|
|
|
纬度每隔0.01度,距离相差约11132米
|
|
|
|
|
*/
|
2023-06-06 07:45:13 +00:00
|
|
|
|
}TT;
|
|
|
|
|
|
2023-07-24 06:57:28 +00:00
|
|
|
|
TT tmp={.sim="-",.xh="-",.rw="-",.jh="-",.jd="-",.wd="-",.ele="-"};
|
2023-06-06 07:45:13 +00:00
|
|
|
|
TT *TTinfo=&tmp;
|
2023-06-02 02:23:26 +00:00
|
|
|
|
static rt_tick_t bootstamp=0;
|
2023-07-24 06:57:28 +00:00
|
|
|
|
#define RST_LEN 100//存储info的数组的长度
|
|
|
|
|
static uint8_t rstInfo[RST_LEN];//存储info的数组
|
2023-08-23 06:41:29 +00:00
|
|
|
|
void resetInfo()
|
|
|
|
|
{
|
2023-08-31 08:12:44 +00:00
|
|
|
|
rt_memset(rstInfo,0x3f,RST_LEN);//初始化
|
2023-08-23 06:41:29 +00:00
|
|
|
|
}
|
2023-05-04 08:35:14 +00:00
|
|
|
|
/**
|
|
|
|
|
* @description: 将TT结构体转换为数组
|
|
|
|
|
* @param {TT} *TTinfo TT结构体
|
|
|
|
|
* @param {rt_uint8_t} *buffer 存储转换结果
|
|
|
|
|
* @return {*} buffer大小
|
|
|
|
|
*/
|
|
|
|
|
rt_uint8_t info2HEX(TT *TTinfo, rt_uint8_t *buffer)
|
|
|
|
|
{
|
|
|
|
|
// 功能:将tt数据转换为9字节HEX数据并返回,存在data
|
|
|
|
|
// 第1节为高3位分别为sim、rw和jh,其余位为xh,xh值若大于31则为31(31=b0001 1111)
|
2023-07-24 06:57:28 +00:00
|
|
|
|
// 第2-5字节为经度。114.410050= 0xF2 0xD1 0xE4 0x42//根据系统大小端的不同可能是反序
|
2023-05-04 08:35:14 +00:00
|
|
|
|
// 第6-9字节为纬度。30.426840= 0x2B 0x6A 0xF3 0x41
|
2023-09-03 10:12:55 +00:00
|
|
|
|
// 第10字节为高度,只保留整数。-31.5= 0xE1
|
2023-05-04 08:35:14 +00:00
|
|
|
|
rt_uint8_t tmp = (atoi(TTinfo->sim) << 7) + (atoi(TTinfo->rw) << 6) + (atoi(TTinfo->jh) << 5)
|
|
|
|
|
+ (atoi(TTinfo->xh) > 31 ? 31 : atoi(TTinfo->xh)); // 位操作
|
|
|
|
|
|
|
|
|
|
char *jd_c = &TTinfo->jd[2]; // 从第二位开始取,去除非数字字符
|
|
|
|
|
char *wd_c = &TTinfo->wd[2];
|
|
|
|
|
float jd_f = strtod(jd_c, NULL); // 字符转浮点
|
|
|
|
|
float wd_f = strtod(wd_c, NULL);
|
|
|
|
|
rt_int8_t ele_f = atoi(TTinfo->ele);
|
|
|
|
|
|
|
|
|
|
// printf("jd--%f\nwd--%f\nele-- %d \n", jd_f, wd_f, ele_f);
|
|
|
|
|
|
|
|
|
|
rt_uint8_t offset = 0;
|
|
|
|
|
memcpy(buffer + offset, &tmp, 1);
|
|
|
|
|
offset += 1;
|
|
|
|
|
memcpy(buffer + offset, &jd_f, sizeof(float));
|
|
|
|
|
offset += sizeof(float);
|
|
|
|
|
memcpy(buffer + offset, &wd_f, sizeof(float));
|
|
|
|
|
offset += sizeof(float);
|
|
|
|
|
memcpy(buffer + offset, &ele_f, sizeof(rt_int8_t));
|
|
|
|
|
offset += sizeof(rt_int8_t);
|
|
|
|
|
|
|
|
|
|
return offset;
|
|
|
|
|
}
|
|
|
|
|
|
2023-07-24 06:57:28 +00:00
|
|
|
|
/**
|
|
|
|
|
* @brief 将新采集到的数据压入结果数组中。采用固定长度的队列方式压入,空间不足时自动弹出最旧的数据
|
|
|
|
|
*
|
|
|
|
|
* @param rst 存储采集结果的数组
|
|
|
|
|
* @param cnt 数组长度
|
|
|
|
|
* @param din 新采集的数据
|
|
|
|
|
* @param len 数据长度
|
|
|
|
|
* @return size_t 0-正常,-1异常
|
|
|
|
|
*/
|
|
|
|
|
int appendInfo(uint8_t *rst, size_t cnt, uint8_t *din, size_t len )
|
|
|
|
|
{
|
|
|
|
|
if (cnt < len)
|
|
|
|
|
{
|
|
|
|
|
return -1;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
uint8_t tmp[cnt];
|
|
|
|
|
memcpy(tmp, rst + len, cnt - len);
|
|
|
|
|
memcpy(rst, tmp, cnt - len);
|
2023-05-04 08:35:14 +00:00
|
|
|
|
|
2023-07-24 06:57:28 +00:00
|
|
|
|
memcpy(rst + cnt - len, din, len);
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 获取当前经纬度信息
|
|
|
|
|
* @param dout 存储结果的数组
|
|
|
|
|
* @param cnt 获取几组位置数据
|
|
|
|
|
* @return 数组长度。0表示位置数据未准备好。
|
|
|
|
|
*/
|
|
|
|
|
int getLoc(uint8_t * dout, size_t cnt)
|
|
|
|
|
{
|
|
|
|
|
// LOG_D("待实现获取位置函数,此处以0xCD代替");
|
2023-08-22 10:23:41 +00:00
|
|
|
|
uint8_t tmp[4];
|
2023-08-31 08:12:44 +00:00
|
|
|
|
rt_memset(tmp,0,4);
|
2023-08-22 10:23:41 +00:00
|
|
|
|
if ((rstInfo[0] == 0x3f) || (memcmp(rstInfo+1,tmp,4) == 0)) {//无有效位置数据,1+4+4+1
|
2023-07-24 06:57:28 +00:00
|
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
memcpy(dout,rstInfo+RST_LEN-cnt*10,cnt*10);//从后开始取
|
|
|
|
|
return cnt*10;//1+4+4+1
|
|
|
|
|
}
|
2023-05-04 08:35:14 +00:00
|
|
|
|
|
2023-08-04 10:13:59 +00:00
|
|
|
|
|
2023-06-20 10:09:07 +00:00
|
|
|
|
extern SYS_CFG scfg;
|
|
|
|
|
|
2023-08-04 10:13:59 +00:00
|
|
|
|
|
2023-06-02 02:23:26 +00:00
|
|
|
|
void initcfg()
|
|
|
|
|
{
|
2023-08-31 08:12:44 +00:00
|
|
|
|
rt_memset(rstInfo,0x3f,RST_LEN);//初始化
|
2023-06-02 02:23:26 +00:00
|
|
|
|
bootstamp = rt_tick_get_millisecond();
|
|
|
|
|
}
|
2023-08-18 07:36:41 +00:00
|
|
|
|
INIT_APP_EXPORT(initcfg);
|
2023-06-02 02:23:26 +00:00
|
|
|
|
|
2023-06-06 07:45:13 +00:00
|
|
|
|
/**
|
|
|
|
|
* 更新统计信息
|
|
|
|
|
*/
|
2023-08-04 10:13:59 +00:00
|
|
|
|
//static void updateSta()
|
|
|
|
|
//{
|
|
|
|
|
// uint16_t v = (rt_tick_get_millisecond()-bootstamp)/1000;//转换为秒
|
|
|
|
|
// LOG_I("耗时%dS.",v);
|
|
|
|
|
// if ((minActiveTime ==0) | (minActiveTime > v)) {
|
|
|
|
|
// minActiveTime = v;
|
|
|
|
|
// set_val("minActiveTime", v);
|
|
|
|
|
// }
|
|
|
|
|
// if (v>maxActiveTime) {
|
|
|
|
|
// maxActiveTime=v;
|
|
|
|
|
// set_val("maxActiveTime", v);
|
|
|
|
|
// }
|
|
|
|
|
//}
|
2023-06-02 02:23:26 +00:00
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 按规则检查TT状态
|
|
|
|
|
*/
|
2023-06-06 07:45:13 +00:00
|
|
|
|
static void rulecheck(void)
|
2023-06-02 02:23:26 +00:00
|
|
|
|
{
|
|
|
|
|
//默认为 TT连续5个周期为激活状态且信号强度不低于5。
|
|
|
|
|
//满足加1,不满足清零
|
2023-08-21 09:18:07 +00:00
|
|
|
|
static size_t okCnt=0;
|
2023-06-06 07:45:13 +00:00
|
|
|
|
if (!okCnt) {
|
2023-08-21 09:18:07 +00:00
|
|
|
|
// LOG_D("当前规则为:连续%d个采集周期TT信号质量不低于%d",scfg.minTTPeriCnt,scfg.minTTsinal);
|
2023-06-06 07:45:13 +00:00
|
|
|
|
}
|
2023-06-11 08:32:09 +00:00
|
|
|
|
int xh=atoi(TTinfo->xh);
|
2023-08-21 09:18:07 +00:00
|
|
|
|
if (xh > 90) {
|
2023-06-11 08:32:09 +00:00
|
|
|
|
xh=0;
|
|
|
|
|
}
|
2023-08-04 10:13:59 +00:00
|
|
|
|
if (atoi(TTinfo->jh) && !(xh < scfg.minTTsinal) ) {//
|
2023-06-02 02:23:26 +00:00
|
|
|
|
okCnt += 1;
|
|
|
|
|
LOG_D("第%d次符合规则。",okCnt);
|
|
|
|
|
}
|
|
|
|
|
else {
|
|
|
|
|
okCnt = 0;
|
2023-08-22 10:23:41 +00:00
|
|
|
|
// LOG_W("不符合。");
|
2023-06-02 02:23:26 +00:00
|
|
|
|
return;
|
|
|
|
|
}
|
2023-08-04 10:13:59 +00:00
|
|
|
|
if (okCnt >= scfg.minTTPeriCnt) {
|
2023-06-02 02:23:26 +00:00
|
|
|
|
//TT具备发送条件
|
2023-08-29 11:29:58 +00:00
|
|
|
|
// LOG_I("----");
|
2023-08-30 02:45:32 +00:00
|
|
|
|
extern void TTIsReady(void);
|
2023-08-01 08:27:21 +00:00
|
|
|
|
TTIsReady();
|
2023-08-29 11:29:58 +00:00
|
|
|
|
// LOG_I("符合规则,TT具备发送状态。");
|
2023-08-04 10:13:59 +00:00
|
|
|
|
okCnt = scfg.minTTPeriCnt -1;
|
2023-06-02 02:23:26 +00:00
|
|
|
|
}
|
2023-06-06 07:45:13 +00:00
|
|
|
|
// if (okCnt > minTTPeriCnt) {
|
|
|
|
|
// //TT具备发送条件
|
|
|
|
|
//// rt_event_send(&sw_check, TT_IS_OK);
|
|
|
|
|
// upTTflag();
|
|
|
|
|
// okCnt = 2;
|
|
|
|
|
// LOG_I("符合规则,TT具备发送状态。");
|
|
|
|
|
//// updateSta();
|
|
|
|
|
// }
|
2023-06-02 02:23:26 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}
|
2023-05-04 08:35:14 +00:00
|
|
|
|
/* 数据解析 */
|
|
|
|
|
static void tt_parse(rt_uint8_t *data)
|
|
|
|
|
{
|
2023-08-22 10:23:41 +00:00
|
|
|
|
// LOG_I("%s",data);
|
2023-05-04 08:35:14 +00:00
|
|
|
|
extern TT *TTinfo;
|
|
|
|
|
cJSON *root = RT_NULL, *object = RT_NULL, *item = RT_NULL;
|
|
|
|
|
|
|
|
|
|
root = cJSON_Parse((const char *) data);
|
|
|
|
|
if (!root)
|
|
|
|
|
{
|
2023-08-21 09:18:07 +00:00
|
|
|
|
LOG_W("JSON string is not ok, or No memory for cJSON root!");
|
2023-05-04 08:35:14 +00:00
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
object = cJSON_GetObjectItem(root, "data");
|
|
|
|
|
|
|
|
|
|
item = cJSON_GetObjectItem(object, "tdsignal");
|
|
|
|
|
if (item)
|
|
|
|
|
{
|
2023-06-06 07:45:13 +00:00
|
|
|
|
// TTinfo->xh = atoi(item->valuestring);
|
2023-05-04 08:35:14 +00:00
|
|
|
|
// tmp.xh = item->valuestring;
|
2023-06-06 07:45:13 +00:00
|
|
|
|
strcpy(TTinfo->xh,item->valuestring);
|
2023-05-04 08:35:14 +00:00
|
|
|
|
// rt_kprintf("\nxh:%s ", item->valuestring);
|
|
|
|
|
// rt_kprintf("\nxh:%s ", TTinfo->xh);
|
|
|
|
|
cJSON_Delete(root);
|
|
|
|
|
return RT_EOK;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
item = cJSON_GetObjectItem(object, "tdnetregstate");
|
|
|
|
|
if (item)
|
|
|
|
|
{
|
2023-06-06 07:45:13 +00:00
|
|
|
|
// TTinfo->rw = atoi(item->valuestring);
|
2023-05-04 08:35:14 +00:00
|
|
|
|
// rt_kprintf("\nrw:%s ", TTinfo.rw);
|
2023-06-06 07:45:13 +00:00
|
|
|
|
strcpy(TTinfo->rw,item->valuestring);
|
2023-05-04 08:35:14 +00:00
|
|
|
|
cJSON_Delete(root);
|
|
|
|
|
return RT_EOK;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
item = cJSON_GetObjectItem(object, "tdpsstate");
|
|
|
|
|
if (item)
|
|
|
|
|
{
|
2023-06-06 07:45:13 +00:00
|
|
|
|
// TTinfo->jh = atoi(item->valuestring);
|
2023-05-04 08:35:14 +00:00
|
|
|
|
// rt_kprintf("\njh:%s ", TTinfo.jh);
|
2023-06-06 07:45:13 +00:00
|
|
|
|
strcpy(TTinfo->jh,item->valuestring);
|
2023-05-04 08:35:14 +00:00
|
|
|
|
cJSON_Delete(root);
|
|
|
|
|
return RT_EOK;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
item = cJSON_GetObjectItem(object, "latitude");
|
|
|
|
|
if (item)
|
|
|
|
|
{
|
2023-06-06 07:45:13 +00:00
|
|
|
|
// TTinfo->wd = item->valuestring;
|
|
|
|
|
strcpy(TTinfo->wd,item->valuestring);
|
2023-05-04 08:35:14 +00:00
|
|
|
|
|
|
|
|
|
item = cJSON_GetObjectItem(object, "longitude");
|
2023-06-06 07:45:13 +00:00
|
|
|
|
// TTinfo->jd = item->valuestring;
|
|
|
|
|
strcpy(TTinfo->jd,item->valuestring);
|
2023-05-04 08:35:14 +00:00
|
|
|
|
|
|
|
|
|
item = cJSON_GetObjectItem(object, "elevation");
|
2023-06-06 07:45:13 +00:00
|
|
|
|
// TTinfo->ele = item->valuestring;
|
|
|
|
|
strcpy(TTinfo->ele,item->valuestring);
|
2023-05-04 08:35:14 +00:00
|
|
|
|
// rt_kprintf("%5s%5s%5s%5s%15s%15s%10s\n", TTinfo->sim, TTinfo->xh, TTinfo->rw,
|
|
|
|
|
// TTinfo->jh, TTinfo->jd, TTinfo->wd,TTinfo->ele);
|
|
|
|
|
|
2023-05-23 06:59:35 +00:00
|
|
|
|
LOG_D("Get RAW data done.");
|
2023-05-04 08:35:14 +00:00
|
|
|
|
cJSON_Delete(root);
|
|
|
|
|
return RT_EOK;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
item = cJSON_GetObjectItem(object, "tdsimstate");
|
|
|
|
|
if (item)
|
|
|
|
|
{
|
2023-06-01 09:10:00 +00:00
|
|
|
|
// TTinfo->sim = atoi(item->valuestring);
|
2023-05-04 08:35:14 +00:00
|
|
|
|
// tmp.sim = item->valuestring;
|
2023-06-01 09:10:00 +00:00
|
|
|
|
strcpy(TTinfo->sim,item->valuestring);
|
2023-05-04 08:35:14 +00:00
|
|
|
|
// rt_kprintf("\nSIM:%s \n", TTinfo->sim);
|
|
|
|
|
cJSON_Delete(root);
|
|
|
|
|
return RT_EOK;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (root != RT_NULL)
|
|
|
|
|
cJSON_Delete(root);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* HTTP client download data by GET request */
|
|
|
|
|
static int webclient_get_data(const char *url)
|
|
|
|
|
{
|
2023-06-01 09:10:00 +00:00
|
|
|
|
static unsigned char *buffer = RT_NULL;
|
2023-05-04 08:35:14 +00:00
|
|
|
|
size_t length = 0;
|
|
|
|
|
|
2023-08-24 03:06:44 +00:00
|
|
|
|
if (!isTCPok() || webclient_request(url, RT_NULL, RT_NULL, 0, (void **) &buffer, &length) <= 0)
|
2023-05-04 08:35:14 +00:00
|
|
|
|
{
|
2023-08-19 06:41:13 +00:00
|
|
|
|
LOG_E("TT server or webclient is not ready.");
|
2023-06-19 07:56:45 +00:00
|
|
|
|
if (buffer)
|
|
|
|
|
{
|
|
|
|
|
web_free(buffer);
|
|
|
|
|
}
|
2023-05-04 08:35:14 +00:00
|
|
|
|
return -RT_ERROR;
|
|
|
|
|
}
|
|
|
|
|
|
2023-05-23 06:59:35 +00:00
|
|
|
|
LOG_D("webclient GET request response data :");
|
|
|
|
|
LOG_D("%s", buffer);
|
2023-05-04 08:35:14 +00:00
|
|
|
|
|
2023-08-24 03:06:44 +00:00
|
|
|
|
if (buffer && length && buffer[length-1] == 0x7d) //0x7d='}',首次返回的数据不完整,此处直接丢掉避免报错
|
2023-05-04 08:35:14 +00:00
|
|
|
|
{
|
2023-08-21 03:17:40 +00:00
|
|
|
|
tt_parse(buffer);
|
2023-05-04 08:35:14 +00:00
|
|
|
|
web_free(buffer);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return RT_EOK;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void getTTinfo_thread_entry(void* parameter)
|
|
|
|
|
{
|
2023-06-02 02:23:26 +00:00
|
|
|
|
// bootstamp = rt_tick_get();
|
2023-05-04 08:35:14 +00:00
|
|
|
|
|
|
|
|
|
CFG* cfg = RT_NULL;
|
|
|
|
|
cfg = (CFG*) parameter;
|
|
|
|
|
// TT TTinfo;
|
|
|
|
|
|
|
|
|
|
rt_kprintf("\n%10s%s\n", " ", "↓---------getTT START.--------↓");
|
|
|
|
|
rt_kprintf("%5s%5s%5s%5s%15s%15s%10s\n", "SIM", "xh", "rw", "jh", "N", "E", "ele");
|
2023-07-24 06:57:28 +00:00
|
|
|
|
for (uint8_t i = 0; i < cfg->cnt; ++i) //按指定次数轮询
|
2023-05-04 08:35:14 +00:00
|
|
|
|
{
|
2023-06-06 07:45:13 +00:00
|
|
|
|
rt_kprintf("%5s%5s%5s%5s%15s%15s%10s\n", TTinfo->sim, TTinfo->xh, TTinfo->rw, TTinfo->jh, TTinfo->jd,
|
2023-06-01 09:10:00 +00:00
|
|
|
|
TTinfo->wd, TTinfo->ele);
|
|
|
|
|
if (i != cfg->cnt - 1) //最后一次采集不延时
|
2023-05-04 08:35:14 +00:00
|
|
|
|
{
|
|
|
|
|
rt_thread_mdelay(cfg->s * 1000);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
rt_kprintf("%10s%s\n", " ", "↑---------getTT DONE.---------↑");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void getTT(int argc, char **argv)
|
|
|
|
|
{
|
|
|
|
|
// size_t cnt = 0, s=3;//次数、间隔
|
|
|
|
|
static CFG cfg;
|
2023-08-31 08:12:44 +00:00
|
|
|
|
rt_memset(&cfg, 0, sizeof(CFG));
|
2023-05-04 08:35:14 +00:00
|
|
|
|
if (argc == 1)
|
|
|
|
|
{
|
|
|
|
|
cfg.cnt = 1;
|
|
|
|
|
cfg.s = 3;
|
|
|
|
|
}
|
|
|
|
|
else if (argc == 2)
|
|
|
|
|
{
|
|
|
|
|
cfg.cnt = atoi(argv[1]);
|
|
|
|
|
cfg.s = 3;
|
|
|
|
|
}
|
|
|
|
|
else if (argc == 3)
|
|
|
|
|
{
|
|
|
|
|
cfg.cnt = atoi(argv[1]);
|
|
|
|
|
cfg.s = atoi(argv[2]);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* 创建 serial 线程 */
|
2023-08-25 08:36:00 +00:00
|
|
|
|
rt_thread_t thread = rt_thread_create("getTT", getTTinfo_thread_entry, (void *) &cfg, 1024 * 5, 25, 10);
|
2023-05-04 08:35:14 +00:00
|
|
|
|
/* 创建成功则启动线程 */
|
|
|
|
|
if (thread != RT_NULL)
|
|
|
|
|
{
|
|
|
|
|
rt_thread_startup(thread);
|
|
|
|
|
// rt_kprintf("done");
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
LOG_E("thread 'getTT' create failure.");
|
|
|
|
|
return RT_ERROR;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* 导出到自动初始化 */
|
|
|
|
|
MSH_CMD_EXPORT(getTT, 获取天通信息,支持参数。 "getTT 3 1" means try 3 times with 1 second interval.);
|
|
|
|
|
//MSH_CMD_EXPORT_ALIAS(webclient_get_data, gTTinfo, GET info of TT server.);
|
2023-07-26 08:26:53 +00:00
|
|
|
|
/**
|
|
|
|
|
* 判断TT是否为开机状态
|
|
|
|
|
* @return 1-开机,0-关机
|
|
|
|
|
*/
|
2023-06-17 10:26:40 +00:00
|
|
|
|
int isTTon(void)
|
|
|
|
|
{
|
2023-08-15 09:10:18 +00:00
|
|
|
|
#ifndef RELAY
|
2023-06-17 10:26:40 +00:00
|
|
|
|
return !rt_pin_read(TT_EN);
|
2023-08-15 09:10:18 +00:00
|
|
|
|
#else
|
|
|
|
|
return rt_pin_read(TT_EN);
|
|
|
|
|
#endif
|
2023-06-17 10:26:40 +00:00
|
|
|
|
}
|
|
|
|
|
|
2023-07-26 08:26:53 +00:00
|
|
|
|
/**
|
|
|
|
|
* 判断TT是否激活
|
|
|
|
|
* @return 1-已激活,0-未激活
|
|
|
|
|
*/
|
2023-08-15 09:10:18 +00:00
|
|
|
|
uint8_t isTTjh(void)
|
2023-07-26 08:26:53 +00:00
|
|
|
|
{
|
|
|
|
|
return atoi(TTinfo->jh);
|
|
|
|
|
}
|
2023-08-15 09:10:18 +00:00
|
|
|
|
uint8_t getXh(void)
|
|
|
|
|
{
|
|
|
|
|
return (uint8_t)atoi(TTinfo->xh);
|
|
|
|
|
}
|
2023-07-26 08:26:53 +00:00
|
|
|
|
|
2023-06-17 10:26:40 +00:00
|
|
|
|
void repGetTT_thread_entry(void* parameter)
|
|
|
|
|
{
|
2023-08-21 09:18:07 +00:00
|
|
|
|
// while(!isTCPok())//第一次运行时未上电则等待
|
|
|
|
|
// {}
|
2023-08-17 01:22:02 +00:00
|
|
|
|
while(isTCPok())//中间未上电则退出
|
2023-06-17 10:26:40 +00:00
|
|
|
|
{
|
|
|
|
|
for (size_t var = 0; var < (sizeof(infoH) / sizeof(infoH[0])); var++) //轮询每个参数
|
|
|
|
|
{
|
2023-08-31 08:12:44 +00:00
|
|
|
|
if (!isTCPok()) {
|
|
|
|
|
break;
|
|
|
|
|
}
|
2023-06-17 10:26:40 +00:00
|
|
|
|
static char *url = RT_NULL;
|
|
|
|
|
url = web_strdup(*(infoH + var));
|
|
|
|
|
if (url == RT_NULL)
|
|
|
|
|
{
|
|
|
|
|
LOG_E("no memory for create getTT url buffer.\n");
|
2023-06-19 07:56:45 +00:00
|
|
|
|
break;
|
2023-06-17 10:26:40 +00:00
|
|
|
|
// return -RT_ENOMEM;
|
|
|
|
|
}
|
|
|
|
|
if (webclient_get_data(url) != RT_EOK)
|
|
|
|
|
{
|
2023-08-22 10:23:41 +00:00
|
|
|
|
// LOG_E("---------");
|
2023-06-19 07:56:45 +00:00
|
|
|
|
web_free(url);
|
2023-06-17 10:26:40 +00:00
|
|
|
|
strcpy(TTinfo->sim,"-");
|
|
|
|
|
strcpy(TTinfo->xh,"-");
|
|
|
|
|
strcpy(TTinfo->jh,"-");
|
|
|
|
|
strcpy(TTinfo->jd,"-");
|
|
|
|
|
strcpy(TTinfo->wd,"-");
|
|
|
|
|
strcpy(TTinfo->ele,"-");
|
|
|
|
|
break;
|
|
|
|
|
}
|
2023-08-21 03:17:40 +00:00
|
|
|
|
if (url) {
|
|
|
|
|
web_free(url);
|
|
|
|
|
}
|
|
|
|
|
|
2023-06-19 07:56:45 +00:00
|
|
|
|
// rt_thread_mdelay(100);
|
2023-07-24 06:57:28 +00:00
|
|
|
|
|
|
|
|
|
//trans© new info to arrBuf
|
|
|
|
|
uint8_t buffer[10];
|
|
|
|
|
int len = info2HEX(TTinfo, buffer);
|
|
|
|
|
appendInfo(rstInfo, RST_LEN, buffer, len);
|
2023-06-17 10:26:40 +00:00
|
|
|
|
}
|
|
|
|
|
rulecheck();
|
2023-09-06 09:25:38 +00:00
|
|
|
|
rt_thread_mdelay(5 * 1000);//间隔3s更新一次数据
|
2023-06-17 10:26:40 +00:00
|
|
|
|
}
|
2023-08-31 08:12:44 +00:00
|
|
|
|
rt_memset(rstInfo,0x3f,RST_LEN);//初始化
|
2023-06-17 10:26:40 +00:00
|
|
|
|
}
|
|
|
|
|
|
2023-06-18 01:34:09 +00:00
|
|
|
|
/**
|
|
|
|
|
* 持续更新TT状态信息,数据3s刷新一次。TT断电后退出。
|
|
|
|
|
*/
|
|
|
|
|
void repGetTT(void)
|
2023-06-17 10:26:40 +00:00
|
|
|
|
{
|
2023-08-21 09:18:07 +00:00
|
|
|
|
while(!isTCPok())//第一次运行时未上电则等待
|
|
|
|
|
{}
|
2023-08-31 08:12:44 +00:00
|
|
|
|
rt_memset(rstInfo,0x3f,RST_LEN);//初始化
|
2023-06-17 10:26:40 +00:00
|
|
|
|
/* 创建 serial 线程 */
|
2023-09-02 11:33:16 +00:00
|
|
|
|
rt_thread_t thread = rt_thread_create("repGetTT", repGetTT_thread_entry, RT_NULL, 1024 * 30, 27+2, 10);
|
2023-06-17 10:26:40 +00:00
|
|
|
|
/* 创建成功则启动线程 */
|
|
|
|
|
if (thread != RT_NULL)
|
|
|
|
|
{
|
|
|
|
|
rt_thread_startup(thread);
|
|
|
|
|
// rt_kprintf("done");
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
LOG_E("thread 'repGetTT' create failure.");
|
|
|
|
|
return RT_ERROR;
|
|
|
|
|
}
|
|
|
|
|
}
|
2023-08-22 10:23:41 +00:00
|
|
|
|
//MSH_CMD_EXPORT(repGetTT,gett);
|
2023-06-19 07:56:45 +00:00
|
|
|
|
|