From b3b682c88a4468f47104f94eebfdbadbfaf10e6e Mon Sep 17 00:00:00 2001 From: WXK <287788329@qq.com> Date: 星期五, 14 二月 2025 09:26:09 +0800 Subject: [PATCH] 1111 --- keil/include/src/TCPClient.c | 105 +++++++++++++++++++++++++++++----------------------- 1 files changed, 59 insertions(+), 46 deletions(-) diff --git a/keil/include/src/TCPClient.c b/keil/include/src/TCPClient.c index be5b299..bd300ca 100644 --- a/keil/include/src/TCPClient.c +++ b/keil/include/src/TCPClient.c @@ -43,6 +43,10 @@ static HIDO_UINT32 l_u32HeartBeatTick = 0; static HIDO_UINT8 l_au8CmdBuff[1024]; +uint8_t TCPfail_flag = 0,flag_first_TCPconnect=1; +uint32_t TCPfailetimer; +uint16_t ip0,ip1,ip2,ip3,port; + /******************************************************************************* * Local Function Declaration * *******************************************************************************/ @@ -55,7 +59,7 @@ /******************************************************************************* * Function Name : TCPClient_DataProc * Description : - * Input : + * Input : * Output : * Return : * Author : www.hido-studio.com @@ -79,77 +83,77 @@ { u32SplitCnt = HIDO_UtilStrSplit((HIDO_CHAR *)_u8Data, ',', apcSplitStr, HIDO_ARRARY_COUNT(apcSplitStr)); TCP_command.tagId = HIDO_UtilHexStrToInt(apcSplitStr[3]); - + if(g_com_map[DEV_ID]==TCP_command.tagId) { - + TCP_command.type = HIDO_UtilStrToInt(apcSplitStr[1]); memcpy(&applyid,apcSplitStr[2],8); - // TCP_command.applyID = HIDO_UtilStrToInt(apcSplitStr[2]); + // TCP_command.applyID = HIDO_UtilStrToInt(apcSplitStr[2]); TCP_command.gunLableId = HIDO_UtilHexStrToInt(apcSplitStr[4]); TCP_command.warnDistance = HIDO_UtilStrToInt(apcSplitStr[5]); TCP_command.alarmDistance = HIDO_UtilStrToInt(apcSplitStr[6]); TCP_command.frequency = HIDO_UtilStrToInt(apcSplitStr[7]); if(TCP_command.type>0&&TCP_command.type<8) - result = 1; - + result = 1; + switch(TCP_command.type) { case BIND_SUCCESS: { - - g_com_map[ALARM_DISTANCE1]= TCP_command.warnDistance; + + g_com_map[ALARM_DISTANCE1]= TCP_command.warnDistance; g_com_map[ALARM_DISTANCE2]=TCP_command.alarmDistance; - // g_com_map[SEND_4G_FREQUENCY]=1000/TCP_command.frequency; + // g_com_map[SEND_4G_FREQUENCY]=1000/TCP_command.frequency; if(g_com_map[BIND_DEV_ID]!=TCP_command.gunLableId) { g_com_map[BIND_DEV_ID]=TCP_command.gunLableId; UWB_work_state = SEARCH_DEV; search_open_flag = 1; } - - + + } break; case UNBIND: g_com_map[BIND_DEV_ID] = 0; UWB_work_state = UN_BIND; - - - break; + + + break; // bind_resetbreak(); case OPEN_GNSS: gps_4g_flag = 1; - - break; + + break; case CLOSE_VIBRATION: g_com_map[MOTOR_ENABLE]=0; - - - break; + + + break; case OPEN_VIBRATION: g_com_map[MOTOR_ENABLE]=1; - - - break; + + + break; case QUARY_INFORMATION: //?? - - break; + + break; case CHANGE_POLL_FREQUENCY: - + g_com_map[SEND_4G_SECOND]=TCP_command.frequency*60; break; } result = 1; TCPHeartBeatUpload(); if(TCP_command.type!=QUARY_INFORMATION||TCP_command.type!=OPEN_GNSS) - save_com_map_to_flash(); - result = 0; + save_com_map_to_flash(); + result = 0; memset(&applyid,0,8); } - }else if(STRCMP(_u8Data, "$message_reply,") == 0) + } else if(STRCMP(_u8Data, "$message_reply,") == 0) { u32SplitCnt = HIDO_UtilStrSplit((HIDO_CHAR *)_u8Data, ',', apcSplitStr, HIDO_ARRARY_COUNT(apcSplitStr)); TCP_command.tagId = HIDO_UtilHexStrToInt(apcSplitStr[1]); @@ -177,6 +181,7 @@ { if(l_eTCPClientState == TCP_CLIENT_STATE_CONNECTING) { + TCPfail_flag = 0; l_eTCPClientState = TCP_CLIENT_STATE_IDLE; } @@ -192,6 +197,7 @@ } case SOCKET_EVENT_CLOSED: { + TCPfail_flag = 0; l_eTCPClientState = TCP_CLIENT_STATE_IDLE; break; } @@ -234,14 +240,14 @@ { HIDO_CHAR acHeart[200]; HIDO_UINT32 u32HeartLen; - if(alarm_type) - { - u32HeartLen = snprintf(acHeart, sizeof(acHeart), "$message,alarm,%04x,%d,%04x,%d,%02u%%,%d,%d,%lf,%lf,%s,%d,%d,0\r\n", \ - g_com_map[DEV_ID],GetUWBBindState(),g_com_map[BIND_DEV_ID],alarm_type,bat_percent,g_com_map[ALARM_DISTANCE1],g_com_map[ALARM_DISTANCE2],jd,wd,applyid,result,distance); - }else{ - u32HeartLen = snprintf(acHeart, sizeof(acHeart), "$message,heart,%04x,%d,%04x,%d,%02u%%,%d,%d,%lf,%lf,%s,%d,%d,0\r\n", \ - g_com_map[DEV_ID],GetUWBBindState(),g_com_map[BIND_DEV_ID],alarm_type,bat_percent,g_com_map[ALARM_DISTANCE1],g_com_map[ALARM_DISTANCE2],jd,wd,applyid,result,distance); -} +// if(alarm_type) +// { +// u32HeartLen = snprintf(acHeart, sizeof(acHeart), "$message,alarm,%04x,%d,%04x,%d,%02u%%,%d,%d,%lf,%lf,%s,%d,%d,0\r\n", \ +// g_com_map[DEV_ID],GetUWBBindState(),g_com_map[BIND_DEV_ID],alarm_type,bat_percent,g_com_map[ALARM_DISTANCE1],g_com_map[ALARM_DISTANCE2],jd,wd,applyid,result,distance); +// } else { +// u32HeartLen = snprintf(acHeart, sizeof(acHeart), "$message,heart,%04x,%d,%04x,%d,%02u%%,%d,%d,%lf,%lf,%s,%d,%d,0\r\n", \ +// g_com_map[DEV_ID],GetUWBBindState(),g_com_map[BIND_DEV_ID],alarm_type,bat_percent,g_com_map[ALARM_DISTANCE1],g_com_map[ALARM_DISTANCE2],jd,wd,applyid,result,distance); +// } Socket_Send(l_i32TCPClientID, (HIDO_UINT8 *)acHeart, u32HeartLen); } @@ -258,9 +264,7 @@ if(alarm_type == 2) alarm_type = 0; } -uint8_t TCPfail_flag = 0,flag_first_TCPconnect=1; -uint32_t TCPfailetimer; -uint16_t ip0,ip1,ip2,ip3,port; + HIDO_INT32 TCPClient_Poll(void) { if (Internet_IsIPReady() == HIDO_TRUE) @@ -272,14 +276,17 @@ { l_eTCPClientState = TCP_CLIENT_STATE_CONNECTING; - + HIDO_UtilSnprintf((HIDO_CHAR *) l_au8CmdBuff, sizeof(l_au8CmdBuff), "%u.%u.%u.%u", ip0,ip1, ip2, ip3); Socket_Connect(l_i32TCPClientID, (HIDO_CHAR *) l_au8CmdBuff, port); // HIDO_UtilSnprintf((HIDO_CHAR *) l_au8CmdBuff, sizeof(l_au8CmdBuff), "123.57.87.125"); // Socket_Connect(l_i32TCPClientID, (HIDO_CHAR *) l_au8CmdBuff, 8888); - TCPfail_flag = 1; + +// HIDO_UtilSnprintf((HIDO_CHAR *) l_au8CmdBuff, sizeof(l_au8CmdBuff), "111.198.60.6"); +// Socket_Connect(l_i32TCPClientID, (HIDO_CHAR *) l_au8CmdBuff, 1234); + TCPfail_flag = 1; } else { @@ -293,10 +300,11 @@ else if (TCP_CLIENT_STATE_CONNECTED == l_eTCPClientState) { - - -// if ((u32CurTick - l_u32HeartBeatTick) >= HIDO_TIMER_TICK_S(g_com_map[SEND_4G_SECOND])||flag_first_TCPconnect) - if ((u32CurTick - l_u32HeartBeatTick) >= HIDO_TIMER_TICK_S(15)||flag_first_TCPconnect) + + + + //if ((u32CurTick - l_u32HeartBeatTick) >= HIDO_TIMER_TICK_S(15)||flag_first_TCPconnect) + if ((u32CurTick - l_u32HeartBeatTick) >= HIDO_TIMER_TICK_S(g_com_map[SEND_4G_SECOND])||flag_first_TCPconnect) { flag_first_TCPconnect = 0; l_u32HeartBeatTick = u32CurTick; @@ -332,6 +340,11 @@ return HIDO_OK; } +HIDO_BOOL TCPClient_IsSendOver(HIDO_VOID) +{ + return Socket_IsSendQueueEmpty(l_i32TCPClientID); +} + /******************************************************************************* * Function Name : TCPClient_Init * Description : TCP客户端初始化 @@ -355,7 +368,7 @@ return HIDO_OK; } -char str[17]={"AT+IPR=9600;&W\r\n"}; +char str[17]= {"AT+IPR=9600;&W\r\n"}; void AIR780E_Reset(void) { gps_air780_power_change(gps_power_state,0);//开启gps,4G -- Gitblit v1.9.3