STM32蓝牙控制循迹避障小车——2.循迹模块

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"

//   1   2   3   4  :  B4  B5  B6  B7
void xunji_config(void)//引脚初始化
{
	GPIO_InitTypeDef GPIO_InitStruct;
	
	RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB,ENABLE);//使能GPIOB
	
	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);//初始化B4,B5,B6,B7
	
	
}

void Read_xunji_Date(void)//读取两个循迹模块的电平
{
	xunji_1;
	xunji_2;
	xunji_3;
	xunji_4;
	
}


xunji.h:

#ifndef __XUNJI_H
#define __XUNJI_H

#include "stm32f10x.h"

//定义B4,B5引脚读取循迹模块D0
#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"

//循迹模块从左到右为: 1   2   3   4  :  B4  B5  B6  B7

int main(void)
{
  delay_init();    //延时初始化		
	TIM3_PWM_Init();	//电机pwm   TIM3
	xunji_config();		//引脚初始化
	

	
	while(1)
	{
		Read_xunji_Date();//读取循迹值
		
		if(xunji_1==0&&xunji_2==0&&xunji_3==0&&xunji_4==0)//如果4个全部没有读取黑线,直走;   Forward();
		{
			Forward(500);
			delay_ms(5);
		}
		
		if(xunji_1==0&&xunji_2==1&&xunji_3==1&&xunji_4==0)//如果2,3读取黑线,直走;   Forward();
		{
			Forward(500);
			delay_ms(5);
		}
		
		if(xunji_1==0&&xunji_2==1&&xunji_3==0&&xunji_4==0)//如果2读取黑线,左转;   Turn_left();
		{
			Turn_left(500);
			delay_ms(5);
		}
		
		if(xunji_1==0&&xunji_2==0&&xunji_3==1&&xunji_4==0)//如果3读取黑线,右转;   Turn_right();
		{
			Turn_right(500);
			delay_ms(5);
		}
		
		if(xunji_1==1&&xunji_2==0&&xunji_3==0&&xunji_4==0)//如果1读取黑线,大左转;   Big_Turn_left();
		{
			Big_Turn_left(200);
			delay_ms(5);
		}
		
		if(xunji_1==0&&xunji_2==0&&xunji_3==0&&xunji_4==1)//如果4读取黑线,大右转;   Big_Turn_right();
		{
			Big_Turn_right(200);
			delay_ms(5);
		}
		
		
		
	}
	

	
}

工程项目:
STM32蓝牙控制循迹避障小车–测试2 循迹模块.zip

下一节我会写舵机和超声波

舵机和超声波测距模块STM32蓝牙控制循迹避障小车中常用的两个重要组件。 首先,舵机用于控制小车的转向。舵机通过PWM信号控制电机的转动角度,通过改变PWM信号的占空比,可以实现不同的转向角度。通常情况下,舵机的控制信号需要与STM32的定时器模块相连,通过调整定时器的周期和占空比,可以控制舵机的转向角度。在源代码中,通常会包括一些函数用于控制舵机的转向,如设置舵机转动角度等。 其次,超声波测距模块用于检测小车前方的障碍物距离。超声波测距模块通过发射超声波脉冲,然后检测超声波脉冲的回波时间,从而计算出前方障碍物的距离。在源代码中,通常会包括一些函数用于控制超声波测距模块的工作方式,如初始化超声波模块、发送超声波脉冲、接收回波信号等。 舵机和超声波测距模块是实现循迹避障功能的关键组件之一。在源代码中,我们需要同时处理舵机和超声波测距模块的数据,并根据测距结果调整舵机的转向角度。通过不断的测距和调整转向角度,小车可以根据前方障碍物的距离来做出合适的转向动作,从而实现循迹避障的功能。 在实际应用中,舵机和超声波测距模块的代码通常需要与其他组件的代码进行协调和集成,以实现整个小车控制逻辑。通过合理的编程和调试,我们可以使得小车根据测距结果和算法判断,实现自动避障循迹控制的功能。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值