From a235d146612544b42b79b49dd128153a156b9352 Mon Sep 17 00:00:00 2001
From: ws <1621320660@qq.com>
Date: Fri, 30 May 2025 22:24:12 +0800
Subject: [PATCH] =?UTF-8?q?=E4=B8=8D=E7=9F=A5=E9=81=93=E5=B0=B1=E8=BF=99?=
=?UTF-8?q?=E6=A0=B7=E5=90=A7?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
MDK-ARM/.vscode/c_cpp_properties.json | 36 ++---
MDK-ARM/.vscode/keil-assistant.log | 16 +++
MDK-ARM/.vscode/uv4.log | 12 +-
MDK-ARM/.vscode/uv4.log.lock | 2 +-
MDK-ARM/R1-shooter.uvoptx | 73 +++++------
README.md | 13 +-
User/device/djiMotor.c | 2 +-
User/module/ball.cpp | 117 ++++++++++++-----
User/module/ball.hpp | 10 ++
User/module/shoot.cpp | 182 +++++++++++++++-----------
User/module/shoot.hpp | 15 ++-
User/task/ballTask.cpp | 58 ++++----
User/task/shootTask.cpp | 37 ++++--
13 files changed, 345 insertions(+), 228 deletions(-)
diff --git a/MDK-ARM/.vscode/c_cpp_properties.json b/MDK-ARM/.vscode/c_cpp_properties.json
index 120b12d..479213b 100644
--- a/MDK-ARM/.vscode/c_cpp_properties.json
+++ b/MDK-ARM/.vscode/c_cpp_properties.json
@@ -3,26 +3,26 @@
{
"name": "R1-shooter",
"includePath": [
- "d:\\Desktop\\r1\\r1_upper\\r1upper-1\\Core\\Inc",
- "d:\\Desktop\\r1\\r1_upper\\r1upper-1\\Drivers\\STM32F4xx_HAL_Driver\\Inc",
- "d:\\Desktop\\r1\\r1_upper\\r1upper-1\\Drivers\\STM32F4xx_HAL_Driver\\Inc\\Legacy",
- "d:\\Desktop\\r1\\r1_upper\\r1upper-1\\Middlewares\\Third_Party\\FreeRTOS\\Source\\include",
- "d:\\Desktop\\r1\\r1_upper\\r1upper-1\\Middlewares\\Third_Party\\FreeRTOS\\Source\\CMSIS_RTOS_V2",
- "d:\\Desktop\\r1\\r1_upper\\r1upper-1\\Middlewares\\Third_Party\\FreeRTOS\\Source\\portable\\RVDS\\ARM_CM4F",
- "d:\\Desktop\\r1\\r1_upper\\r1upper-1\\Drivers\\CMSIS\\Device\\ST\\STM32F4xx\\Include",
- "d:\\Desktop\\r1\\r1_upper\\r1upper-1\\Drivers\\CMSIS\\Include",
- "d:\\Desktop\\r1\\r1_upper\\r1upper-1\\User\\bsp",
- "d:\\Desktop\\r1\\r1_upper\\r1upper-1\\User\\module",
- "d:\\Desktop\\r1\\r1_upper\\r1upper-1\\User\\task",
- "d:\\Desktop\\r1\\r1_upper\\r1upper-1\\User\\lib",
- "d:\\Desktop\\r1\\r1_upper\\r1upper-1\\User\\device",
+ "d:\\Desktop\\r1\\r1_upper\\r1_upper\\r1upper-1\\Core\\Inc",
+ "d:\\Desktop\\r1\\r1_upper\\r1_upper\\r1upper-1\\Drivers\\STM32F4xx_HAL_Driver\\Inc",
+ "d:\\Desktop\\r1\\r1_upper\\r1_upper\\r1upper-1\\Drivers\\STM32F4xx_HAL_Driver\\Inc\\Legacy",
+ "d:\\Desktop\\r1\\r1_upper\\r1_upper\\r1upper-1\\Middlewares\\Third_Party\\FreeRTOS\\Source\\include",
+ "d:\\Desktop\\r1\\r1_upper\\r1_upper\\r1upper-1\\Middlewares\\Third_Party\\FreeRTOS\\Source\\CMSIS_RTOS_V2",
+ "d:\\Desktop\\r1\\r1_upper\\r1_upper\\r1upper-1\\Middlewares\\Third_Party\\FreeRTOS\\Source\\portable\\RVDS\\ARM_CM4F",
+ "d:\\Desktop\\r1\\r1_upper\\r1_upper\\r1upper-1\\Drivers\\CMSIS\\Device\\ST\\STM32F4xx\\Include",
+ "d:\\Desktop\\r1\\r1_upper\\r1_upper\\r1upper-1\\Drivers\\CMSIS\\Include",
+ "d:\\Desktop\\r1\\r1_upper\\r1_upper\\r1upper-1\\User\\bsp",
+ "d:\\Desktop\\r1\\r1_upper\\r1_upper\\r1upper-1\\User\\module",
+ "d:\\Desktop\\r1\\r1_upper\\r1_upper\\r1upper-1\\User\\task",
+ "d:\\Desktop\\r1\\r1_upper\\r1_upper\\r1upper-1\\User\\lib",
+ "d:\\Desktop\\r1\\r1_upper\\r1_upper\\r1upper-1\\User\\device",
"D:\\keil\\ARM\\ARMCC\\include",
"D:\\keil\\ARM\\ARMCC\\include\\rw",
- "d:\\Desktop\\r1\\r1_upper\\r1upper-1\\MDK-ARM",
- "d:\\Desktop\\r1\\r1_upper\\r1upper-1\\Core\\Src",
- "d:\\Desktop\\r1\\r1_upper\\r1upper-1\\Drivers\\STM32F4xx_HAL_Driver\\Src",
- "d:\\Desktop\\r1\\r1_upper\\r1upper-1\\Middlewares\\Third_Party\\FreeRTOS\\Source",
- "d:\\Desktop\\r1\\r1_upper\\r1upper-1\\Middlewares\\Third_Party\\FreeRTOS\\Source\\portable\\MemMang"
+ "d:\\Desktop\\r1\\r1_upper\\r1_upper\\r1upper-1\\MDK-ARM",
+ "d:\\Desktop\\r1\\r1_upper\\r1_upper\\r1upper-1\\Core\\Src",
+ "d:\\Desktop\\r1\\r1_upper\\r1_upper\\r1upper-1\\Drivers\\STM32F4xx_HAL_Driver\\Src",
+ "d:\\Desktop\\r1\\r1_upper\\r1_upper\\r1upper-1\\Middlewares\\Third_Party\\FreeRTOS\\Source",
+ "d:\\Desktop\\r1\\r1_upper\\r1_upper\\r1upper-1\\Middlewares\\Third_Party\\FreeRTOS\\Source\\portable\\MemMang"
],
"defines": [
"USE_HAL_DRIVER",
diff --git a/MDK-ARM/.vscode/keil-assistant.log b/MDK-ARM/.vscode/keil-assistant.log
index 5d1bd7b..210b1cd 100644
--- a/MDK-ARM/.vscode/keil-assistant.log
+++ b/MDK-ARM/.vscode/keil-assistant.log
@@ -106,3 +106,19 @@
[info] Log at : 2025/5/23|21:04:08|GMT+0800
+[info] Log at : 2025/5/25|14:26:08|GMT+0800
+
+[info] Log at : 2025/5/26|19:07:26|GMT+0800
+
+[info] Log at : 2025/5/26|20:16:52|GMT+0800
+
+[info] Log at : 2025/5/27|00:06:58|GMT+0800
+
+[info] Log at : 2025/5/27|19:35:30|GMT+0800
+
+[info] Log at : 2025/5/28|13:50:56|GMT+0800
+
+[info] Log at : 2025/5/29|19:03:54|GMT+0800
+
+[info] Log at : 2025/5/30|19:34:50|GMT+0800
+
diff --git a/MDK-ARM/.vscode/uv4.log b/MDK-ARM/.vscode/uv4.log
index fb7ea63..03df30f 100644
--- a/MDK-ARM/.vscode/uv4.log
+++ b/MDK-ARM/.vscode/uv4.log
@@ -1,16 +1,8 @@
*** Using Compiler 'V5.06 update 7 (build 960)', folder: 'D:\keil\ARM\ARMCC\Bin'
Build target 'R1-shooter'
-compiling motor.cpp...
compiling ball.cpp...
-compiling djiMotor.c...
-compiling gimbal.cpp...
-compiling encodeCan.cpp...
-compiling shoot.cpp...
-compiling ballTask.cpp...
-compiling shootTask.cpp...
-compiling gimbalTask.cpp...
linking...
-Program Size: Code=28808 RO-data=1800 RW-data=264 ZI-data=23712
+Program Size: Code=30584 RO-data=2144 RW-data=276 ZI-data=24012
FromELF: creating hex file...
"R1-shooter\R1-shooter.axf" - 0 Error(s), 0 Warning(s).
-Build Time Elapsed: 00:00:05
+Build Time Elapsed: 00:00:03
diff --git a/MDK-ARM/.vscode/uv4.log.lock b/MDK-ARM/.vscode/uv4.log.lock
index 1473684..83f0a16 100644
--- a/MDK-ARM/.vscode/uv4.log.lock
+++ b/MDK-ARM/.vscode/uv4.log.lock
@@ -1 +1 @@
-2025/5/23 21:17:13
\ No newline at end of file
+2025/5/28 19:17:30
\ No newline at end of file
diff --git a/MDK-ARM/R1-shooter.uvoptx b/MDK-ARM/R1-shooter.uvoptx
index 2b9c404..a8fdc74 100644
--- a/MDK-ARM/R1-shooter.uvoptx
+++ b/MDK-ARM/R1-shooter.uvoptx
@@ -103,7 +103,7 @@
1
0
0
- 6
+ 3
@@ -114,7 +114,7 @@
- STLink\ST-LINKIII-KEIL_SWO.dll
+ BIN\CMSIS_AGDI.dll
@@ -140,7 +140,7 @@
0
DLGUARM
- (105=-1,-1,-1,-1,0)
+
0
@@ -153,40 +153,7 @@
-U00160029510000164E574E32 -O2254 -SF10000 -C0 -A0 -I0 -HNlocalhost -HP7184 -P1 -N00("ARM CoreSight SW-DP (ARM Core") -D00(2BA01477) -L00(0) -TO131090 -TC10000000 -TT10000000 -TP21 -TDS8007 -TDT0 -TDC1F -TIEFFFFFFFF -TIP8 -FO15 -FD20000000 -FC800 -FN1 -FF0STM32F4xx_1024.FLM -FS08000000 -FL0100000 -FP0($$Device:STM32F407IGHx$CMSIS\Flash\STM32F4xx_1024.FLM)
-
-
- 0
- 0
- 169
- 1
- 134235782
- 0
- 0
- 0
- 0
- 0
- 1
- ..\User\device\djiMotor.c
-
- \\R1_shooter\../User/device/djiMotor.c\169
-
-
- 1
- 0
- 174
- 1
- 134235770
- 0
- 0
- 0
- 0
- 0
- 1
- ..\User\device\djiMotor.c
-
- \\R1_shooter\../User/device/djiMotor.c\174
-
-
+
0
@@ -303,6 +270,36 @@
1
motor_5065
+
+ 23
+ 1
+ test_distance
+
+
+ 24
+ 1
+ xxx
+
+
+ 25
+ 1
+ test_speed,0x0A
+
+
+ 26
+ 1
+ speedm,0x0A
+
+
+ 27
+ 1
+ Torque,0x0A
+
+
+ 28
+ 1
+ triggerspeed,0x0A
+
@@ -1113,7 +1110,7 @@
User/module
- 0
+ 1
0
0
0
diff --git a/README.md b/README.md
index e0529d1..5e0cdac 100644
--- a/README.md
+++ b/README.md
@@ -14,4 +14,15 @@ r1上层
//PC6 接球光电
-//PI6 运球光电
\ No newline at end of file
+//PI6 运球光电
+
+## 上层过程
+
++ 一个按键切换 运球 /发射
++ 👈 运球 +
++ .3
+
+
+
+
+
diff --git a/User/device/djiMotor.c b/User/device/djiMotor.c
index ca9390a..e277254 100644
--- a/User/device/djiMotor.c
+++ b/User/device/djiMotor.c
@@ -416,7 +416,7 @@ return DEVICE_OK;
uint32_t send_mail_box;
id = controller_id | ((uint32_t)CAN_PACKET_SET_RPM << 8);
- assert_param_rpm(&RPM);
+ //assert_param_rpm(&RPM);
data = (int32_t)(RPM);
vesc_tx_message.ExtId = id;
diff --git a/User/module/ball.cpp b/User/module/ball.cpp
index 35c69c1..4439b92 100644
--- a/User/module/ball.cpp
+++ b/User/module/ball.cpp
@@ -7,8 +7,8 @@
extern RC_ctrl_t rc_ctrl;
extern int key;
-// C键 sw[4]👆 200 中1000 👇1800
-// D键 sw[5]👆 1800 👇200
+// C键 sw[5]👆 1800 中1000 👇200
+// D键 sw[6]👆 200 👇1800
#define M_SPEED 4000
@@ -17,6 +17,8 @@ extern int key;
//添加平移3508 得跑位置吧
const fp32 Ball:: M3508_speed_PID[3] = {15, 0.03, 0};
+const fp32 Ball:: Extend_speed_PID[3] = { 25, 0, 0.};
+const fp32 Ball:: Extend_angle_PID[3]= { 60, 0, 0.1};
//摩擦轮转速
int speedm=0;
@@ -40,6 +42,23 @@ Ball ::Ball()
speedSet[i] = 0;
}
+ //两个伸缩6020
+ Extern_Motor[0] = get_motor_point(6);
+ Extern_Motor[1] = get_motor_point(7);
+
+ Extern_Motor[0]->type = GM6020;
+ Extern_Motor[1]->type = GM6020;
+ PID_init(&extend_speed_pid[0],PID_POSITION,Extend_speed_PID,25000, 2000);
+ PID_init(&extend_angle_pid[0],PID_POSITION,Extend_angle_PID,25000, 1000);
+
+ PID_init(&extend_speed_pid[1],PID_POSITION,Extend_speed_PID,25000, 2000);
+ PID_init(&extend_angle_pid[1],PID_POSITION,Extend_angle_PID,25000, 1000);
+
+ e_result[0] = 0;
+ e_result[1] = 0;
+ angleSet[0] = 0;
+ angleSet[1] = 0;
+
//小米电机初始化
JZ_xiaomi.position = 0; //
JZ_xiaomi.speed = 20; //
@@ -55,6 +74,35 @@ Ball ::Ball()
}
+void Ball ::Extend_control(int angle)
+{
+ int16_t delta[2];
+ angleSet[0] = angle;
+ angleSet[1] = -angle;
+
+ delta[0] = PID_calc(&extend_angle_pid[0],Extern_Motor[0]->total_angle , angleSet[0]);
+ e_result[0] = PID_calc(&extend_speed_pid[0], Extern_Motor[0]->speed_rpm, delta[0]);
+
+ delta[1] = PID_calc(&extend_angle_pid[1], Extern_Motor[1]->total_angle , angleSet[1]);
+ e_result[1] = PID_calc(&extend_speed_pid[1], Extern_Motor[1]->speed_rpm, delta[1]);
+
+ // delta[1] = PID_calc(&extend_angle_pid, angle_get[1], angleSet[1]);
+ // e_result[1] = PID_calc(&extend_speed_pid, Extern_Motor[1]->speed_rpm, delta[1]);
+
+ // angle_get[0]=motor_angle_change(Extern_Motor[0]->real_round, angleSet[0]);
+ // angle_get[1]=motor_angle_change(Extern_Motor[1]->real_round, angleSet[1]);
+
+
+ // delta[0] = PID_calc(&extend_angle_pid, angle_get[0], angleSet[0]);
+ // e_result[0] = PID_calc(&extend_speed_pid, Extern_Motor[0]->speed_rpm, delta[0]);
+
+ // delta[1] = PID_calc(&extend_angle_pid, angle_get[1], angleSet[1]);
+ // e_result[1] = PID_calc(&extend_speed_pid, Extern_Motor[1]->speed_rpm, delta[1]);
+
+
+}
+
+
void Ball ::Spin(float speed)
{
@@ -78,6 +126,7 @@ void Ball::ballDown(void)
void Ball::ballStop(void)
{
+ HAL_GPIO_WritePin(CLOSE_GPIO_Port, CLOSE_Pin, GPIO_PIN_RESET); // 确保闭合气缸
speedm=0;
}
@@ -98,77 +147,70 @@ void Ball::ballTake(void)
void Ball::ballHadling(void)
{
+ static int last_sw5 = 0; // 保存上一次拨杆状态
+ ball_state = HAL_GPIO_ReadPin(up_ball_GPIO_Port, up_ball_Pin); // 有球 1 无球 0
- ball_state =HAL_GPIO_ReadPin(up_ball_GPIO_Port, up_ball_Pin);//有球 1 无球 0
switch (currentState1)
{
case BALL_IDLE:
- HAL_GPIO_WritePin(CLOSE_GPIO_Port, CLOSE_Pin, GPIO_PIN_RESET);//确保闭合气缸
- if (rc_ctrl.sw[4] > 1000||key > 0) // 检测按键是否被按下,自动回弹的
+ HAL_GPIO_WritePin(CLOSE_GPIO_Port, CLOSE_Pin, GPIO_PIN_RESET); // 确保闭合气缸
+ // 只在拨杆从非200切到200时触发
+ if ((rc_ctrl.sw[5] == 200 && last_sw5 != 200) || key > 0)
{
- speedm=-4000;
+ speedm = -4000;
currentState1 = BALL_FORWARD; // 切换到正转状态
}
break;
case BALL_FORWARD:
-
- if ( hand_Motor[MOTOR_1]->speed_rpm >= 3980&&hand_Motor[MOTOR_1]->speed_rpm <= 4020 &&
- hand_Motor[MOTOR_2]->speed_rpm <= -3980&&hand_Motor[MOTOR_2]->speed_rpm >= -4020 &&
- hand_Motor[MOTOR_3]->speed_rpm <= -3980&&hand_Motor[MOTOR_3]->speed_rpm >= -4020 )
+ if (hand_Motor[MOTOR_1]->speed_rpm >= 3980 && hand_Motor[MOTOR_1]->speed_rpm <= 4020 &&
+ hand_Motor[MOTOR_2]->speed_rpm <= -3980 && hand_Motor[MOTOR_2]->speed_rpm >= -4020 &&
+ hand_Motor[MOTOR_3]->speed_rpm <= -3980 && hand_Motor[MOTOR_3]->speed_rpm >= -4020)
{
- HAL_GPIO_WritePin(CLOSE_GPIO_Port, CLOSE_Pin, GPIO_PIN_SET);// 打开气缸
+ HAL_GPIO_WritePin(CLOSE_GPIO_Port, CLOSE_Pin, GPIO_PIN_SET); // 打开气缸
currentState1 = BALL_DROP; // 切换到球下落状态
}
break;
case BALL_DROP:
-
- if (ball_state == 0) //读光电 有球 1 无球 0
+ if (ball_state == 0) // 读光电 有球 1 无球 0
{
osDelay(200); // 延时200ms
- speedm=3500;
+ speedm = 3500;
currentState1 = BALL_REVERSE; // 切换到反转状态
}
-
break;
case BALL_REVERSE:
-
- if (ball_state == 1)
+ if (ball_state == 1)
{
-
- speedm=0; // 停止电机
+ speedm = 0; // 停止电机
currentState1 = BALL_CLOSE; // 切换到完成状态
}
-
- break;
+ break;
case BALL_CLOSE:
-
- if(ball_state == 1)
- {
- HAL_GPIO_WritePin(CLOSE_GPIO_Port, CLOSE_Pin, GPIO_PIN_RESET);
- currentState1 = BALL_FINISH; // 切换到完成状态
- }
-
- break;
+ if (ball_state == 1)
+ {
+ HAL_GPIO_WritePin(CLOSE_GPIO_Port, CLOSE_Pin, GPIO_PIN_RESET);
+ currentState1 = BALL_FINISH; // 切换到完成状态
+ }
+ break;
case BALL_FINISH:
- osDelay(200); // 延时50ms
- key=0; // 重置按键状态
- speedm=0;
+ osDelay(200); // 延时200ms
+ key = 0; // 重置按键状态
+ speedm = 0;
osThreadFlagsSet(task_struct.thread.shoot, BALL_OK);
- currentState1 = BALL_IDLE; // 回到空闲状态
+ currentState1 = BALL_IDLE; // 直接回到空闲状态
break;
default:
- currentState1 = BALL_IDLE; // 默认回到空闲状态
+ currentState1 = BALL_IDLE; // 默认回到空闲状态
break;
}
-
-
+ last_sw5 = rc_ctrl.sw[5]; // 更新上一次拨杆状态
}
void Ball::Send_control()
@@ -176,6 +218,9 @@ void Ball::Send_control()
CAN_cmd_200(result[MOTOR_1],result[MOTOR_2],result[MOTOR_3],0,&hcan1);
osDelay(1);
+ CAN_cmd_1FF(0,0,e_result[0],e_result[1],&hcan1);
+ osDelay(2);
+
}
#else
diff --git a/User/module/ball.hpp b/User/module/ball.hpp
index 3919c88..4bb3c3e 100644
--- a/User/module/ball.hpp
+++ b/User/module/ball.hpp
@@ -54,6 +54,7 @@ public:
void Send_control(void);
void ballStop(void);
void ballTake(void);
+ void Extend_control(int angle);
BallState_t currentState1; // 当前状态
int flag;//暂时还没用到
@@ -62,6 +63,10 @@ public:
//小米电机伸缩
JZ_xiaomi_t JZ_xiaomi;
+ //伸缩6020
+ int16_t e_result[2];
+ motor_measure_t * Extern_Motor[2];
+
int16_t result[MOTOR_NUM];
motor_measure_t *hand_Motor[MOTOR_NUM];
//==========================公共变量==========================//
@@ -75,12 +80,17 @@ private:
static const float M3508_speed_PID[3];
static const float M3508_angle_PID[3];
+ static const float Extend_speed_PID[3];
+ static const float Extend_angle_PID[3];
//电机速度pid结构体
pid_type_def speed_pid[MOTOR_NUM];
//位置环pid
pid_type_def angle_pid[MOTOR_NUM];
+ pid_type_def extend_speed_pid[2];
+ pid_type_def extend_angle_pid[2];
+
float angleSet[2];
float speedSet[MOTOR_NUM];
};
diff --git a/User/module/shoot.cpp b/User/module/shoot.cpp
index 32e84e1..0b24d5f 100644
--- a/User/module/shoot.cpp
+++ b/User/module/shoot.cpp
@@ -8,24 +8,32 @@
#include "vofa.h"
extern RC_ctrl_t rc_ctrl;
+NUC_t nuc_v;
+
float vofa[8];
#define SHOOT_SPEED 30500
#define SHOOT_SPEED_BACK -2500
#define Error 50
-int test_speed =30500;
+int triggerspeed = -5000; // 扳机速度
+int test_speed =34700;
+float test_distance =3.6;
+float xxx;
#define STOP 0
+int Torque = -5000; // 扳机恒力
#define Trigger_Torque -5000
+#define Trigger_Slow 2000//扳机慢速 不用加负号
//sw[7]👆 1694 中 1000 👇306
//sw[2]👆 1694 👇306
-//F键 sw[0]👆 1800 中 1000 👇200
-//E键 sw[1]👆 1800 👇200
+//E键 sw[1]👆 200 shoot 中 1000 stop 👇1800 error
+//F键 sw[0]👆 1800 开 👇200 关
+//B键 sw[3]👆 200 开 👇1800 关
-const fp32 Shoot:: M2006_speed_PID[3] = {5, 0, 0};
+const fp32 Shoot:: M2006_speed_PID[3] = {50, 0, 0};
int t=0;
Shoot::Shoot()
@@ -33,8 +41,8 @@ Shoot::Shoot()
//扳机初始化
trigger_Motor= get_motor_point(4);
trigger_Motor->type=M2006;
- PID_init(&speed_pid,PID_POSITION,M2006_speed_PID,6000, 1000);//pid初始化
- speedSet = 0;
+ PID_init(&speed_pid,PID_POSITION,M2006_speed_PID,8000, 1000);//pid初始化
+ t_speedSet = 0;
result = 0;
//发射摩擦轮
@@ -46,80 +54,84 @@ Shoot::Shoot()
void Shoot::trigger_control()
{
- ///speedSet=speed;
- //result = PID_calc(&speed_pid, trigger_Motor->speed_rpm, speedSet);
- //result = Trigger_Torque;
+ // result = PID_calc(&speed_pid,trigger_Motor->speed_rpm,t_speedSet);
CAN_cmd_1FF(result,0,0,0,&hcan1);
-
-}
-
-void Shoot::shootThree()
-{
- if((rc_ctrl.sw[7]==1694))
- {
-
- speed_5065 = SHOOT_SPEED;
-
- }
- if((rc_ctrl.sw[7]==1000))
- {
- speed_5065=STOP;
- //发一次会堵塞另一个
-// CAN_VESC_HEAD(1);
-// CAN_VESC_HEAD(2);
- }
- if(rc_ctrl.sw[7]==306)
- {
- speed_5065=SHOOT_SPEED_BACK;
-
- }
- CAN_VESC_Control(1,speed_5065,&hcan2);
- // CAN_VESC_RPM(1, speed_5065);
- // CAN_VESC_RPM(2, speed_5065);
-
- // vofa[0] = motor_5065[1]->rotor_speed;
- // vofa[1] = motor_5065[0]->rotor_speed; // 发送电机速度数据
- // vofa_tx_main(vofa); // 发送数据到虚拟串口
-}
-
-void Shoot::shootBack()
-{
- speed_5065=SHOOT_SPEED_BACK;
- CAN_VESC_Control(1,speed_5065,&hcan2);
-
}
void Shoot::shootStop()
{
- speed_5065=STOP;
- CAN_VESC_Control(1,speed_5065,&hcan2);
-
+ speed_5065=STOP;
+ result=STOP;//扳机慢速归位
+
+
}
-void Shoot::shootStateMachine() {
+void Shoot::errorControl()
+{
+ result=Trigger_Slow;//扳机慢速归位
+ speed_5065=SHOOT_SPEED_BACK; //摩擦归位
+
+
+}
- distance =3.5;
+
+void Shoot :: distanceGet(const NUC_t &nuc_v)
+{
+
+ test_distance=nuc_v.vision.z;
+
+}
+
+void Shoot::vesc_send()
+{
+ CAN_VESC_Control(1, speed_5065, &hcan2);
+}
+
+void Shoot::vofaWatch()
+{
+ vofa[0] = motor_5065[1]->rotor_speed;
+ vofa[1] = motor_5065[0]->rotor_speed; // 发送电机速度数据
+ vofa[2] = speed_5065; // 发送电机速度数据
+ vofa[4] = trigger_Motor->speed_rpm; // 发送扳机电机速度数据
+ vofa_tx_main(vofa); // 发送数据到虚拟串口
+}
+
+
+void Shoot::shootStateMachine() {
+
+ xxx=polynomial(test_distance);
+ distance =test_distance;
switch (currentState) {
case SHOOT_IDLE: {
speed_5065=STOP;
- result=STOP;
+ t_speedSet=STOP;
// 空闲状态,等待遥控器输入
- if((rc_ctrl.sw[0]==1800)) {
- currentState = SHOOT_FIRE; // 切换到发射状态
+ if((rc_ctrl.sw[1]==200)) {
+ currentState = SHOOT_READY; // 切换到发射状态
}
break;
}
- case SHOOT_FIRE: {
- // 发射状态,控制电机发射
- // speed_5065 = test_speed;
- speed_5065 =distanceToSpeed(distance);
+ case SHOOT_READY:
+ {
+ // 发射状态,控制电机发射
+ speed_5065 = test_speed;
+ // speed_5065 =polynomial(distance);
if(motor_5065[0]->rotor_speed>=speed_5065-Error && motor_5065[0]->rotor_speed<=speed_5065+Error &&
motor_5065[1]->rotor_speed>=speed_5065-Error && motor_5065[1]->rotor_speed<=speed_5065+Error)
{
- result=Trigger_Torque;//恒力扳机
+ if((rc_ctrl.sw[3]==1800)) {
+ currentState = SHOOT_FIRE; // 切换到发射状态
+ }
+
}
+ break;
+ }
+
+ case SHOOT_FIRE: {
+
+ t_speedSet=triggerspeed;// 扳机速度影响?
// 检测光电传感器是否触发
if (IS_PHOTOELECTRIC_TRIGGERED()) {
currentState = SHOOT_BACK; // 切换到光电触发状态
@@ -127,11 +139,13 @@ void Shoot::shootStateMachine() {
break;
}
+
+
case SHOOT_BACK: {
// 光电触发状态,停止发射
- result=STOP;
+ t_speedSet=STOP;
speed_5065=STOP;
-
+
// 切换到返回状态
currentState = SHOOT_RETURN;
break;
@@ -140,12 +154,12 @@ void Shoot::shootStateMachine() {
case SHOOT_RETURN: {
// 自动返回状态,控制电机反转
speed_5065=SHOOT_SPEED_BACK;
- result=-Trigger_Torque;
+ t_speedSet=2000;
// 检测返回完成(可以通过时间或其他传感器判断)
- if (rc_ctrl.sw[0]==1000) { // 假设遥控器开关控制返回完成
+ if (rc_ctrl.sw[1]==1000) { // 假设遥控器开关控制返回完成
speed_5065=SHOOT_SPEED_BACK;
- result=STOP;
+ t_speedSet=STOP;
currentState = SHOOT_IDLE; // 切换回空闲状态
}
break;
@@ -157,21 +171,31 @@ void Shoot::shootStateMachine() {
break;
}
}
- CAN_VESC_Control(1,speed_5065,&hcan2);
-
- vofa[0] = motor_5065[1]->rotor_speed;
- vofa[1] = motor_5065[0]->rotor_speed; // 发送电机速度数据
- vofa[2] = speed_5065; // 发送电机速度数据
-
- vofa_tx_main(vofa); // 发送数据到虚拟串口
-
+ result = PID_calc(&speed_pid,trigger_Motor->speed_rpm,t_speedSet);
+ // CAN_VESC_Control(1,speed_5065,&hcan2);
+
}
-//拟合函数
-float distanceToSpeed(float x) {
- return -2.3958f * x * x * x * x
- + 59.615f * x * x * x
- - 525.63f * x * x
- + 2136.4f * x
- + 28001.0f;
+//MATLAB拟合函数
+float polynomial(float x) {
+ return 1185.3918f * powf(x, 5.0f)
+ + -45876.846f * powf(x, 4.0f)
+ + 517061.22f * powf(x, 3.0f)
+ + -2567947.4f * powf(x, 2.0f)
+ + 5954537.4f * x
+ + -5258769.0f;
}
+
+
+float polynomial2(float x) {
+ return 49162.7402f * powf(x, 5.0f)
+ + -917344.6015f * powf(x, 4.0f)
+ + 6840516.5228f * powf(x, 3.0f)
+ + -25479457.6038f * powf(x, 2.0f)
+ + 47406744.9129f * x
+ + -35217628.5565f;
+}
+
+// float polynomial(float x) {
+// return 1185.3918*pow(x,5) + -45876.846*pow(x,4) + 517061.22*pow(x,3) + -2567947.4*pow(x,2) + 5954537.4*x + -5258769;
+// }
diff --git a/User/module/shoot.hpp b/User/module/shoot.hpp
index a034ce1..24ff431 100644
--- a/User/module/shoot.hpp
+++ b/User/module/shoot.hpp
@@ -2,10 +2,12 @@
#define SHOOT_HPP
#include "djiMotor.h"
#include "pid.h"
+#include "nuc.h"
// 定义状态枚举
typedef enum {
SHOOT_IDLE, // 空闲状态
+ SHOOT_READY,
SHOOT_FIRE, // 发射状态
SHOOT_BACK, // 光电触发状态
SHOOT_RETURN // 自动返回状态
@@ -28,16 +30,19 @@ class Shoot
{
public:
Shoot();
- void shootThree(void);
void shootStop(void);
- void shootBack(void);
void shootStateMachine(void);
void trigger_control(void);
+ void errorControl(void);
+ void vofaWatch(void);
+ void vesc_send(void);
+ void distanceGet(const NUC_t &nuc);
float speed_5065;
float speed_trigger;
ShootState_t currentState;
int16_t result;
+ float t_speedSet;
//暂时放在公共,task里使用
CAN_MotorFeedback_t *motor_5065[2];
//==========================公共变量==========================
@@ -54,7 +59,7 @@ private:
//电机速度pid结构体
pid_type_def speed_pid;
motor_measure_t *trigger_Motor;
- float speedSet;
+
};
@@ -62,4 +67,8 @@ private:
float distanceToSpeed(float x);
+float polynomial(float x);
+
+float polynomial2(float x);
+
#endif
diff --git a/User/task/ballTask.cpp b/User/task/ballTask.cpp
index 5da663c..a51e0cc 100644
--- a/User/task/ballTask.cpp
+++ b/User/task/ballTask.cpp
@@ -10,10 +10,10 @@ extern RC_ctrl_t rc_ctrl;
Ball ball;
//float vofa[8];
-// 左旋钮 sw[2] 左1800 右200
-// 右旋钮 sw[3] 左1800 右200
-// C键 sw[4]👆 200 中1000 👇1800
-// D键 sw[5]👆 1800 👇200
+
+// C键 sw[5]👆 1800 中1000 👇200
+// D键 sw[6]👆 200 外伸 👇1800 归位 //三摩擦架子
+// H键 sw[7]👆 200 👇1800 //取球
int angle1=34;
int angle2=23;
@@ -26,7 +26,7 @@ int speed_set=0;
int speed_feedback=0;
extern int speedm;
-extern int speedm1;
+
void FunctionBall(void *argument)
{
@@ -44,42 +44,46 @@ void FunctionBall(void *argument)
abc=HAL_GPIO_ReadPin(up_ball_GPIO_Port, up_ball_Pin);
- if(rc_ctrl.sw[2]>=1200)
+ if(rc_ctrl.sw[6] == 200)
{
angle1=75;
}
- if(rc_ctrl.sw[2]<1200)
+ if(rc_ctrl.sw[6]==1800)
{
angle1=0;
}
+
//运球
- if(rc_ctrl.sw[3]>=1200)
- {
- a1=1;
- //👇
- ball.ballHadling(); // 处理摩擦轮转动
- }
+ if(rc_ctrl.sw[5]==200)
+ {
+ //👇
+ ball.ballHadling(); // 处理摩擦轮转动
+ }
//下球
- if(rc_ctrl.sw[4]==200)
+ if(rc_ctrl.sw[5]==1800)
+ {
+ //👆
+ ball.ballDown();
+ }
+ //中间
+ if(rc_ctrl.sw[7]==200)
+ {
+ if(rc_ctrl.sw[5]==1000)
{
- //👆
- ball.ballDown();
- }
- //回弹停止
- if(rc_ctrl.sw[3]<1000)
- {
- //👆
+ //中
ball.ballStop();
+ ball.ballHadling(); // 处理摩擦轮转动
}
- if(rc_ctrl.sw[7]==1800)
- {
- ball.ballTake();
+ }
- }
+ if(rc_ctrl.sw[7]==1800)
+ {
+ //ball.ballTake();
-
- CAN_XiaoMi(1,&ball.JZ_xiaomi,&hcan2);
+ }
+
+ // CAN_XiaoMi(1,&ball.JZ_xiaomi,&hcan2);
ball.Spin(speedm);
ball.Send_control();
diff --git a/User/task/shootTask.cpp b/User/task/shootTask.cpp
index 4802847..7e79eab 100644
--- a/User/task/shootTask.cpp
+++ b/User/task/shootTask.cpp
@@ -15,10 +15,8 @@ int shoot_flag = 0;
int a2;
-// sw[0]2 下306上1694 sw[5]3前306后1694 sw[4]4前1694后306 sw[1]xuan1 sw[3]xuan2
-
-//F键 sw[0]👆 1800 中 1000 👇200
-//E键 sw[1]👆 1800 👇200
+//E键 sw[0]👆 200 中 1000 👇1800
+//F键 sw[1]👆 1800 👇200
void FunctionShoot(void *argument)
{
@@ -40,35 +38,46 @@ while(1)
if(shoot.flag_thread & BALL_OK)
{
a2=2;
- // shoot.shootThree();
}
+
shoot_flag=HAL_GPIO_ReadPin(STOP_GPIO_Port, STOP_Pin);
if (osMessageQueueGet(task_struct.msgq.nuc, &nucData, NULL, 0) == osOK)
{
- // 使用接收到的视觉数据调整云台
- //gimbal.gimbalVision(nucData);
+ //shoot.distanceGet(nucData);
}
- if(rc_ctrl.sw[1]>1000)
+
+
+ if(rc_ctrl.sw[0]>1000)
{
- shoot.shootStateMachine();
- if(rc_ctrl.sw[0]==200)
+
+ if(rc_ctrl.sw[1]==1800)
{
- shoot.shootBack();
+ shoot.errorControl();
}
- if(rc_ctrl.sw[0]==1000)
+ if(rc_ctrl.sw[1]==1000)
{
shoot.shootStop();
+ shoot.shootStateMachine();//shoot
+ }
+ if(rc_ctrl.sw[1]==200)
+ {
+ shoot.shootStateMachine();//shoot
}
}
- if(rc_ctrl.sw[1]==200)
+ if(rc_ctrl.sw[0]==200)
{
shoot.shootStop();
}
- shoot.trigger_control();
+ shoot.vesc_send(); // 发送电机速度数据
+
+ shoot.trigger_control();
+
+ shoot.vofaWatch();
+
osDelay(2);
tick += delay_tick; /* 计算下一个唤醒时刻 */