From 2cb63340687ae2ada98c545227ffb247f48f3a9a Mon Sep 17 00:00:00 2001
From: yincheng.zhong <634916154@qq.com>
Date: 星期四, 11 五月 2023 11:05:41 +0800
Subject: [PATCH] V1.9

---
 源码/核心板/Src/application/dw_app.c |   73 ++++++++++++++++++++++++++++++++----
 1 files changed, 64 insertions(+), 9 deletions(-)

diff --git "a/\346\272\220\347\240\201/\346\240\270\345\277\203\346\235\277/Src/application/dw_app.c" "b/\346\272\220\347\240\201/\346\240\270\345\277\203\346\235\277/Src/application/dw_app.c"
index f2aacaf..877e596 100644
--- "a/\346\272\220\347\240\201/\346\240\270\345\277\203\346\235\277/Src/application/dw_app.c"
+++ "b/\346\272\220\347\240\201/\346\240\270\345\277\203\346\235\277/Src/application/dw_app.c"
@@ -1,6 +1,6 @@
 #include "dw_app.h"
 #include "ADC.h"
-#define TDFILTER
+//#define TDFILTER
 enum enumtagstate
 {
 	DISCPOLL,
@@ -861,6 +861,58 @@
 u8 misdist_num[TAG_NUM_IN_SYS],seize_anchor,getrange_success=0;
 int32_t filter_dist,filter_speed;
 u8 newmeasure,recpoll_len;
+uint32_t current_syncid=0xffffffff,synclost_timer;
+extern uint8_t flag_syncbase;
+uint8_t tagpos_rec[50],tagpos_send[50],ancidlist_num;
+uint16_t ancidlist_rec[20],ancidlist_send[20],rec_ancidlist[20],rec_ancdistlist[20];
+uint16_t samegroup_ancid,anc_mount_dist;
+uint8_t getvaluetimes = 0;
+uint16_t first_dist,second_dist,delta_dist;
+int16_t tag_angle[TAG_NUM_IN_SYS],tag_dist[TAG_NUM_IN_SYS];
+float p_dist;
+void AngleCalculate(void)
+{
+    getvaluetimes = 0;
+    for(uint8_t i=0;i<rec_nearbase_num;i++)
+    {
+        if(rec_ancidlist[i]==dev_id)
+        {
+            
+            first_dist = rec_ancdistlist[i];
+            if(first_dist!=0xffff)
+            {
+                getvaluetimes++;
+            }
+        }else if(rec_ancidlist[i]==samegroup_ancid)
+        {
+            
+            second_dist = rec_ancdistlist[i];
+            if(second_dist != 0xffff)
+            {
+                getvaluetimes++;
+            }
+        }
+    }
+    if(getvaluetimes==2)
+    {
+       p_dist = ((float)first_dist-(float)second_dist)/anc_mount_dist;
+        if(p_dist>1)
+        {
+            p_dist = 1;
+        }else if(p_dist<-1)
+        {
+            p_dist = -1;
+        }
+        tag_dist[taglist_pos] = second_dist;
+        tag_angle[taglist_pos]  = asin(p_dist)*57.3; 
+        OUT485_ENABLE;
+		delay_us(10);
+        printf("角度:%d,距离差:%d,距离1:%d,距离2:%d......\r\n",tag_angle[taglist_pos],first_dist-second_dist,first_dist,second_dist);
+		delay_us(10);
+        OUT485_DISABLE;
+    }
+}
+extern int16_t alarm_angle;
 u8 Anchor_RecNearPoll(u8 ancrec_nearbasepos) //0 mainbase  1 first near_base
 {
 	u8 motorstate;
@@ -886,14 +938,18 @@
 				memcpy(&tx_nearresp_msg[DIST_IDX], &tagdist_list[taglist_pos], 4);
 			}
 			motorstate =0;
-		if(tagdist_list[taglist_pos]<g_com_map[ALARM_DISTANCE2])
+		
+            if(g_Tagdist[taglist_pos]<g_com_map[ALARM_DISTANCE1]||g_Tagdist[taglist_pos]==0)
+			{
+				motorstate =0;
+			}else if(g_Tagdist[taglist_pos]<g_com_map[ALARM_DISTANCE2])
 			{
 				if(flag_tag_distsmooth[taglist_pos])
 				{motorstate =2;
 				}else{
 					motorstate =0;
 				}
-			}else if(tagdist_list[taglist_pos]<g_com_map[ALARM_DISTANCE3])
+			}else if(g_Tagdist[taglist_pos]<g_com_map[ALARM_DISTANCE3])
 			{
 				if(flag_tag_distsmooth[taglist_pos])
 				{motorstate =1;
@@ -901,7 +957,7 @@
 					motorstate =0;
 				}
 			}
-      tx_nearresp_msg[GROUP_ID_IDX] = group_id;
+            tx_nearresp_msg[GROUP_ID_IDX] = group_id;
 			tx_nearresp_msg[MAINBASE_INDEX]=flag_syncbase;
 			tx_nearresp_msg[MESSAGE_TYPE_IDX]=NEAR_RESPONSE;
 			tx_nearresp_msg[MOTORSTATE_INDEX]=motorstate;//(remotesend_state<<4)|motorstate;
@@ -1008,6 +1064,7 @@
                         }else{
                             g_Tagdist[taglist_pos]= 0x2ffff;
                         }
+                         AngleCalculate();
 				#ifdef USART_SINGLE_OUTPUT
 					usart_send[2] = 1;//正常模式 
 					usart_send[3] = 17;//数据段长度
@@ -1020,7 +1077,7 @@
 					usart_send[13] = battary;
 					usart_send[14] = button;
 					usart_send[15] = firstpath_power;
-					usart_send[16] = rx_power;
+					usart_send[16] = tag_angle[taglist_pos];
 					checksum = Checksum_u16(&usart_send[2],17);
 					memcpy(&usart_send[19],&checksum,2);
 					UART_PushFrame(usart_send,21);
@@ -1039,11 +1096,9 @@
 					//printf("%x/n",status_reg);
 				dwt_write32bitreg(SYS_STATUS_ID, SYS_STATUS_ALL_RX_ERR);
 			}
+           
 }
-uint32_t current_syncid=0xffffffff,synclost_timer;
-extern u8 flag_syncbase;
-u8 tagpos_rec[50],tagpos_send[50],ancidlist_num;
-u16 ancidlist_rec[20],ancidlist_send[20],rec_ancidlist[20],rec_ancdistlist[20];
+
 void Anchor_App(void)
 {
 	

--
Gitblit v1.9.3