活动介绍

51单片机,AT89C52RC,双电机(左电机AO1,AO2,右电机BO1,BO2)驱动四轮,HC-SR05(P2.1,P2.2),12V电源,OLED显示器(P0.1,P0.2),LED灯,电源启动停止开关,蜂鸣器(P2.0),SG90舵机(P0.0),TB6612左和TB6612右,自动超声波避障小车代码。 要求有小车行驶程序(前进,后退,停止,左转,右转),PWM控制小车运动速度程序,超声波测距模块程序,舵机旋转程序,LED显示器显示小车与障碍物的距离程序,蜂鸣器遇障警报,LED灯随警报亮起,蓝牙控制程序。

时间: 2025-08-21 20:24:18 浏览: 5
<think>好的,我现在需要帮助用户获取基于51单片机(AT89C52RC)的自动超声波避障小车的完整代码,包括所有提到的功能。首先,我得确认用户的需求是否明确。用户提到了小车行驶控制、PWM速度控制、超声波测距、舵机旋转、OLED显示距离、蜂鸣器警报、LED灯联动以及蓝牙控制功能。这些功能都需要整合到一个系统中,所以需要先考虑各个模块的硬件连接和软件实现。 首先,硬件部分,用户使用的是AT89C52RC单片机,双TB6612电机驱动模块驱动四轮小车。TB6612的控制需要PWM信号和方向控制引脚。接下来是HC-SR05超声波模块,这通常需要Trig和Echo引脚来触发测距和接收回波。SG90舵机用于旋转超声波模块,以检测不同方向的障碍物,舵机的控制需要PWM信号。OLED显示通常使用I2C或SPI接口,蜂鸣器和LED灯则通过GPIO控制,蓝牙模块可能是HC-05或类似的,使用串口通信。 接下来是软件部分。主程序需要循环执行各个功能模块,比如超声波测距、舵机转动、数据处理、电机控制、显示更新等。各个模块的代码需要分块编写,并确保时序正确,尤其是超声波模块的测距和舵机的PWM信号。PWM生成部分可能需要定时器中断来实现,因为51单片机的资源有限,定时器的配置需要仔细处理。 PWM速度控制方面,TB6612的PWM输入需要由单片机产生,占空比调节电机的转速。这里可能需要使用定时器来生成PWM波,同时需要设置对应的IO口方向来控制电机的正反转。超声波测距部分,需要发送触发信号,然后检测回波的高电平时间,计算距离。舵机的角度控制需要生成特定脉宽的PWM信号,SG90的PWM周期是20ms,脉宽在0.5ms到2.5ms之间对应0到180度。 OLED显示部分需要编写显示驱动,将距离数据转换为字符串显示在屏幕上。蜂鸣器和LED的联动可以在检测到障碍物时触发,比如当距离小于某个阈值时,蜂鸣器响,LED闪烁。蓝牙控制部分需要串口中断服务程序,接收来自手机或蓝牙模块的指令,解析后控制小车的运动方向或模式。 需要注意的是,51单片机的资源有限,比如定时器数量和RAM大小,需要合理分配资源。例如,使用定时器0来处理PWM生成,定时器1用于串口通信的波特率发生器,定时器2用于超声波测距的计时。中断优先级也需要配置正确,避免冲突。 代码结构方面,主循环中可能需要先处理超声波测距,然后根据距离判断是否需要避障,或者根据蓝牙指令执行相应的动作。舵机可能需要周期性地左右转动以扫描周围环境。每个功能模块的函数需要模块化,便于调试和维护。 可能遇到的问题包括PWM信号不稳定导致电机转速不均,超声波测距受到环境干扰,舵机转动时的机械延迟影响测距准确性,蓝牙通信的数据解析错误等。需要逐步调试每个模块,确保单独功能正常后再整合。 最后,用户可能需要代码的详细注释,方便理解和修改。此外,硬件连接图或引脚定义表也会对用户有帮助,但用户主要请求的是代码部分,所以需要确保代码中的引脚定义清晰,并给出必要的配置说明。</think>以下是基于51单片机AT89C52RC的超声波避障小车完整代码框架,包含您所述的全部功能模块。代码采用模块化设计,包含详细的注释说明。 ```c #include <reg52.h> #include <intrins.h> // 硬件引脚定义 // 电机驱动模块 sbit MOTOR_A_PWM = P1^0; // 右电机PWM sbit MOTOR_B_PWM = P1^1; // 左电机PWM sbit MOTOR_A_IN1 = P1^2; sbit MOTOR_A_IN2 = P1^3; sbit MOTOR_B_IN1 = P1^4; sbit MOTOR_B_IN2 = P1^5; // 超声波模块 sbit TRIG = P2^1; sbit ECHO = P2^2; // 舵机控制 sbit SERVO = P2^3; // SG90舵机信号线 // OLED显示 #define OLED_SCL P2^4 #define OLED_SDA P2^5 // 蜂鸣器与LED sbit BUZZER = P2^0; sbit LED_R = P2^6; sbit LED_G = P2^7; // 蓝牙模块 #define BLUETOOTH_RXD P3^0 #define BLUETOOTH_TXD P3^1 // 全局变量 unsigned int distance = 0; bit flag_obstacle = 0; // 定时器配置 void Timer_Init() { TMOD = 0x11; // 定时器0、1模式1 TH0 = 0xFC; // 1ms定时 TL0 = 0x66; ET0 = 1; TR0 = 1; EA = 1; } // PWM生成中断 void Timer0() interrupt 1 { static unsigned char pwm_count = 0; TH0 = 0xFC; TL0 = 0x66; pwm_count++; // 电机PWM控制(占空比50%) if(pwm_count >= 100) pwm_count = 0; MOTOR_A_PWM = (pwm_count < 50) ? 1 : 0; MOTOR_B_PWM = (pwm_count < 50) ? 1 : 0; } // 超声波测距 float Get_Distance() { unsigned int time; TRIG = 1; _nop_(); _nop_(); _nop_(); _nop_(); TRIG = 0; while(!ECHO); TH1 = TL1 = 0; TR1 = 1; while(ECHO); TR1 = 0; time = (TH1 << 8) | TL1; return time * 0.017; // 计算距离(cm) } // 舵机角度控制 void Servo_Angle(unsigned char angle) { unsigned int pulse = 500 + angle * 11.11; // 0.5ms-2.5ms SERVO = 1; DelayMs(pulse); SERVO = 0; DelayMs(20000 - pulse); } // 电机控制函数 void Motor_Control(unsigned char cmd) { switch(cmd) { case 'F': // 前进 MOTOR_A_IN1 = 1; MOTOR_A_IN2 = 0; MOTOR_B_IN1 = 1; MOTOR_B_IN2 = 0; break; case 'B': // 后退 MOTOR_A_IN1 = 0; MOTOR_A_IN2 = 1; MOTOR_B_IN1 = 0; MOTOR_B_IN2 = 1; break; case 'L': // 左转 MOTOR_A_IN1 = 1; MOTOR_A_IN2 = 0; MOTOR_B_IN1 = 0; MOTOR_B_IN2 = 1; break; case 'R': // 右转 MOTOR_A_IN1 = 0; MOTOR_A_IN2 = 1; MOTOR_B_IN1 = 1; MOTOR_B_IN2 = 0; break; case 'S': // 停止 MOTOR_A_IN1 = MOTOR_A_IN2 = 0; MOTOR_B_IN1 = MOTOR_B_IN2 = 0; break; } } // OLED显示函数 void OLED_Display(unsigned int dist) { // 实现OLED显示驱动代码 // 需要根据具体OLED型号实现 } // 蓝牙通信 void UART_Init() { SCON = 0x50; TMOD |= 0x20; TH1 = 0xFD; // 波特率9600 TL1 = 0xFD; TR1 = 1; } void UART_Receive() interrupt 4 { if(RI) { RI = 0; Motor_Control(SBUF); } } // 主程序 void main() { Timer_Init(); UART_Init(); while(1) { distance = Get_Distance(); OLED_Display(distance); // 避障逻辑 if(distance < 30) { flag_obstacle = 1; BUZZER = 1; LED_R = 0; LED_G = 1; Motor_Control('B'); DelayMs(500); Motor_Control('R'); DelayMs(300); } else { flag_obstacle = 0; BUZZER = 0; LED_R = 1; LED_G = 0; Motor_Control('F'); } // 舵机扫描 Servo_Angle(90); // 中位 DelayMs(1000); Servo_Angle(45); DelayMs(1000); Servo_Angle(135); DelayMs(1000); } } ```
阅读全文

相关推荐

EAGLE 9.6.2 #Encoding UTF-8 $SCHEMATIC Name "Cleaning_Robot_Path_Planning" Date "2025-07-07" Revision "1.1" Description "清洁机器人清扫路径规划系统完整原理图" $END_SCHEMATIC $LIBRARY Library "cleaning_robot_lib" # 主控模块STM32F103ZET6 $PACKAGE "STM32F103ZET6" (0 0) rectangle (120 100) 0.25 0 (10 10) smd 1.5 1.5 0.25 0 "VCC_3.3V" 1 (10 20) smd 1.5 1.5 0.25 0 "GND" 1 (30 10) smd 1.5 1.5 0.25 0 "PA0" 1 # 超声波传感器1 Trig (30 20) smd 1.5 1.5 0.25 0 "PA1" 1 # 超声波传感器1 Echo (30 30) smd 1.5 1.5 0.25 0 "PA2" 1 # 超声波传感器2 Trig (30 40) smd 1.5 1.5 0.25 0 "PA3" 1 # 超声波传感器2 Echo (40 10) smd 1.5 1.5 0.25 0 "PB0" 1 # 红外传感器1 (40 20) smd 1.5 1.5 0.25 0 "PB1" 1 # 红外传感器2 (40 30) smd 1.5 1.5 0.25 0 "PB2" 1 # 红外传感器3 (40 40) smd 1.5 1.5 0.25 0 "PB3" 1 # 红外传感器4 (50 10) smd 1.5 1.5 0.25 0 "SPI1_MOSI" 1 # NRF24L01 (50 20) smd 1.5 1.5 0.25 0 "SPI1_MISO" 1 (50 30) smd 1.5 1.5 0.25 0 "SPI1_SCK" 1 (50 40) smd 1.5 1.5 0.25 0 "SPI1_NSS" 1 (60 10) smd 1.5 1.5 0.25 0 "TIM1_CH1" 1 # 左电机PWM (60 20) smd 1.5 1.5 0.25 0 "TIM1_CH2" 1 # 右电机PWM (60 30) smd 1.5 1.5 0.25 0 "TIM2_CH1" 1 # 滚刷PWM (70 10) smd 1.5 1.5 0.25 0 "I2C1_SDA" 1 # MPU6050 (70 20) smd 1.5 1.5 0.25 0 "I2C1_SCL" 1 (70 30) smd 1.5 1.5 0.25 0 "USART1_TX" 1 # 调试串口 (70 40) smd 1.5 1.5 0.25 0 "USART1_RX" 1 $END_PACKAGE # 超声波传感器HC-SR04 $PACKAGE "HC_SR04" (0 0) rectangle (50 30) 0.25 0 (10 10) smd 1.5 1.5 0.25 0 "VCC" 1 (20 10) smd 1.5 1.5 0.25 0 "GND" 1 (30 10) smd 1.5 1.5 0.25 0 "Trig" 1 (40 10) smd 1.5 1.5 0.25 0 "Echo" 1 $END_PACKAGE # 红外传感器模块 $PACKAGE "IR_SENSOR" (0 0) rectangle (30 20) 0.25 0 (10 10) smd 1.5 1.5 0.25 0 "VCC" 1 (20 10) smd 1.5 1.5 0.25 0 "GND" 1 (15 5) smd 1.5 1.5 0.25 0 "OUT" 1 $END_PACKAGE # 双电机驱动模块TB6612FNG $PACKAGE "TB6612FNG" (0 0) rectangle (80 60) 0.25 0 (10 10) smd 1.5 1.5 0.25 0 "VM" 1 # 电机电源(12V) (10 20) smd 1.5 1.5 0.25 0 "VCC" 1 # 逻辑电源(3.3V) (10 30) smd 1.5 1.5 0.25 0 "GND" 1 (25 10) smd 1.5 1.5 0.25 0 "AIN1" 1 # 左电机方向1 (25 20) smd 1.5 1.5 0.25 0 "AIN2" 1 # 左电机方向2 (25 30) smd 1.5 1.5 0.25 0 "BIN1" 1 # 右电机方向1 (25 40) smd 1.5 1.5 0.25 0 "BIN2" 1 # 右电机方向2 (40 10) smd 1.5 1.5 0.25 0 "PWMA" 1 # 左电机PWM (40 20) smd 1.5 1.5 0.25 0 "PWMB" 1 # 右电机PWM (40 30) smd 1.5 1.5 0.25 0 "STBY" 1 # 待机控制 (60 10) smd 2 2 0.25 0 "AO1" 1 # 左电机输出1 (60 20) smd 2 2 0.25 0 "AO2" 1 # 左电机输出2 (60 30) smd 2 2 0.25 0 "BO1" 1 # 右电机输出1 (60 40) smd 2 2 0.25 0 "BO2" 1 # 右电机输出2 $END_PACKAGE # 滚刷电机驱动DRV8833 $PACKAGE "DRV8833" (0 0) rectangle (60 40) 0.25 0 (10 10) smd 1.5 1.5 0.25 0 "VM" 1 # 电机电源(12V) (10 20) smd 1.5 1.5 0.25 0 "VCC" 1 # 逻辑电源(3.3V) (10 30) smd 1.5 1.5 0.25 0 "GND" 1 (25 10) smd 1.5 1.5 0.25 0 "IN1" 1 # 滚刷方向1 (25 20) smd 1.5 1.5 0.25 0 "IN2" 1 # 滚刷方向2 (25 30) smd 1.5 1.5 0.25 0 "ENA" 1 # 滚刷PWM (45 10) smd 2 2 0.25 0 "OUT1" 1 # 滚刷输出1 (45 20) smd 2 2 0.25 0 "OUT2" 1 # 滚刷输出2 $END_PACKAGE # 惯性测量单元MPU6050 $PACKAGE "MPU6050" (0 0) rectangle (40 30) 0.25 0 (10 10) smd 1.5 1.5 0.25 0 "VCC" 1 (20 10) smd 1.5 1.5 0.25 0 "GND" 1 (10 15) smd 1.5 1.5 0.25 0 "SDA" 1 (20 15) smd 1.5 1.5 0.25 0 "SCL" 1 (10 20) smd 1.5 1.5 0.25 0 "INT" 1 # 中断输出 $END_PACKAGE # 无线通信模块NRF24L01 $PACKAGE "NRF24L01" (0 0) rectangle (50 30) 0.25 0 (10 10) smd 1.5 1.5 0.25 0 "VCC" 1 (20 10) smd 1.5 1.5 0.25 0 "GND" 1 (10 15) smd 1.5 1.5 0.25 0 "CE" 1 # 芯片使能 (20 15) smd 1.5 1.5 0.25 0 "CSN" 1 # SPI片选 (30 15) smd 1.5 1.5 0.25 0 "SCK" 1 # SPI时钟 (40 15) smd 1.5 1.5 0.25 0 "MOSI" 1 # SPI主出从入 (10 20) smd 1.5 1.5 0.25 0 "MISO" 1 # SPI主入从出 (20 20) smd 1.5 1.5 0.25 0 "IRQ" 1 # 中断输出 $END_PACKAGE # 电源管理模块 $PACKAGE "POWER_MANAGER" (0 0) rectangle (60 50) 0.25 0 (10 10) smd 2 2 0.25 0 "VBAT" 1 # 电池输入(18650锂电池组) (10 20) smd 1.5 1.5 0.25 0 "GND" 1 (10 30) smd 1.5 1.5 0.25 0 "5V_OUT" 1 # 5V输出 (10 40) smd 1.5 1.5 0.25 0 "3V3_OUT" 1 # 3.3V输出 (30 10) smd 1.5 1.5 0.25 0 "CHG" 1 # 充电指示 (30 20) smd 1.5 1.5 0.25 0 "PWR_EN" 1 # 电源使能 $END_PACKAGE # 电池保护电路 $PACKAGE "BATTERY_PROTECTION" (0 0) rectangle (40 30) 0.25 0 (10 10) smd 2 2 0.25 0 "BATT+" 1 # 电池正极 (10 20) smd 2 2 0.25 0 "BATT-" 1 # 电池负极 (30 10) smd 2 2 0.25 0 "OUT+" 1 # 输出正极 (30 20) smd 2 2 0.25 0 "OUT-" 1 # 输出负极 $END_PACKAGE $END_LIBRARY $DESIGN $NET "3V3" (STM32F103ZET6 VCC_3.3V) (MPU6050 VCC) (NRF24L01 VCC) (TB6612FNG VCC) (DRV8833 VCC) (POWER_MANAGER 3V3_OUT) $END_NET $NET "GND" (STM32F103ZET6 GND) (HC_SR04 GND) (IR_SENSOR GND) (TB6612FNG GND) (DRV8833 GND) (MPU6050 GND) (NRF24L01 GND) (POWER_MANAGER GND) (BATTERY_PROTECTION OUT-) $END_NET $NET "5V" (HC_SR04 VCC) (IR_SENSOR VCC) (POWER_MANAGER 5V_OUT) $END_NET $NET "VBAT" (BATTERY_PROTECTION BATT+) (POWER_MANAGER VBAT) $END_NET $NET "USART1_TX" (STM32F103ZET6 USART1_TX) $END_NET $NET "USART1_RX" (STM32F103ZET6 USART1_RX) $END_NET $NET "ULTRASONIC1_TRIG" (STM32F103ZET6 PA0) (HC_SR04 Trig) $END_NET $NET "ULTRASONIC1_ECHO" (STM32F103ZET6 PA1) (HC_SR04 Echo) $END_NET $NET "ULTRASONIC2_TRIG" (STM32F103ZET6 PA2) (HC_SR04 Trig) $END_NET $NET "ULTRASONIC2_ECHO" (STM32F103ZET6 PA3) (HC_SR04 Echo) $END_NET $NET "IR_SENSOR1" (STM32F103ZET6 PB0) (IR_SENSOR OUT) $END_NET $NET "IR_SENSOR2" (STM32F103ZET6 PB1) (IR_SENSOR OUT) $END_NET $NET "IR_SENSOR3" (STM32F103ZET6 PB2) (IR_SENSOR OUT) $END_NET $NET "IR_SENSOR4" (STM32F103ZET6 PB3) (IR_SENSOR OUT) $END_NET $NET "LEFT_MOTOR_PWM" (STM32F103ZET6 TIM1_CH1) (TB6612FNG PWMA) $END_NET $NET "RIGHT_MOTOR_PWM" (STM32F103ZET6 TIM1_CH2) (TB6612FNG PWMB) $END_NET $NET "LEFT_MOTOR_DIR1" (STM32F103ZET6 PA4) (TB6612FNG AIN1) $END_NET $NET "LEFT_MOTOR_DIR2" (STM32F103ZET6 PA5) (TB6612FNG AIN2) $END_NET $NET "RIGHT_MOTOR_DIR1" (STM32F103ZET6 PA6) (TB6612FNG BIN1) $END_NET $NET "RIGHT_MOTOR_DIR2" (STM32F103ZET6 PA7) (TB6612FNG BIN2) $END_NET $NET "BRUSH_MOTOR_PWM" (STM32F103ZET6 TIM2_CH1) (DRV8833 ENA) $END_NET $NET "BRUSH_MOTOR_DIR1" (STM32F103ZET6 PB4) (DRV8833 IN1) $END_NET $NET "BRUSH_MOTOR_DIR2" (STM32F103ZET6 PB5) (DRV8833 IN2) $END_NET $NET "I2C1_SDA" (STM32F103ZET6 I2C1_SDA) (MPU6050 SDA) $END_NET $NET "I2C1_SCL" (STM32F103ZET6 I2C1_SCL) (MPU6050 SCL) $END_NET $NET "NRF_CE" (STM32F103ZET6 PB6) (NRF24L01 CE) $END_NET $NET "NRF_CSN" (STM32F103ZET6 SPI1_NSS) (NRF24L01 CSN) $END_NET $NET "SPI1_SCK" (STM32F103ZET6 SPI1_SCK) (NRF24L01 SCK) $END_NET $NET "SPI1_MOSI" (STM32F103ZET6 SPI1_MOSI) (NRF24L01 MOSI) $END_NET $NET "SPI1_MISO" (STM32F103ZET6 SPI1_MISO) (NRF24L01 MISO) $END_NET $NET "MOTOR_POWER" (POWER_MANAGER VBAT) (TB6612FNG VM) (DRV8833 VM) $END_NET $NET "POWER_ENABLE" (STM32F103ZET6 PC13) (POWER_MANAGER PWR_EN) $END_NET $END_DESIGN $INSTANCE (STM32F103ZET6 "U1" (100 100) 0) (HC_SR04 "S1" (200 80) 0) # 前方超声波 (HC_SR04 "S2" (200 120) 0) # 侧方超声波 (IR_SENSOR "IR1" (250 70) 0) # 前左红外 (IR_SENSOR "IR2" (250 90) 0) # 前右红外 (IR_SENSOR "IR3" (250 110) 0) # 后左红外 (IR_SENSOR "IR4" (250 130) 0) # 后右红外 (TB6612FNG "U2" (300 100) 0) # 驱动电机控制 (DRV8833 "U3" (300 150) 0) # 滚刷电机控制 (MPU6050 "U4" (350 100) 0) # 姿态传感器 (NRF24L01 "U5" (350 150) 0) # 无线通信 (POWER_MANAGER "U6" (150 50) 0) # 电源管理 (BATTERY_PROTECTION "U7" (100 50) 0) # 电池保护 $END_INSTANCE

else if(!DL_GPIO_readPins(GPIOB,DL_GPIO_PIN_8)) { starrt=1; delay_ms(200); } else if(flag<20 && starrt>=1) { if(DL_GPIO_readPins(GPIOB,DL_GPIO_PIN_13)>0 && DL_GPIO_readPins(GPIOB,DL_GPIO_PIN_14)<=0 && DL_GPIO_readPins(GPIOB,DL_GPIO_PIN_15)<=0 && DL_GPIO_readPins(GPIOB,DL_GPIO_PIN_16)<=0 && DL_GPIO_readPins(GPIOA,DL_GPIO_PIN_12)<=0) { DL_GPIO_setPins(GPIOA,DL_GPIO_PIN_13);//AO1 DL_GPIO_clearPins(GPIOA,DL_GPIO_PIN_14);//AO2 DL_GPIO_setPins(GPIOA,DL_GPIO_PIN_15);//BO1 DL_GPIO_clearPins(GPIOA,DL_GPIO_PIN_16);//BO2 DL_TimerG_setCaptureCompareValue(TIMG8,500, DL_TIMER_CC_1_INDEX);//左 右一 DL_TimerG_setCaptureCompareValue(TIMA0,900,DL_TIMER_CC_1_INDEX);//右 } else if(DL_GPIO_readPins(GPIOB,DL_GPIO_PIN_13)<=0 && DL_GPIO_readPins(GPIOB,DL_GPIO_PIN_14)>0 && DL_GPIO_readPins(GPIOB,DL_GPIO_PIN_15)<=0 && DL_GPIO_readPins(GPIOB,DL_GPIO_PIN_16)<=0 && DL_GPIO_readPins(GPIOA,DL_GPIO_PIN_12)<=0) { DL_GPIO_setPins(GPIOA,DL_GPIO_PIN_13);//AO1 DL_GPIO_clearPins(GPIOA,DL_GPIO_PIN_14);//AO2 DL_GPIO_setPins(GPIOA,DL_GPIO_PIN_15);//BO1 DL_GPIO_clearPins(GPIOA,DL_GPIO_PIN_16);//BO2 DL_TimerG_setCaptureCompareValue(TIMG8,700,DL_TIMER_CC_1_INDEX);//左 右二 DL_TimerG_setCaptureCompareValue(TIMA0,900,DL_TIMER_CC_1_INDEX);//右 } else if(DL_GPIO_readPins(GPIOB,DL_GPIO_PIN_13)<=0 && DL_GPIO_readPins(GPIOB,DL_GPIO_PIN_14)<=0 && DL_GPIO_readPins(GPIOB,DL_GPIO_PIN_15)>0 && DL_GPIO_readPins(GPIOB,DL_GPIO_PIN_16)<=0 && DL_GPIO_readPins(GPIOA,DL_GPIO_PIN_12)<=0) { DL_GPIO_setPins(GPIOA,DL_GPIO_PIN_13);//AO1 DL_GPIO_clearPins(GPIOA,DL_GPIO_PIN_14);//AO2 DL_GPIO_setPins(GPIOA,DL_GPIO_PIN_15);//BO1 DL_GPIO_clearPins(GPIOA,DL_GPIO_PIN_16);//BO2 DL_TimerG_setCaptureCompareValue(TIMG8,800,DL_TIMER_CC_1_INDEX);//左 中 DL_TimerG_setCaptureCompareValue(TIMA0,800,DL_TIMER_CC_1_INDEX);//右 } else if(DL_GPIO_readPins(GPIOB,DL_GPIO_PIN_13)<=0 && DL_GPIO_readPins(GPIOB,DL_GPIO_PIN_14)<=0 && DL_GPIO_readPins(GPIOB,DL_GPIO_PIN_15)<=0 && DL_GPIO_readPins(GPIOB,DL_GPIO_PIN_16)>0 && DL_GPIO_readPins(GPIOA,DL_GPIO_PIN_12)<=0) { DL_GPIO_setPins(GPIOA,DL_GPIO_PIN_13);//AO1 DL_GPIO_clearPins(GPIOA,DL_GPIO_PIN_14);//AO2 DL_GPIO_setPins(GPIOA,DL_GPIO_PIN_15);//BO1 DL_GPIO_clearPins(GPIOA,DL_GPIO_PIN_16);//BO2 DL_TimerG_setCaptureCompareValue(TIMG8,900,DL_TIMER_CC_1_INDEX);//左 左二 DL_TimerG_setCaptureCompareValue(TIMA0,700,DL_TIMER_CC_1_INDEX);//右 } else if(DL_GPIO_readPins(GPIOB,DL_GPIO_PIN_13)<=0 && DL_GPIO_readPins(GPIOB,DL_GPIO_PIN_14)<=0 && DL_GPIO_readPins(GPIOB,DL_GPIO_PIN_15)<=0 && DL_GPIO_readPins(GPIOB,DL_GPIO_PIN_16)<=0 && DL_GPIO_readPins(GPIOA,DL_GPIO_PIN_12)>0) { DL_GPIO_setPins(GPIOA,DL_GPIO_PIN_13);//AO1 DL_GPIO_clearPins(GPIOA,DL_GPIO_PIN_14);//AO2 DL_GPIO_setPins(GPIOA,DL_GPIO_PIN_15);//BO1 DL_GPIO_clearPins(GPIOA,DL_GPIO_PIN_16);//BO2 DL_TimerG_setCaptureCompareValue(TIMG8,900,DL_TIMER_CC_1_INDEX);//左 左一 DL_TimerG_setCaptureCompareValue(TIMA0,500,DL_TIMER_CC_1_INDEX);//右 } else if(DL_GPIO_readPins(GPIOB,DL_GPIO_PIN_13)<=0 && DL_GPIO_readPins(GPIOB,DL_GPIO_PIN_14)<=0 && DL_GPIO_readPins(GPIOB,DL_GPIO_PIN_15)<=0 && DL_GPIO_readPins(GPIOB,DL_GPIO_PIN_16)>0 && DL_GPIO_readPins(GPIOA,DL_GPIO_PIN_12)>0) { DL_GPIO_setPins(GPIOA,DL_GPIO_PIN_13);//AO1 DL_GPIO_clearPins(GPIOA,DL_GPIO_PIN_14);//AO2 DL_GPIO_setPins(GPIOA,DL_GPIO_PIN_15);//BO1 DL_GPIO_clearPins(GPIOA,DL_GPIO_PIN_16);//BO2 DL_TimerG_setCaptureCompareValue(TIMG8,800,DL_TIMER_CC_1_INDEX); DL_TimerG_setCaptureCompareValue(TIMA0,800,DL_TIMER_CC_1_INDEX); delay_ms(250); DL_GPIO_setPins(GPIOA,DL_GPIO_PIN_14);//AO2倒转 DL_GPIO_clearPins(GPIOA,DL_GPIO_PIN_13);//AO1 DL_TimerG_setCaptureCompareValue(TIMG8,800,DL_TIMER_CC_1_INDEX);//左 左一加左二 DL_TimerG_setCaptureCompareValue(TIMA0,800,DL_TIMER_CC_1_INDEX);//右 delay_ms(600); DL_GPIO_setPins(GPIOA,DL_GPIO_PIN_13);//AO1回正 DL_GPIO_clearPins(GPIOA,DL_GPIO_PIN_14);//AO2 DL_TimerG_setCaptureCompareValue(TIMG8,800,DL_TIMER_CC_1_INDEX); DL_TimerG_setCaptureCompareValue(TIMA0,800,DL_TIMER_CC_1_INDEX); flag++; }不能右转的原因

最新推荐

recommend-type

chromedriver-mac-x64-141.0.7371.0(Canary).zip

chromedriver-mac-x64-141.0.7371.0(Canary).zip
recommend-type

python38-psycopg2-doc-2.8.4-4.module_el8.5.0+742+dbad1979.tar.gz

# 适用操作系统:Centos8 #Step1、解压 tar -zxvf xxx.el8.tar.gz #Step2、进入解压后的目录,执行安装 sudo rpm -ivh *.rpm
recommend-type

0081-E3-001330_035.TIF

0081-E3-001330_035.TIF
recommend-type

【情感分析】文本情感分析系统-自然语言处理.zip

【情感分析】文本情感分析系统-自然语言处理
recommend-type

企业网络结构设计与拓扑图的PKT文件解析

企业网络拓扑设计是网络架构设计的一个重要组成部分,它涉及到企业内部网络的布局结构,确保信息传递的高效和网络安全。网络拓扑设计需要详细规划网络中每个组件的位置、连接方式、设备类型等关键要素。在设计过程中,通常会使用网络拓扑图来形象地表示这些组件和它们之间的关系。 网络拓扑设计中重要的知识点包括: 1. 拓扑图的类型:网络拓扑图主要有以下几种类型,每一种都有其特定的应用场景和设计要求。 - 总线拓扑:所有设备都连接到一条共享的主干线上,信息在全网中广播。适合小型网络,维护成本低,但故障排查较为困难。 - 星型拓扑:所有设备通过点对点连接到一个中心节点。便于管理和监控,中心节点的故障可能导致整个网络瘫痪。 - 环形拓扑:每个节点通过专用链路形成一个闭合环路。信息单向流动,扩展性较差,对单点故障敏感。 - 网状拓扑:网络中的设备通过多条路径连接,提供极高的冗余性。适合大型网络,成本较高。 2. 网络设备的选择:网络设备包括路由器、交换机、防火墙、无线接入点等。设计时需根据实际需求选择适合的设备类型和配置。 3. IP地址规划:合理的IP地址分配能确保网络的有序运行,包括私有地址和公有地址的规划,子网划分,以及IP地址的动态分配(DHCP)和静态分配。 4. 网络安全设计:保护企业网络不受攻击至关重要。包括设置防火墙规则、配置入侵检测系统(IDS)、实施访问控制列表(ACL)等安全策略。 5. 网络冗余和负载均衡:为防止网络中的单点故障,设计时需要考虑使用冗余技术和负载均衡技术,例如多线路接入、链路聚合、VRRP(虚拟路由器冗余协议)等。 6. 物理布线规划:这是指网络中的物理连接方式和布线方案,通常根据实际建筑环境和网络设备位置来决定,包括线缆的种类和长度限制等。 7. 虚拟化和云计算:在现代企业网络设计中,虚拟化技术和云计算服务的集成也变得越来越重要,需要合理规划服务器资源和云服务接口。 从提供的文件描述来看,包含了详细的网络结构设计和拓扑图PKT文件,以及源代码。这说明该课设文件不仅包括了网络拓扑图的视觉展示,还涉及到了实际的网络配置和编程实现。PKT文件可能指的是Packet Tracer(网络模拟软件)生成的网络拓扑文件, Packet Tracer 是Cisco开发的网络模拟工具,用户可以通过它创建网络拓扑图并模拟网络设备之间的数据通信。 由于文件名仅标注为“课设”,我们无法得知具体的课程名称或者网络拓扑设计的具体案例。不过,可以推测这份文件可能是一个教学材料或课程设计项目,旨在帮助学生或者网络工程师通过实践来加深对网络拓扑设计的理解和应用。其中包含的源代码可能是用于配置网络设备(如路由器和交换机的命令脚本),或者是一些网络应用的编程实现,比如网络监控工具或者数据分析脚本等。
recommend-type

【技术解读】:5个步骤深入自定义你的Winform窗口

# 摘要 本文全面概述了Winform窗口自定义开发的关键方面,涵盖了从基础操作到高级功能开发以及性能调优的各个方面。文章首先介绍了Winform窗口的基本操作、设计元素及响应式设计实现方法。随后,深入探讨了自定义控件创建、多线程处理以及插件机制等高级功能开发技术。为了优化交互体验,文中还阐述了用户输入处理、动画效果集成以及高级用户界面交互技术。此外,文章详细讨论了窗口的国
recommend-type

ARM/x86/c86 的具体区别

<think>好的,用户之前问过国产化服务器和操作系统,现在又想知道ARM、x86、x86的具体区别。看起来用户可能是在做技术选型或者需要了解不同架构的优缺点,以便在实际项目中选择合适的硬件和系统。 首先,用户提到的c86可能是个笔误,应该是x86。需要确认这一点,避免误解。然后需要分别从架构、设计理念、应用场景、性能、生态等方面对比ARM和x86。另外,用户可能对国产芯片如鲲鹏、飞腾等基于ARM的处理器感兴趣,所以需要联系之前的回答,说明这些国产芯片的架构背景。 接下来,需要检查技术细节的准确性,比如指令集类型、功耗、扩展性、授权模式等。还要考虑用户可能的实际需求,比如是否需要低功耗设备
recommend-type

最新Swift语言iOS开发实战教程免费下载

标题《Intermediate_swift_ios_12_book》表明了本书是一本关于Swift语言以及iOS 12平台的中阶开发教程。在Swift语言方面,它侧重于深入探讨和实践,旨在帮助读者提升在iOS开发方面的技能水平。自从2014年苹果公司首次推出Swift语言以来,它就成为了开发iOS、macOS、watchOS和tvOS应用的首选语言。Swift语言以其安全、快速、现代的特性逐渐取代了Objective-C,成为苹果生态系统中的主流开发语言。iOS 12作为苹果公司推出的最新操作系统版本,它引入了许多新特性,比如ARKit 2、MeasureKit和新的Screen Time功能,因此开发者需要学习和适应这些变化以充分利用它们。 描述强调了这本书是由Appcoda出版的,Appcoda是一家专注于提供高质量iOS和Swift编程教程的在线平台。通过Appcoda出版的教程,读者通常能够获得紧跟行业标准和实践的教学材料。此书被推荐给希望学习使用最新的Swift语言进行iOS开发的人群。这暗示了该书涵盖了iOS 12的新特性和API,这些内容对于想要掌握最新开发技术的开发者来说至关重要。 标签"ios swift programming practice"则进一步明确了这本书的三个主要知识点:iOS开发、Swift编程和编程实践。这些标签指向了iOS开发的核心技能和知识领域。iOS开发涉及到使用Xcode作为主要的开发环境,掌握使用Interface Builder构建用户界面,以及理解如何使用UIKit框架来创建和管理用户界面。Swift编程则集中在语言本身,包括其基本语法、类型系统、面向协议编程、闭包、泛型等高级特性。编程实践则强调实际编写代码的能力,如编写可测试、可维护和高性能的代码,以及如何使用设计模式来解决常见的开发问题。 文件名称列表中的"Intermediate swift ios12 book.epub"指出了该教程的电子书格式。EPUB是一种广泛使用的电子书标准格式,它支持可调整的布局,使得内容在不同尺寸的屏幕上都可阅读。EPUB格式允许用户在各种阅读设备上阅读书籍,如平板电脑、智能手机、电子书阅读器等。而文件名"._Intermediate swift ios12 book.epub"前面的点和下划线可能表明这是一个隐藏文件或在某种特定环境下被创建的临时文件。 综上所述,知识点涉及: 1. Swift语言基础:Swift是一种安全、快速、现代的编程语言,由苹果公司开发,用于iOS、macOS、watchOS和tvOS应用的开发。Swift语言的特性包括语法简洁、类型安全、内存管理自动化、对闭包和泛型的支持等。 2. iOS 12平台特性:iOS 12作为当时较新的操作系统版本,提供了许多新API和功能,如ARKit 2、MeasureKit等。开发者需要掌握如何在应用中利用这些API实现增强现实(AR)、时间管理等高级功能。 3. Xcode和UIKit框架:Xcode是iOS开发的主要集成开发环境(IDE),它提供了代码编辑器、调试工具、性能分析工具以及用户界面构建器等工具。UIKit框架是构建iOS应用用户界面的基础框架,它提供了丰富的用户界面组件和控件。 4. Swift高级特性和编程实践:学习Swift的高级特性有助于编写高效和可维护的代码。这包括理解闭包的使用、泛型编程、面向协议的设计等。同时,学习和实践良好的编程习惯,如编写可测试的代码、应用设计模式、以及遵循苹果的编码规范和最佳实践。 5. Appcoda及其教程特点:Appcoda是一家提供高质量iOS和Swift编程教程的平台,其教学材料通常紧跟技术发展和行业标准,很适合用于自我学习和提升技能。
recommend-type

【核心攻略】:掌握Winform界面构建的10大黄金法则

# 摘要 Winform界面构建是开发桌面应用程序的重要组成部分,本文从界面布局、数据管理、性能优化、安全性以及进阶技术等多方面进行深入探讨。第一章提供了一个概览,接下来的章节分别详细阐述了如何设计高效的Winform布局,包括布局容器的选择与嵌套布局策略;如何通过数据绑定简化数据管理并保证数据的正确性;以及如何优化界面性能,提高渲染效率并
recommend-type

给我讲解一下boost升压电路

<think>嗯,用户想了解Boost升压电路的工作原理和应用场景。首先,我需要回忆一下Boost电路的基本结构。根据引用[1],Boost升压电路由控制IC、功率电感和MOSFET组成,非同步Boost架构可能更简单,适合用来解释原理。那它的工作原理是怎样的呢? 记得Boost电路属于开关电源,通过开关管的通断来控制电感储能和释放。当MOSFET导通时,电流流过电感,电感开始储能,此时二极管截止,电容负责维持输出电压。而当MOSFET关闭时,电感电流不能突变,会产生反向电动势,这时候电感的电压加上输入电压,通过二极管给电容充电,从而提升输出电压。这个过程需要控制IC来调节开关的占空比,以维