STM32蓝牙控制循迹避障小车源代码——2.循迹模块
注意-所需模块:
接线:四个循迹模块(从左到右分别为1,2,3,4) B4–第1个循迹模块的D0 B5–第2个循迹模块的D0 B6–第3个循迹模块的D0 B7–第4个循迹模块的D0
代码
所有的代码都是直接从工程里面复制的,实测是没有问题的。
参考文章: 基于STM32F103C8T6的循迹避障小车完整制作过程
我这里再简单总结一下:
-
四个IO口,VCC,GND,A0,D0. 用3个,即VCC,GND,D0(输出高低电平) 当模块检测到黑线的时候,D0输出高电平,正常情况下D0输出处低电平。 -
定义B4,B5,B6,B7引脚,分别接到4个循迹模块上的D0口。 -
四个循迹模块从左到右依次为: 1 2 3 4 如果4个全部没有读取黑线,直走; Forward(); 如果2,3读取黑线,直走; Forward(); 如果2读取黑线,左转; Turn_left(); 如果3读取黑线,右转; Turn_right(); 如果1读取黑线,大左转; Big_Turn_left(); 如果4读取黑线,大右转; Big_Turn_right();
xunji.c
#include "XUNJI.H"
void xunji_config(void)
{
GPIO_InitTypeDef GPIO_InitStruct;
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB,ENABLE);
GPIO_InitStruct.GPIO_Mode=GPIO_Mode_IPU;
GPIO_InitStruct.GPIO_Pin=GPIO_Pin_4|GPIO_Pin_5|GPIO_Pin_6|GPIO_Pin_7;
GPIO_InitStruct.GPIO_Speed=GPIO_Speed_50MHz;
GPIO_Init(GPIOB,&GPIO_InitStruct);
}
void Read_xunji_Date(void)
{
xunji_1;
xunji_2;
xunji_3;
xunji_4;
}
xunji.h:
#ifndef __XUNJI_H
#define __XUNJI_H
#include "stm32f10x.h"
#define xunji_1 GPIO_ReadInputDataBit(GPIOB,GPIO_Pin_4)
#define xunji_2 GPIO_ReadInputDataBit(GPIOB,GPIO_Pin_5)
#define xunji_3 GPIO_ReadInputDataBit(GPIOB,GPIO_Pin_6)
#define xunji_4 GPIO_ReadInputDataBit(GPIOB,GPIO_Pin_7)
void xunji_config(void);
void Read_xunji_Date(void);
#endif
测试
将上面两个代码写进工程里,在主函数里写进以下代码。
main.c
#include "stm32f10x.h"
#include "moter.h"
#include "delay.h"
#include "xunji.h"
#include "usart.h"
int main(void)
{
delay_init();
TIM3_PWM_Init();
xunji_config();
while(1)
{
Read_xunji_Date();
if(xunji_1==0&&xunji_2==0&&xunji_3==0&&xunji_4==0)
{
Forward(500);
delay_ms(5);
}
if(xunji_1==0&&xunji_2==1&&xunji_3==1&&xunji_4==0)
{
Forward(500);
delay_ms(5);
}
if(xunji_1==0&&xunji_2==1&&xunji_3==0&&xunji_4==0)
{
Turn_left(500);
delay_ms(5);
}
if(xunji_1==0&&xunji_2==0&&xunji_3==1&&xunji_4==0)
{
Turn_right(500);
delay_ms(5);
}
if(xunji_1==1&&xunji_2==0&&xunji_3==0&&xunji_4==0)
{
Big_Turn_left(200);
delay_ms(5);
}
if(xunji_1==0&&xunji_2==0&&xunji_3==0&&xunji_4==1)
{
Big_Turn_right(200);
delay_ms(5);
}
}
}
工程项目: STM32蓝牙控制循迹避障小车–测试2 循迹模块.zip
下一节我会写舵机和超声波
|