From dd4e6900813f4ca7e98d6d287baf1f8626303625 Mon Sep 17 00:00:00 2001 From: WXK <287788329@qq.com> Date: 星期一, 26 五月 2025 09:55:21 +0800 Subject: [PATCH] 加入气压数据输出在gps 跟uwb里 --- keil/uwb_app.c | 31 +++++++++++++++++++++---------- 1 files changed, 21 insertions(+), 10 deletions(-) diff --git a/keil/uwb_app.c b/keil/uwb_app.c index 20ba960..4dbf58a 100644 --- a/keil/uwb_app.c +++ b/keil/uwb_app.c @@ -11,6 +11,8 @@ #include "board.h" #include "lib_aoa.h" #include "WS2812.h" +#include "TCPClient.h" + extern int simple_main(void); extern int temp_main(void); void Calibration_Time(void); @@ -62,6 +64,7 @@ int16_t elevation = 0; int16_t azimuth = 0; uint8_t fom = 0; +extern CountState_t current_state; int32_t distance; uint8_t taglist_num; float *sts_rssi=NULL; @@ -141,7 +144,7 @@ // .phy_cfg.sts_seglen = STS_SEGLEN_BPRF_64, /* Number of symbols in an STS segment */ // .phy_cfg.rx_ant_id = UWB_RX_ANT_3, /* UWB RX antenna port */ //}; -#ifdef UWB_DW1000_XB +#ifdef UWB_MK8000_XB static struct mk_uwb_configure config = { .phy_work_mode = (uint8_t)(PHY_TX | PHY_RX), .phy_cfg.ch_num = 5, /* Channel number. */ @@ -158,7 +161,7 @@ .phy_cfg.rx_ant_id = UWB_RX_ANT_3, /* UWB RX antenna port */ }; #endif -#ifdef UWB_DW1000_MBXJZ +#ifdef UWB_DW1000_MBXJZ_OLD static struct mk_uwb_configure config = { .phy_work_mode = (uint8_t)(PHY_TX | PHY_RX), .phy_cfg.ch_num = 5, /* Channel number. */ @@ -356,9 +359,7 @@ Anchor_App(); if(resp_tx_flag==0) { - OpenUWB(); - } // #ifdef STS_MODE // valid_sts= sts_valid_check(); @@ -669,6 +670,7 @@ if(uwb_losttimer>g_com_map[UWB_RNAGE_TIME]) uwb_losttimer=g_com_map[UWB_RNAGE_TIME]+1;//防止溢出 } +extern uint16_t gaodu; void UWBSendUDPTask(void) { uint16_t checksum,tempdistarray[20]; @@ -709,8 +711,8 @@ // } // Set4LEDColor(uwbled,rtkled,led4g,powerled); - if(taglist_num>20) //最多上传20个基站数据,距离最近的20个 - taglist_num = 20; + if(taglist_num>14) //最多上传20个基站数据,距离最近的20个 + taglist_num = 14; usart_send[0]= 0x55; usart_send[1]= 0xaa; usart_send[2] = 0x12;//正常模式 @@ -722,8 +724,9 @@ // usart_send[8] = rxnum; usart_send[9] = userkey_state|0<<1|0<<2|0<<5|uwb_state<<6; // memcpy(&usart_send[10],&rec_tagheight,2); - usart_send[12] = 0; - usart_send[13] = 0; + memcpy(&usart_send[12],gaodu,2); +// usart_send[12] = 0; +// usart_send[13] = 0; usart_send[14] = 0; usart_send[15] = 0; usart_send[16] = taglist_num; @@ -734,7 +737,7 @@ checksum = Checksum_u16(&usart_send[2],15+5*taglist_num); memcpy(&usart_send[17+5*taglist_num],&checksum,2); HexToAsciiSendUDP(usart_send,19+5*taglist_num); - taglist_num = 0; +// taglist_num = 0; // rxnum=0; } void UWBIdleTask(void) @@ -754,17 +757,23 @@ { uwbtasktimer = HIDO_TimerGetTick(); UWBOneSecondTask(); -// UWBSendUDPTask(); + if(g_com_map[UWBFrequency]==1) + { + UWBSendUDPTask(); + } } } int uwb_app_poll(void) { UWBIdleTask(); } +extern uint8_t uwb_offtime_count; int Anchor_App(void) { uint8_t i; uint16_t tempid; + uwb_offtime_count=0; + current_state = STATE_NORMAL; if(group_id==rx_buf[GROUP_ID_IDX]&&rx_buf[MESSAGE_TYPE_IDX] == MBX_POLL)//判断是否是和自己是同一组通讯的且为poll包 { flag_recsuccess = 1; wltag_state=RANGE;//成功后从search切换为range @@ -779,6 +788,8 @@ memcpy(rec_ancdistlist,&rx_buf[FZ_NEARBASEID_INDEX+2*rec_nearbase_num],2*rec_nearbase_num); memcpy(&rec_antdelay,&rx_buf[FZ_NEARBASEID_INDEX+rec_nearbase_num*4],2); uwbled=BLUE; + + // for(i=0; i<rec_nearbase_num; i++) // { // if(rec_ancidlist[i] == dev_id) -- Gitblit v1.9.3