diff --git a/MDK-ARM/.vscode/keil-assistant.log b/MDK-ARM/.vscode/keil-assistant.log
index 67e4303..8d5c96e 100644
--- a/MDK-ARM/.vscode/keil-assistant.log
+++ b/MDK-ARM/.vscode/keil-assistant.log
@@ -94,3 +94,11 @@
[info] Log at : 2025/6/30|10:24:59|GMT+0800
+[info] Log at : 2025/7/1|10:57:51|GMT+0800
+
+[info] Log at : 2025/7/2|02:59:15|GMT+0800
+
+[info] Log at : 2025/7/2|17:15:33|GMT+0800
+
+[info] Log at : 2025/7/4|09:10:46|GMT+0800
+
diff --git a/MDK-ARM/.vscode/settings.json b/MDK-ARM/.vscode/settings.json
index e5a3724..ceea9fd 100644
--- a/MDK-ARM/.vscode/settings.json
+++ b/MDK-ARM/.vscode/settings.json
@@ -5,6 +5,7 @@
"buzzer.h": "c",
"calc_lib.h": "c",
"usertask.h": "c",
- "detect.h": "c"
+ "detect.h": "c",
+ "nuc.h": "c"
}
}
\ No newline at end of file
diff --git a/MDK-ARM/.vscode/uv4.log b/MDK-ARM/.vscode/uv4.log
index 8ed7e1c..001bdc4 100644
--- a/MDK-ARM/.vscode/uv4.log
+++ b/MDK-ARM/.vscode/uv4.log
@@ -1,76 +1,13 @@
*** Using Compiler 'V5.06 update 7 (build 960)', folder: 'D:\keil\ARM\ARMCC\Bin'
-Rebuild target 'R1'
-assembling startup_stm32f407xx.s...
-compiling dma.c...
-compiling spi.c...
-compiling gpio.c...
-compiling stm32f4xx_hal_msp.c...
-compiling tim.c...
-compiling stm32f4xx_it.c...
-compiling stm32f4xx_hal_rcc.c...
-compiling freertos.c...
-compiling main.c...
-compiling usart.c...
-compiling stm32f4xx_hal_can.c...
-compiling crc.c...
-compiling can.c...
-compiling stm32f4xx_hal_gpio.c...
-compiling stm32f4xx_hal_flash_ramfunc.c...
-compiling stm32f4xx_hal_flash_ex.c...
-compiling stm32f4xx_hal_flash.c...
-compiling stm32f4xx_hal_rcc_ex.c...
-compiling stm32f4xx_hal_cortex.c...
-compiling stm32f4xx_hal_pwr_ex.c...
-compiling stm32f4xx_hal_dma.c...
-compiling stm32f4xx_hal_crc.c...
-compiling stm32f4xx_hal.c...
-compiling stm32f4xx_hal_pwr.c...
-compiling croutine.c...
-compiling stm32f4xx_hal_exti.c...
-compiling event_groups.c...
-compiling list.c...
-compiling stm32f4xx_hal_dma_ex.c...
-compiling queue.c...
-compiling stream_buffer.c...
-compiling timers.c...
-compiling tasks.c...
-compiling heap_4.c...
-compiling system_stm32f4xx.c...
-compiling port.c...
-compiling stm32f4xx_hal_spi.c...
-compiling stm32f4xx_hal_uart.c...
-compiling stm32f4xx_hal_tim_ex.c...
-compiling stm32f4xx_hal_tim.c...
-compiling calc_lib.c...
-compiling crc_ccitt.c...
-compiling kalman.c...
-compiling cmsis_os2.c...
-compiling bsp_buzzer.c...
-compiling bsp_delay.c...
-compiling can_init.c...
-compiling can_it.c...
-compiling gpio_it.c...
-compiling uart_it.c...
-compiling filter.c...
-compiling pid.c...
-compiling user_math.c...
-compiling buzzer.c...
-compiling userTask.c...
-compiling detect.c...
-compiling shoot.cpp...
-compiling vofa.c...
-compiling remote_control.c...
-compiling djiMotor.c...
-compiling GO_M8010_6_Driver.c...
-compiling nuc.c...
-compiling ball.cpp...
-compiling initTask.c...
-compiling ballTask.cpp...
-compiling encodeCan.cpp...
-compiling nucTask.cpp...
+Build target 'R1'
compiling shootTask.cpp...
+compiling nuc.c...
+compiling initTask.c...
+compiling ball.cpp...
+compiling nucTask.cpp...
+compiling shoot.cpp...
linking...
-Program Size: Code=32916 RO-data=1832 RW-data=276 ZI-data=32220
+Program Size: Code=32960 RO-data=1832 RW-data=268 ZI-data=32220
FromELF: creating hex file...
"R1\R1.axf" - 0 Error(s), 0 Warning(s).
-Build Time Elapsed: 00:04:01
+Build Time Elapsed: 00:02:09
diff --git a/MDK-ARM/.vscode/uv4.log.lock b/MDK-ARM/.vscode/uv4.log.lock
index 4fb6d15..397b7bf 100644
--- a/MDK-ARM/.vscode/uv4.log.lock
+++ b/MDK-ARM/.vscode/uv4.log.lock
@@ -1 +1 @@
-2025/6/30 14:27:15
\ No newline at end of file
+2025/7/4 9:21:52
\ No newline at end of file
diff --git a/MDK-ARM/R1.uvoptx b/MDK-ARM/R1.uvoptx
index 73eea2c..1e93deb 100644
--- a/MDK-ARM/R1.uvoptx
+++ b/MDK-ARM/R1.uvoptx
@@ -178,7 +178,22 @@
4
1
- cmd_fromnuc
+ nuc_v
+
+
+ 5
+ 1
+ abc,0x0A
+
+
+ 6
+ 1
+ shoot_wait,0x0A
+
+
+ 7
+ 1
+ error_code
diff --git a/User/device/nuc.c b/User/device/nuc.c
index 1fbcaaa..0cf5add 100644
--- a/User/device/nuc.c
+++ b/User/device/nuc.c
@@ -4,7 +4,7 @@
static osThreadId_t thread_alert;
-static volatile uint32_t drop_message = 0;
+volatile uint32_t drop_message = 0;
uint8_t nucbuf[16];
uint8_t packet[32]; // 假设最大数据包长度为 32 字节
@@ -13,10 +13,11 @@ static void NUC_CBLTCallback(void)
{
osThreadFlagsSet(thread_alert, SIGNAL_NUC_RAW_REDY);
}
+uint32_t error_code;
static void NUC_ERRORCALLBACK(void)
{
- NUC_Restart();
- uint32_t error_code = HAL_UART_GetError(BSP_UART_GetHandle(BSP_UART_AI));
+ NUC_Restart();
+ error_code = HAL_UART_GetError(BSP_UART_GetHandle(BSP_UART_AI));
}
@@ -33,22 +34,8 @@ int8_t NUC_Init(NUC_t *nuc)
return DEVICE_OK;
}
-// static void NUC_IdleCallback(void) {
-// osThreadFlagsSet(thread_alert,SIGNAL_NUC_RAW_REDY);
-
-// }
-
-// int8_t NUC_Init(NUC_t *nuc){
-// if(nuc == NULL) return DEVICE_ERR_NULL;
-// if((thread_alert = osThreadGetId()) == NULL ) return DEVICE_ERR_NULL;
-// BSP_UART_RegisterCallback(BSP_UART_AI,BSP_UART_IDLE_LINE_CB,
-// NUC_IdleCallback);
-
-// return DEVICE_OK;
-// }
-
int8_t NUC_StartReceiving(void) {
- if (HAL_UARTEx_ReceiveToIdle_DMA(BSP_UART_GetHandle(BSP_UART_AI),
+ if (HAL_UART_Receive_DMA(BSP_UART_GetHandle(BSP_UART_AI),
(uint8_t *)nucbuf,
sizeof(nucbuf)) == HAL_OK)
return DEVICE_OK;
@@ -63,7 +50,7 @@ int8_t NUC_Restart(void) {
bool_t NUC_WaitDmaCplt(void) {
- return (osThreadFlagsWait(SIGNAL_NUC_RAW_REDY, osFlagsWaitAll,500) ==
+ return (osThreadFlagsWait(SIGNAL_NUC_RAW_REDY, osFlagsWaitAll,20) ==
SIGNAL_NUC_RAW_REDY);
}
@@ -94,7 +81,7 @@ int8_t NUC_SendPacket(void *data, uint16_t length) {
return DEVICE_OK; // 发送成功
}
-int wzcsb=0;
+
int8_t NUC_RawParse(NUC_t *n) {
if (n == NULL) return DEVICE_ERR_NULL;
union {
@@ -112,12 +99,10 @@ int8_t NUC_RawParse(NUC_t *n) {
case VISION:
/* 协议格式
0xFF HEAD
- 0x09
+ 0x07
控制帧
0x01 相机帧
x fp32
- y fp32
- z fp32
0xFE TAIL
*/
if (nucbuf[7] != TAIL) goto error;
@@ -146,7 +131,7 @@ int8_t NUC_RawParse(NUC_t *n) {
error:
- wzcsb++;
+ drop_message++;
return DEVICE_ERR;
}
diff --git a/User/device/nuc.h b/User/device/nuc.h
index 6c8ff79..02a0bac 100644
--- a/User/device/nuc.h
+++ b/User/device/nuc.h
@@ -8,6 +8,7 @@ extern "C" {
#include "struct_typedef.h"
#include "device.h"
#include "uart_it.h"
+#include "main.h"
// 帧头针尾
#define HEAD (0xFF)
@@ -15,7 +16,7 @@ extern "C" {
#define ODOM (0x04)
#define PICK (0x06)
-#define VISION (0x09)
+#define VISION (0x07)
#define SEND (0X07)
// 写结构体存入视觉信息
diff --git a/User/module/ball.cpp b/User/module/ball.cpp
index cce6747..b004a4d 100644
--- a/User/module/ball.cpp
+++ b/User/module/ball.cpp
@@ -11,6 +11,7 @@ extern int ball_exit;
// 外死点168 外163 中150 内127 限位124.8
// 伸缩
+//外死点168 外163 中150 内127 限位124.8
#define I_ANGLE 127
#define O_ANGLE 163
#define WAIT_POS 150
@@ -78,7 +79,7 @@ void Ball::rc_mode()
}
if (rc_ctrl.sw[5] == 200)
{
- ready_key = DE; // 默认不准备
+ ready_key = DEF; // 默认不准备
}
}
@@ -237,14 +238,16 @@ void Ball::ball_control()
ballHadling();
break;
}
+
Send_control();
}
// 防守
- if(ready_key == DEFENSE)
+ else if(ready_key == DEF)
{
xiaomi.position = I_ANGLE; // 保持收回
HAL_GPIO_WritePin(CLOSE_GPIO_Port, CLOSE_Pin, GPIO_PIN_RESET); // 确保爪气缸关闭
HAL_GPIO_WritePin(DOWN_GPIO_Port, DOWN_Pin, GPIO_PIN_RESET); // 确保下气缸关闭
+
Send_control();
}
@@ -286,6 +289,7 @@ void Ball::ballDown(void)
break;
case EXTEND_FINISH:
+ HAL_GPIO_WritePin(CLOSE_GPIO_Port, CLOSE_Pin, GPIO_PIN_RESET);
xiaomi.position = O_ANGLE; // 一直保持伸出
// 等待拨杆复位(如切到MIDDLE2),Idle_control会负责回位
break;
@@ -358,6 +362,7 @@ void Ball::ballHadling(void)
break;
case BALL_FORWARD:
+ osDelay(300); // 不放太快
HAL_GPIO_WritePin(CLOSE_GPIO_Port, CLOSE_Pin, GPIO_PIN_SET); // 打开气缸爪子
osDelay(5);
HAL_GPIO_WritePin(DOWN_GPIO_Port, DOWN_Pin, GPIO_PIN_SET); // 打开下气缸
diff --git a/User/module/ball.hpp b/User/module/ball.hpp
index 4a0a678..8595c5f 100644
--- a/User/module/ball.hpp
+++ b/User/module/ball.hpp
@@ -40,7 +40,7 @@ typedef enum
IN,
OUT,
SIDE,
- DE
+ DEF
}ball_rc_mode;
// 定义光电传感器检测宏
diff --git a/User/module/shoot.cpp b/User/module/shoot.cpp
index 36474ea..62765dd 100644
--- a/User/module/shoot.cpp
+++ b/User/module/shoot.cpp
@@ -58,7 +58,7 @@ Shoot::Shoot()
go1.K_P = 1.0f,
go1.K_W = 0.05,
go1.Pos = 0, // 上电先到一个舒服的位置
- go1.W = 0,
+ go1.W = 0,
go1.T = 0,
limit_speed = TO_TOP; // 快速上去
@@ -148,71 +148,6 @@ int Shoot::GO_SendData(float pos, float limit)
// B键 sw[3]👆 200 开 中 1000 👇1800 关
// sw[5] 👆 200 👇1800
// 左旋 sw[7] 200 --1800
-// void Shoot::rc_mode()
-// {
-// if (rc_ctrl.sw[1] == 200)
-// {
-// rc_key = UP1;
-// }
-// if (rc_ctrl.sw[1] == 1800 && rc_ctrl.sw[2] == 200)
-// {
-// rc_key = MIDDLE1;
-// }
-// if (rc_ctrl.sw[2] == 1800 && rc_ctrl.sw[1] == 1800)
-// {
-// rc_key = DOWN1;
-// }
-// if (rc_ctrl.sw[0] == 1800)
-// {
-// mode_key = PASS;
-// }
-// if (rc_ctrl.sw[0] == 200)
-// {
-// mode_key = VSION;
-// }
-// // if(rc_ctrl.sw[5]==200)
-// // {
-// // mode_key=OUT;
-// // }
-// if (rc_ctrl.sw[5] == 1800)
-// {
-// ready_key = OFFENSIVE;
-// }
-// else if (rc_ctrl.sw[5] == 200)
-// {
-// ready_key = DEFENSE;
-// }
-
-// // //旋钮增量
-// // static int last_knob_value = 0; // 记录旋钮的上一次值
-// // int current_knob_value = rc_ctrl.sw[7]; // 获取当前旋钮值
-
-// // // 计算旋钮增量
-// // if (current_knob_value >= 200 && current_knob_value <= 1800) {
-// // knob_increment = (current_knob_value - last_knob_value) / 15.0f; // 每80单位对应一个增量
-// // } else {
-// // knob_increment = 0; // 如果旋钮值超出范围,不产生增量
-// // }
-
-// // 旋钮物理范围
-// const int knob_min = 200;
-// const int knob_max = 1800;
-
-// // 目标映射范围
-// const float map_min = 130.0f;
-// const float map_max = -60.0f;
-
-// int current_knob_value = rc_ctrl.sw[7];
-
-// // 限制范围
-// if (current_knob_value < knob_min)
-// current_knob_value = knob_min;
-// if (current_knob_value > knob_max)
-// current_knob_value = knob_max;
-
-// // 线性映射
-// knob_increment = map_min + (map_max - map_min) * (current_knob_value - knob_min) / (knob_max - knob_min);
-// }
void Shoot::rc_mode()
{
@@ -226,12 +161,12 @@ void Shoot::rc_mode()
if (bottom_sensor == 0)
{
is_ready = true;
-
- // 可选:蜂鸣器提示“归零成功”
+ BSP_Buzzer_Stop();
}
else
{
- // 未到位,所有按键无效,直接返回
+ BSP_Buzzer_Start();
+ BSP_Buzzer_Set(1, 5000);
return;
}
}
@@ -455,7 +390,6 @@ void Shoot::RemoveError()
#if ONE_CONTROL
-int shoot_wait = 0;
void Shoot::shoot_control()
{
@@ -499,10 +433,11 @@ void Shoot::shoot_control()
t_posSet = Tigger_ZERO;
if (feedback.fd_tpos >= Tigger_ZERO - 20)
{
-
+
BSP_Buzzer_Stop();
currentState = SHOOT_IDLE;
osThreadFlagsClear(EXTEND_OK);
+ osThreadFlagsClear(READY_TELL); // 蓄力标志位
shoot_wait = 0;
}
}
@@ -546,7 +481,7 @@ void Shoot::shoot_control()
break;
case DOWN1:
- if (shoot_thread & EXTEND_OK )
+ if (shoot_thread & EXTEND_OK)
{
if (shoot_wait == 1)
{
@@ -557,6 +492,7 @@ void Shoot::shoot_control()
BSP_Buzzer_Stop();
currentState = SHOOT_IDLE;
osThreadFlagsClear(EXTEND_OK);
+ osThreadFlagsClear(READY_TELL); // 蓄力标志位
shoot_wait = 0;
}
}
diff --git a/User/module/shoot.hpp b/User/module/shoot.hpp
index a008caf..54d1f7d 100644
--- a/User/module/shoot.hpp
+++ b/User/module/shoot.hpp
@@ -112,6 +112,8 @@ private:
float limit_speed;//go电机限速
+ int shoot_wait;
+
};
diff --git a/User/task/ballTask.cpp b/User/task/ballTask.cpp
index c50162a..6408282 100644
--- a/User/task/ballTask.cpp
+++ b/User/task/ballTask.cpp
@@ -34,15 +34,12 @@ void FunctionBall(void *argument)
#endif
//abc=HAL_GPIO_ReadPin(up_ball_GPIO_Port, up_ball_Pin);
- abc=HAL_GPIO_ReadPin(BALL_GPIO_Port, BALL_Pin); // 0为到位
+ abc=HAL_GPIO_ReadPin(BALL_GPIO_Port, BALL_Pin); // 0为到位
ball.rc_mode(); // 遥控器模式
ball.ball_control(); // 控制球的动作
-// HAL_GPIO_WritePin(CLOSE_GPIO_Port, CLOSE_Pin, GPIO_PIN_SET); // 确保气缸爪子闭合
-// HAL_GPIO_WritePin(DOWN_GPIO_Port, DOWN_Pin, GPIO_PIN_SET); // 确保下气缸关闭
-
// ball.xiaomi.position = aaaa;
// CAN_XiaoMi(1,&ball.xiaomi,&hcan2);
diff --git a/User/task/nucTask.cpp b/User/task/nucTask.cpp
index f622aaf..8895412 100644
--- a/User/task/nucTask.cpp
+++ b/User/task/nucTask.cpp
@@ -1,10 +1,11 @@
#include "nucTask.hpp"
#include "nuc.h"
#include "userTask.h"
-#include "TopDefine.h"//事件组的一些东西
+#include "TopDefine.h" //事件组的一些东西
#include "FreeRTOS.h"
#include
#include
+#include "bsp_buzzer.h"
#ifdef DEBUG
@@ -14,50 +15,53 @@ NUC_t cmd_fromnuc;
void Function_nuc(void *argument)
{
- (void)argument; /* 未使用argument,消除警告 */
-
- const uint32_t delay_tick = osKernelGetTickFreq() / TASK_FREQ_AI;
+ (void)argument; /* 未使用argument,消除警告 */
- NUC_Init(&cmd_fromnuc);
-
- HAL_GPIO_WritePin(LED_G_GPIO_Port,LED_G_Pin,GPIO_PIN_SET);
+ const uint32_t delay_tick = osKernelGetTickFreq() / TASK_FREQ_AI;
- uint32_t tick = osKernelGetTickCount();
+ NUC_Init(&cmd_fromnuc);
- while(1)
- {
+ uint32_t tick = osKernelGetTickCount();
+
+ while (1)
+ {
#ifdef DEBUG
- task_struct.stack_water_mark.nuc = osThreadGetStackSpace(osThreadGetId());
-#endif
+ task_struct.stack_water_mark.nuc = osThreadGetStackSpace(osThreadGetId());
+#endif
NUC_StartReceiving();
- //NUC_RawParse(&cmd_fromnuc);
- //NUC_SendPacket(&send, sizeof(send)); // 发送数据包
-//掉线处理有空写
- // if(NUC_WaitDmaCplt())
- // {
- // NUC_RawParse(&cmd_fromnuc);
-
+ // NUC_RawParse(&cmd_fromnuc);
+ // NUC_SendPacket(&send, sizeof(send)); // 发送数据包
+ // 掉线处理有空写
+ // if(NUC_WaitDmaCplt())
+ // {
+ // NUC_RawParse(&cmd_fromnuc);
+
// }
// else
// {
// NUC_HandleOffline(&cmd_fromnuc);
// }
- // 假设你在主循环或任务里这样用
if (NUC_RawParse(&cmd_fromnuc) == DEVICE_OK)
{
- osMessageQueueReset(task_struct.msgq.nuc); // 清空消息队列
- osMessageQueuePut(task_struct.msgq.nuc,&(cmd_fromnuc),0,0);
+ //BSP_Buzzer_Stop();
+ HAL_GPIO_WritePin(LED_G_GPIO_Port, LED_G_Pin, GPIO_PIN_SET);
+ HAL_GPIO_WritePin(LED_R_GPIO_Port, LED_R_Pin, GPIO_PIN_RESET);
+ osMessageQueueReset(task_struct.msgq.nuc); // 清空消息队列
+ osMessageQueuePut(task_struct.msgq.nuc, &(cmd_fromnuc), 0, 0);
}
else
{
- NUC_HandleOffline(&cmd_fromnuc);
- }
- osDelay(2);
- tick += delay_tick; /* 计算下一个唤醒时刄1ķ*/
- osDelayUntil(tick);
-
- }
+ // BSP_Buzzer_Start();
+ // BSP_Buzzer_Set(1, 5000);
+ HAL_GPIO_WritePin(LED_G_GPIO_Port, LED_G_Pin, GPIO_PIN_RESET);
+ HAL_GPIO_WritePin(LED_R_GPIO_Port, LED_R_Pin, GPIO_PIN_SET);
+ NUC_HandleOffline(&cmd_fromnuc);
+ }
+
+ tick += delay_tick; /* 计算下一个唤醒时刄1ķ*/
+ osDelayUntil(tick);
+ }
}