From 7db378e2b93702b98ffe7f7b6ab9a4d20aaabb20 Mon Sep 17 00:00:00 2001 From: zhyinch <zhyinch@gmail.com> Date: 星期四, 16 四月 2020 08:50:37 +0800 Subject: [PATCH] V1.10 去掉基站标识,改输出模式 --- 源码/核心板/Src/application/dw_app.c | 41 +++++++++++++++++++++++++++++++++-------- 1 files changed, 33 insertions(+), 8 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 0c1c192..2f077f3 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" @@ -158,7 +158,7 @@ } u16 tag_time_recv[TAG_NUM_IN_SYS]; -u8 usart_send[25]; +u8 usart_send[100]; u8 battary,button; extern uint8_t g_pairstart; void tag_sleep_configuraion(void) @@ -238,7 +238,7 @@ } } u8 anclost_times=0; -u8 exsistbase_list[MAX_NEARBASE_NUM]; +u8 exsistbase_list[MAX_NEARBASE_NUM],report_num; void NearPoll(void) { static u8 mainbase_lost_count=0,flag_finalsend; @@ -247,6 +247,7 @@ uint32_t final_tx_time; u32 start_poll; u8 i,j,getsync_flag=0,timeout; +// printf("%d",sync_timer); dwt_forcetrxoff(); dwt_setrxaftertxdelay(POLL_TX_TO_RESP_RX_DLY_UUS); //设置发送后开启接收,并设定延迟时间 dwt_setrxtimeout(RESP_RX_TIMEOUT_UUS); @@ -257,6 +258,7 @@ } //nearbase_num=0; recbase_num=0; + tx_near_msg[BATTARY_IDX] = Get_Battary(); tx_near_msg[BUTTON_IDX] = !READ_KEY0; tx_near_msg[SEQUENCE_IDX] = frame_seq_nb++; @@ -326,8 +328,8 @@ memcpy(&sync_timer,&rx_buffer[ANCTIMEMS],2); memcpy(&tmp_time,&rx_buffer[ANCTIMEUS],2); exsistbase_list[0]=1; -// memcpy(&tagslotpos,&rx_buffer[TAGSLOTPOS],2); - +//// memcpy(&tagslotpos,&rx_buffer[TAGSLOTPOS],2); +// tmp_time=tmp_time+450; if(tmp_time>999) { @@ -362,6 +364,7 @@ dwt_writetxfctrl(28+nearbase_num*4, 0);//设定发送数据长度 if(temp_dist!=0x1ffff) { + #ifndef USART_INTEGRATE_OUTPUT usart_send[2] = 1;//正常模式 usart_send[3] = 17;//数据段长度 usart_send[4] = frame_seq_nb;//数据段长度 @@ -373,6 +376,7 @@ checksum = Checksum_u16(&usart_send[2],17); memcpy(&usart_send[19],&checksum,2); UART_PushFrame(usart_send,21); + #endif } //result=dwt_starttx(DWT_START_TX_DELAYED);//设定为延迟发送 }else{ @@ -394,6 +398,7 @@ LED0_BLINK; if(temp_dist!=0x1ffff) { + #ifndef USART_INTEGRATE_OUTPUT usart_send[2] = 1;//正常模式 usart_send[3] = 17;//数据段长度 usart_send[4] = frame_seq_nb;//数据段长度 @@ -405,6 +410,7 @@ checksum = Checksum_u16(&usart_send[2],17); memcpy(&usart_send[19],&checksum,2); UART_PushFrame(usart_send,21); + #endif //dwt_setdelayedtrxtime(final_tx_time);//设置final包发送时间T5 // result=dwt_starttx(DWT_START_TX_DELAYED);//设定为延迟发送 @@ -454,11 +460,25 @@ } } } + report_num=0; for (i=0;i<nearbase_num;i++) { nearbaseid_list[i]=true_nearbase_idlist[i]; - nearbase_distlist[i]=true_nearbase_distlist[i]; + nearbase_distlist[i]=true_nearbase_distlist[i]; + if(nearbase_distlist[i]!=0x1ffff) + { + memcpy(&usart_send[4+6*report_num],&nearbaseid_list[i],2); + memcpy(&usart_send[6+6*report_num],&nearbase_distlist[i],4); + report_num++; + } } + #ifdef USART_INTEGRATE_OUTPUT + usart_send[2] = 4;//正常模式 + usart_send[3] = report_num*6+2;//正常模式 + checksum = Checksum_u16(&usart_send[2],report_num*6+2); + memcpy(&usart_send[4+report_num*6],&checksum,2); + UART_PushFrame(usart_send,6+report_num*6); + #endif // if(mainbase_lost_count>5) // { // //tag_state=DISCPOLL; @@ -522,7 +542,6 @@ void Tag_App(void)//发送模式(TAG标签) { //LED0_ON; - dwt_forcetrxoff(); g_Resttimer=0; NearPoll(); } @@ -557,7 +576,7 @@ } uint32_t frame_len; uint32_t resp_tx_time; -uint8_t rec_nearbase_num; +uint8_t rec_nearbase_num,anc_report_num; void Anchor_RecPoll(void) { tmp_time=TIM3->CNT; @@ -716,7 +735,8 @@ { misdist_num=0; tagdist_list[taglist_pos] = hex_dist; - his_dist[taglist_pos]=hex_dist; + his_dist[taglist_pos]=hex_dist; + #ifndef USART_INTEGRATE_OUTPUT usart_send[2] = 1;//正常模式 usart_send[3] = 17;//数据段长度 usart_send[4] = frame_seq_nb;//数据段长度 @@ -728,6 +748,11 @@ checksum = Checksum_u16(&usart_send[2],17); memcpy(&usart_send[19],&checksum,2); UART_PushFrame(usart_send,21); + #else + memcpy(&usart_send[4+6*anc_report_num],&tag_id_recv,2); + memcpy(&usart_send[6+6*anc_report_num],&tagdist_list[taglist_pos],4); + anc_report_num++; + #endif }else{ misdist_num++; } -- Gitblit v1.9.3