From fc89f1e7e828ce2045d9744ab4816b30d72e4c22 Mon Sep 17 00:00:00 2001
From: zhangbo <zhangbo@qq.com>
Date: 星期三, 07 五月 2025 10:25:44 +0800
Subject: [PATCH] 1.12添加无测距休眠30秒开一次测距

---
 keil/include/main/main.c |   65 +++++++++++++++++++-------------
 1 files changed, 39 insertions(+), 26 deletions(-)

diff --git a/keil/include/main/main.c b/keil/include/main/main.c
index 7c564a2..1bcc551 100644
--- a/keil/include/main/main.c
+++ b/keil/include/main/main.c
@@ -29,6 +29,7 @@
 extern int simple_main(void);
 extern int temp_main(void);
 void boot_deinit(void);
+void upload_apppoll();
 #define TEST_UART_POLL_MODE 0
 #define TEST_UART_INTERUPT_MODE 1
 #define TEST_UART_DMA_MODE 2
@@ -42,8 +43,8 @@
 
 
 #define UWB_OPEN_COUNT 1
-#define UWB_MEASUREMENT_INTERVAL 3
-#define UWB_MEASUREMENT_INTERVAL_SLEEP 60
+#define UWB_MEASUREMENT_INTERVAL 5
+#define UWB_MEASUREMENT_INTERVAL_SLEEP 30
 
 extern uint8_t mUsartReceivePack[100];
 extern uint8_t mUsart2ReceivePack[150];
@@ -78,11 +79,7 @@
 } Operation_step;
 
 Operation_step UWB_work_state;
-// 定义状态
-typedef enum {
-    STATE_NORMAL,    // 正常状态,3秒测距上传一次
-    STATE_SLEEP      // 休眠状态,1分钟测距上传一次
-} CountState_t;
+
 
 uint32_t uwb_time_count = 0;  // 定时器计数值
 //uint32_t step_count = 0;      // 步数计数
@@ -306,7 +303,7 @@
 }
 uint8_t tt=1;
 uint8_t flag_sleeptimer,flag_secondtask,secondtask_count,log_4g_enable_flag;
-uint8_t uwb_enable_flag=0;
+uint8_t uwb_offtime_count=0;
 uint8_t input5v_time;
 extern uint8_t taglist_num;
 uint8_t gps_ntripsend;
@@ -316,6 +313,15 @@
     {   
         input5v_time=1;
         flag_secondtask = 1;
+			  #ifdef UWB_1_5HZ
+			  uwb_time_count++;
+		    #endif
+			  uwb_offtime_count++;
+			  if(uwb_offtime_count>30)
+				{
+				 uwb_offtime_count=0;
+				 current_state = STATE_SLEEP;
+				}
         if(!read_5v_input_pca())
         {
         if(bat_percent>15)
@@ -332,10 +338,11 @@
         input5v_time=1;
         if(taglist_num==0)
         {
-        CloseUWB();
-        Uwb_init();
-        OpenUWB();
+//        CloseUWB();
+//        Uwb_init();
+//        OpenUWB();
         }
+		 upload_apppoll();
     }else{
         flag_secondtask = 0;
     }
@@ -426,7 +433,7 @@
 		}
     g_com_map[MODBUS_MODE] = 0;
 		log_4g_enable_flag=g_com_map[LOG_4G_ENABLE];
-    g_com_map[VERSION] = (1<<8)|8;
+    g_com_map[VERSION] = (1<<8)|12;
          
         
     LOG_INFO(TRACE_MODULE_APP,"设备ID: %x .\r\n",dev_id);
@@ -604,9 +611,12 @@
 }
 
 extern uint32_t uwb_time_count;
+uint8_t GPS_UPLOAD_FLAG=0;
 void upload_apppoll()
 {	
-	  uint32_t elapsed_time_jibu;
+	uint32_t elapsed_time_jibu;
+#ifdef UWB_1_5HZ
+	  
 
     switch (current_state) 
 			{
@@ -616,35 +626,37 @@
 						{
 							case UWB_OPEN_COUNT:
 									 CloseUWB();
-									 uwbled = LEDOFF;
+//									 uwbled = LEDOFF;
+							     UWBSendUDPTask();
+							     GPS_UPLOAD_FLAG=1;
 							break;
 							
 							case UWB_MEASUREMENT_INTERVAL:
+								   taglist_num = 0;
 									 OpenUWB();
-									 uwbled = BLUE;							
-                   state_start_time = uwb_time_count;							
+//									 uwbled = WHITE;							
+                   state_start_time = uwb_time_count;	
+							
 							break;						
 						}
             break;
-
         case STATE_SLEEP:
             elapsed_time_jibu = uwb_time_count - state_start_time;
 				    switch(elapsed_time_jibu)
 						{
 							case UWB_OPEN_COUNT:
-
-											CloseUWB();	
+									 CloseUWB();
+                   UWBSendUDPTask();							
 							break;
 							
 							case UWB_MEASUREMENT_INTERVAL_SLEEP:
-
-											OpenUWB();	
-                      state_start_time = uwb_time_count;							
+									 OpenUWB();	
+                   state_start_time = uwb_time_count;							
 							break;						
 						}
             break;
 			}	
-
+#endif
 }
 
 uint8_t flag_4guart_needinit=0;
@@ -710,7 +722,9 @@
     adc_get(&sample[0], NUM_SAMPLES, adc_callback);//adc采样
     pca_input_detection_init(pca_handler);//pca检测输入
     Uwb_init();
-    OpenUWB();    
+		#ifdef UWB_CK
+		OpenUWB();
+		#endif  
 //    DBG_SetMode(DBG_MODE_SHELL);
 //    Shell_Init();
 
@@ -731,7 +745,6 @@
     while (1)
     { 
         uwb_app_poll();
-//			  upload_apppoll();
         Internet_Poll();
         HIDO_TimerPoll();
         HIDO_ATLitePoll();
@@ -745,7 +758,7 @@
             flag_secondtask = 0;
             SecondTask();
         }
-		IMUTask();
+		    IMUTask();
         IdleTask();
     }
 }

--
Gitblit v1.9.3