From 526f2fbdaa4532c5bc0b6dffd7b9b84f784d7fef Mon Sep 17 00:00:00 2001
From: yincheng.zhong <634916154@qq.com>
Date: 星期一, 29 一月 2024 15:49:44 +0800
Subject: [PATCH] 1.76

---
 源码/核心板/Src/application/beep_logic_app.c |  203 +++++++++++++++++++++++++-------------------------
 1 files changed, 102 insertions(+), 101 deletions(-)

diff --git "a/\346\272\220\347\240\201/\346\240\270\345\277\203\346\235\277/Src/application/beep_logic_app.c" "b/\346\272\220\347\240\201/\346\240\270\345\277\203\346\235\277/Src/application/beep_logic_app.c"
index 171a26c..5527f4a 100644
--- "a/\346\272\220\347\240\201/\346\240\270\345\277\203\346\235\277/Src/application/beep_logic_app.c"
+++ "b/\346\272\220\347\240\201/\346\240\270\345\277\203\346\235\277/Src/application/beep_logic_app.c"
@@ -13,65 +13,57 @@
 #define ONTIME3 5   // 500ms
 #define OFFTIME3 5  // 500ms
 
-uint16_t min_dist1,min_dist2;
+int32_t min_dist1,min_dist2;
 extern u16 JDQ_time;
+typedef enum{	
+    NO_ALARM,
+    YUJING_ALARM,
+    BAOJING_ALARM,
+}alarm_state;
+alarm_state alarm1 = NO_ALARM,alarm2 = NO_ALARM;
 void Relay1Task(u16 min_dist)
 {
     static u8 distoffset1=0,distoffset2=0;
     static uint8_t beep_state,timer_state,beep_timer,beep_ontime,beep_offtime;
          if (min_dist <= g_com_map[ALARM_DISTANCE2]+distoffset1)
                 {
-                    beep_ontime = 1;
-                    beep_offtime = 0;
-                    beep_state=2;
-                    distoffset1=0;
-                    distoffset2=0;
-                    beep_timer = 0;
-                    timer_state = 1;
+                    alarm1 = BAOJING_ALARM;
                 }
          else if (min_dist <= g_com_map[ALARM_DISTANCE3]+distoffset2)
                 {
-                    beep_ontime = JDQ_time;
-                    beep_offtime = JDQ_time;
-                    beep_state=1;
-                    distoffset1=0;
-                    distoffset2=0;
+                    alarm1 = YUJING_ALARM;
                 }
                 else{
-                    beep_state=0;
-                    distoffset1=0;
-                    distoffset2=0;
-                    beep_timer = 0;
-                    timer_state = 1;
+                    alarm1 = NO_ALARM;
                 }
                 
-                if(beep_state!=0)
-                {
-                    if(timer_state==1)
-                    {
-                        if(beep_timer++ < beep_ontime)
-                        {
-                            RELAY1_ON;
-                           		
-                        }else{
-                            timer_state=0;
-                            beep_timer=0;
-                        }
-                    }else{
-                        if(beep_timer++ < beep_offtime)
-                            {
-                                RELAY1_OFF;
-                       
-                            }else{
-                                    timer_state=1;
-                                    beep_timer=0;
-                            }
-                        
-                    }
-                }else {
-                    RELAY1_OFF;
-                 //    RELAY2_OFF;
-                }
+//                if(beep_state!=0)
+//                {
+//                    if(timer_state==1)
+//                    {
+//                        if(beep_timer++ < beep_ontime)
+//                        {
+//                            RELAY1_ON;
+//                           		
+//                        }else{
+//                            timer_state=0;
+//                            beep_timer=0;
+//                        }
+//                    }else{
+//                        if(beep_timer++ < beep_offtime)
+//                            {
+//                                RELAY1_OFF;
+//                       
+//                            }else{
+//                                    timer_state=1;
+//                                    beep_timer=0;
+//                            }
+//                        
+//                    }
+//                }else {
+//                    RELAY1_OFF;
+//                 //    RELAY2_OFF;
+//                }
 }
 void Relay2Task(u16 min_dist)
 {
@@ -79,58 +71,63 @@
     static uint8_t beep_state2,timer_state2,beep_timer2,beep_ontime2,beep_offtime2;
          if (min_dist <= g_com_map[RELAY2_DISTANCE2]+distoffset12)
                 {
-                    beep_ontime2 = 1;
-                    beep_offtime2 = 0;
-                    beep_state2=2;
-                    distoffset12=0;
-                    distoffset22=0;
-                    timer_state2=1;
-                    beep_timer2=0;
+                    alarm2 = BAOJING_ALARM;
                 }
          else if (min_dist <= g_com_map[RELAY2_DISTANCE3]+distoffset22)
                 {
-                    beep_ontime2 = JDQ_time;
-                    beep_offtime2 = JDQ_time;
-                    beep_state2=1;
-                    distoffset12=0;
-                    distoffset22=0;
+                    alarm2 = YUJING_ALARM;
                 }
                 else{
-                    beep_state2=0;
-                    distoffset12=0;
-                    distoffset22=0;
-                    timer_state2=1;
-                    beep_timer2=0;
+                    alarm2 = NO_ALARM;
                 }
                 
-                if(beep_state2!=0)
-                {
-                    if(timer_state2==1)
-                    {
-                        if(beep_timer2++ < beep_ontime2)
-                        {
-                            RELAY2_ON;
-                           		
-                        }else{
-                            timer_state2=0;
-                            beep_timer2=0;
-                        }
-                    }else{
-                        if(beep_timer2++ < beep_offtime2)
-                            {
-                                RELAY2_OFF;
-                       
-                            }else{
-                                    timer_state2=1;
-                                    beep_timer2=0;
-                            }
-                        
-                    }
-                }else {
-                   // RELAY1_OFF;
-                     RELAY2_OFF;
-                }
+//                if(beep_state2!=0)
+//                {
+//                    if(timer_state2==1)
+//                    {
+//                        if(beep_timer2++ < beep_ontime2)
+//                        {
+//                            RELAY2_ON;
+//                           		
+//                        }else{
+//                            timer_state2=0;
+//                            beep_timer2=0;
+//                        }
+//                    }else{
+//                        if(beep_timer2++ < beep_offtime2)
+//                            {
+//                                RELAY2_OFF;
+//                       
+//                            }else{
+//                                    timer_state2=1;
+//                                    beep_timer2=0;
+//                            }
+//                        
+//                    }
+//                }else {
+//                   // RELAY1_OFF;
+//                     RELAY2_OFF;
+//                }
 }
+void AlarmJuge(void)
+{
+    if(alarm1 == BAOJING_ALARM||alarm2 == BAOJING_ALARM)
+    {
+        RELAY1_ON;
+        RELAY2_ON;
+        return;
+    }else{
+        RELAY1_OFF;
+    }
+    if(alarm1 == YUJING_ALARM||alarm2 == YUJING_ALARM)
+    {
+        RELAY2_ON;
+    }else{
+        RELAY2_OFF;
+    }
+}
+extern uint16_t tagid_list[TAG_NUM_IN_SYS];
+extern u16 taglist_num;
 void main_logic(void)	//主逻辑在这里执行
 {	
 	uint16_t i;
@@ -141,23 +138,27 @@
             if(beep_judge_cnt++ >= 100)
             {	
                 beep_judge_cnt = 0;
-                min_dist1=0xffff;
-                min_dist2=0xffff;
-                for(i = 0; i < 255;i++)
+                min_dist1=0x1ffff;
+                min_dist2=0x1ffff;
+                for(i = 0; i < taglist_num;i++)
                 {
-                    if(g_Tagdist[i] < min_dist1&&g_Tagdist[i]>g_com_map[ALARM_DISTANCE1])
+                    if((tagid_list[i]>>12)!=9)
                     {
-                        min_dist1=g_Tagdist[i];
+                        if(g_Tagdist[i] < min_dist1&&g_Tagdist[i]>g_com_map[ALARM_DISTANCE1])
+                        {
+                            min_dist1=g_Tagdist[i];
+                        }
                     }
-                    if(g_Tagdist[i] < min_dist2&&g_Tagdist[i]>g_com_map[RELAY2_DISTANCE1])
-                    {
-                        min_dist2=g_Tagdist[i];
-                    }
-                   
+                    else{
+                        if(g_Tagdist[i] < min_dist2&&g_Tagdist[i]>g_com_map[RELAY2_DISTANCE1])
+                        {
+                            min_dist2=g_Tagdist[i];
+                        }
+                    }                   
                 }
                 Relay1Task(min_dist1);
-                Relay2Task(min_dist2);
-         
+                Relay2Task(min_dist2);    
+                AlarmJuge();                
             }
     }else{
         if(g_com_map[RELAY1ON_INDEX]==1)

--
Gitblit v1.9.3