单片机交流
登录
直播中
唯爱萌meng
10年用户
1038经验值
擅长:可编程逻辑
私信
关注
[问答]
如何使用STC89C53单片机实现带全向轮的两轮驱动避障小车的设计?
开启该帖子的消息推送
超声波
如何利用超声波实现小车的避障功能?
如何利用红外传感器实现避障功能?
如何利用红外传感器实现循线功能?
回帖
(1)
陆苏倌
2021-10-12 15:16:36
实验简介
使用STC89C53单片机作为主控制器芯片实现了带全向轮的两轮驱动避障以及循线小车,感知模块为超声波和红外传感器。本实验分为3个独立的部分:
1、利用超声波实现小车的避障功能;
2、利用红外传感器实现避障功能;
3、利用红外传感器实现循线功能。
元器件介绍
如下是一款常见的超声波模块HC-SR04的外观图,HC-SR04超声波测距模块可提供2cm-400cm的非接触式距离感测功能,测距精度可达高到3mm;模块包括超声波发射器、接收器与控制威廉希尔官方网站 。使用51单片机采集HC-SR04数据时就要用到AD转换器,这部分的知识请参见前几个章节。
下图是一个四路的红外循迹模块,其原理是利用红外传感器感知车轮下是否有目标线(黑色),然后将这个数据交给单片机处理后控制相应的电机,红外模块的读取只需要用到单片机的输入IO。
下图是一个电机驱动模块,使用的芯片是L293D,通过对信号线(M1A、M1B)的控制进而驱动电机。这里之所以要使用到电机驱动模块,是因为单片机的电压输出是5v并且其电流输出也很微弱,而电机是一个较大功率的用电器,因此就要使用一个驱动模块单片机只需要输出逻辑控制信号便可以控制电机的转动。
威廉希尔官方网站 结构图
代码
1、超声波避障
#include
#include
#include
#define TX P2_1
#define RX P2_0
//速度调节 0~256
#define Forward_L_DATA 180
#define Forward_R_DATA 180
***it IN1=P1^2;
***it IN2=P1^3;
***it IN3=P1^6;
***it IN4=P1^7;
***it EN1=P1^4;
***it EN2=P1^5;
***it K=P2^7;
unsigned char code Range[]="==Range Finder==";
unsigned char code ASCII[13]="0123456789.-M";
unsigned char code table[]="Distance:000.0cm";
unsigned char code table1[]="!!! Outof range";
unsigned char di***uff[4]={0,0,0,0};
unsigned int time=0;
unsigned long S=0;//存放距离值
bit flag=0;
bit turn_right_flag;
void Delay1ms(unsigned int i)
{
unsigned int x,y;
for(x=0;x
{
for(y=0;y<250;y++)
{
_nop_();
_nop_();
_nop_();
_nop_();
}
}
}
void Forward(unsigned char Speed_Right,unsigned char Speed_Left)//前进
{
IN1=0;
IN2=1;
IN3=1;
IN4=0;
}
void Stop(void)//刹车
{
IN1=0;
IN2=0;
IN3=0;
IN4=0;
}
void Turn_Right(unsigned char Speed_Right,unsigned char Speed_Left)//后
{
IN1=1;
IN2=0;
IN3=0;
IN4=0;
}
void Conut(void)
{
time=TH1*256+TL1;
TH1=0;
TL1=0;
S=time*2;
S=S*0.17;//单位毫米
if(S<=300)
{
if(turn_right_flag!=1)
{
Stop();
Delay1ms(5);
}
turn_right_flag=1;
P2_3=0;
Delay1ms(50);
P2_3=1;
Turn_Right(120,120);
}
else
{
turn_right_flag=0;
Forward(Forward_R_DATA,Forward_L_DATA);
}
if((S>=5000)||flag==1)
{
flag=0;
DisplayListChar(0,1,table);
}
else
{
di***uff[0]=S%10;
di***uff[1]=S/10%10;
di***uff[2]=S/100%10;
di***uff[3]=S/1000;
DisplayOneChar(9,1,ASCII[di***uff[3]]);
DisplayOneChar(10,1,ASCII[di***uff[2]]);
DisplayOneChar(11,1,ASCII[di***uff[1]]);
DisplayOneChar(12,1,ASCII[di***uff[10]]);
DisplayOneChar(13,1,ASCII[di***uff[0]]);
}
}
void zd0() interrupt 3
{
flag=0;
RX=0;
}
//计算脉冲宽度
void Timer_Count(void)
{
TR1=1;
while(RX);
TR1=0;
Count();
}
void StarModule()
{
TX=1;
Delay1ms(1);
TX=0;
}
void main(void)
{
unsigned char i;
unsigned int a;
Delay1ms(400);
LCMInit();
Delay1ms(5);
DisplayListChar(0,0,Range);
DisplayListChar(0,1,table);
TMOD=0x10;
EA=1;
TH1=0;
TL1=0;
ET1=1;
turn_right_flag=0;
while(1)
{
if(K==0)
{
RX=1;
StartModule();
for(a=951;a>0;a--)
{
if(RX==1)
{
Timer_Count();
}
}
}
}
}
红外避障
#include
#include
#include
#define uchar unsigned char
#define uint unsigned int
***it K=P2^7;
uint i;
void init()
{
TMOD=0x01;
TH0=0xfc;
TL0=0x16;
TR0=1;
ET0=1;
EA=1;
}
void delay_nms(uint i)
{
uint x,y;
for(x=0;x
{
for(y=0;y<250;y++)
{
_nop_();
_nop_();
_nop_();
_nop_();
}
}
}
void main()
{
B: for(i=0;i<50;i++)
{
delay_nms(1);
if(P2_7!=0)
goto B;
}
init();
while(1)
{
if(Left_1_led==1&&Right_1_led==1)
{
run();
}
if(Right_1_led==0&&Left_1_led==0)
{
rearrun();
delay_nms(500);
leftrun();
delay_nms(200);
}
if(Right_1_led==0&&Left_1_led==1)
{
rightrun();
}
if(Right_1_led==1&&Left_1_led==0)
{
leftrun();
}
}
}
红外循迹
#include
#include
#define uchar unsigned char
#define uint unsigned int
uint i,count;
***it K4=P2^7;
void init();
void main()
{
init();
while(1) //无限循环
{
if(K4==0)
{
//有信号为0 没有信号为1
if(Left_1_led==0&&Right_1_led==0)
{
run(); //调用前进函数
}
if(Left_1_led==0&&Right_1_led==1) //左边检测到黑线
{
rightrun(); //调用小车右转 函数
}
if(Right_1_led==0&&Left_1_led==1) //右边检测到黑线
{
leftrun(); //调用小车左转 函数
}
}
}
}
void init()
{
TMOD=0x11;
TH0=0xfc;
TL0=0x18;
TR0=1;
ET0=1;
EA=1;
}
实验简介
使用STC89C53单片机作为主控制器芯片实现了带全向轮的两轮驱动避障以及循线小车,感知模块为超声波和红外传感器。本实验分为3个独立的部分:
1、利用超声波实现小车的避障功能;
2、利用红外传感器实现避障功能;
3、利用红外传感器实现循线功能。
元器件介绍
如下是一款常见的超声波模块HC-SR04的外观图,HC-SR04超声波测距模块可提供2cm-400cm的非接触式距离感测功能,测距精度可达高到3mm;模块包括超声波发射器、接收器与控制威廉希尔官方网站 。使用51单片机采集HC-SR04数据时就要用到AD转换器,这部分的知识请参见前几个章节。
下图是一个四路的红外循迹模块,其原理是利用红外传感器感知车轮下是否有目标线(黑色),然后将这个数据交给单片机处理后控制相应的电机,红外模块的读取只需要用到单片机的输入IO。
下图是一个电机驱动模块,使用的芯片是L293D,通过对信号线(M1A、M1B)的控制进而驱动电机。这里之所以要使用到电机驱动模块,是因为单片机的电压输出是5v并且其电流输出也很微弱,而电机是一个较大功率的用电器,因此就要使用一个驱动模块单片机只需要输出逻辑控制信号便可以控制电机的转动。
威廉希尔官方网站 结构图
代码
1、超声波避障
#include
#include
#include
#define TX P2_1
#define RX P2_0
//速度调节 0~256
#define Forward_L_DATA 180
#define Forward_R_DATA 180
***it IN1=P1^2;
***it IN2=P1^3;
***it IN3=P1^6;
***it IN4=P1^7;
***it EN1=P1^4;
***it EN2=P1^5;
***it K=P2^7;
unsigned char code Range[]="==Range Finder==";
unsigned char code ASCII[13]="0123456789.-M";
unsigned char code table[]="Distance:000.0cm";
unsigned char code table1[]="!!! Outof range";
unsigned char di***uff[4]={0,0,0,0};
unsigned int time=0;
unsigned long S=0;//存放距离值
bit flag=0;
bit turn_right_flag;
void Delay1ms(unsigned int i)
{
unsigned int x,y;
for(x=0;x
{
for(y=0;y<250;y++)
{
_nop_();
_nop_();
_nop_();
_nop_();
}
}
}
void Forward(unsigned char Speed_Right,unsigned char Speed_Left)//前进
{
IN1=0;
IN2=1;
IN3=1;
IN4=0;
}
void Stop(void)//刹车
{
IN1=0;
IN2=0;
IN3=0;
IN4=0;
}
void Turn_Right(unsigned char Speed_Right,unsigned char Speed_Left)//后
{
IN1=1;
IN2=0;
IN3=0;
IN4=0;
}
void Conut(void)
{
time=TH1*256+TL1;
TH1=0;
TL1=0;
S=time*2;
S=S*0.17;//单位毫米
if(S<=300)
{
if(turn_right_flag!=1)
{
Stop();
Delay1ms(5);
}
turn_right_flag=1;
P2_3=0;
Delay1ms(50);
P2_3=1;
Turn_Right(120,120);
}
else
{
turn_right_flag=0;
Forward(Forward_R_DATA,Forward_L_DATA);
}
if((S>=5000)||flag==1)
{
flag=0;
DisplayListChar(0,1,table);
}
else
{
di***uff[0]=S%10;
di***uff[1]=S/10%10;
di***uff[2]=S/100%10;
di***uff[3]=S/1000;
DisplayOneChar(9,1,ASCII[di***uff[3]]);
DisplayOneChar(10,1,ASCII[di***uff[2]]);
DisplayOneChar(11,1,ASCII[di***uff[1]]);
DisplayOneChar(12,1,ASCII[di***uff[10]]);
DisplayOneChar(13,1,ASCII[di***uff[0]]);
}
}
void zd0() interrupt 3
{
flag=0;
RX=0;
}
//计算脉冲宽度
void Timer_Count(void)
{
TR1=1;
while(RX);
TR1=0;
Count();
}
void StarModule()
{
TX=1;
Delay1ms(1);
TX=0;
}
void main(void)
{
unsigned char i;
unsigned int a;
Delay1ms(400);
LCMInit();
Delay1ms(5);
DisplayListChar(0,0,Range);
DisplayListChar(0,1,table);
TMOD=0x10;
EA=1;
TH1=0;
TL1=0;
ET1=1;
turn_right_flag=0;
while(1)
{
if(K==0)
{
RX=1;
StartModule();
for(a=951;a>0;a--)
{
if(RX==1)
{
Timer_Count();
}
}
}
}
}
红外避障
#include
#include
#include
#define uchar unsigned char
#define uint unsigned int
***it K=P2^7;
uint i;
void init()
{
TMOD=0x01;
TH0=0xfc;
TL0=0x16;
TR0=1;
ET0=1;
EA=1;
}
void delay_nms(uint i)
{
uint x,y;
for(x=0;x
{
for(y=0;y<250;y++)
{
_nop_();
_nop_();
_nop_();
_nop_();
}
}
}
void main()
{
B: for(i=0;i<50;i++)
{
delay_nms(1);
if(P2_7!=0)
goto B;
}
init();
while(1)
{
if(Left_1_led==1&&Right_1_led==1)
{
run();
}
if(Right_1_led==0&&Left_1_led==0)
{
rearrun();
delay_nms(500);
leftrun();
delay_nms(200);
}
if(Right_1_led==0&&Left_1_led==1)
{
rightrun();
}
if(Right_1_led==1&&Left_1_led==0)
{
leftrun();
}
}
}
红外循迹
#include
#include
#define uchar unsigned char
#define uint unsigned int
uint i,count;
***it K4=P2^7;
void init();
void main()
{
init();
while(1) //无限循环
{
if(K4==0)
{
//有信号为0 没有信号为1
if(Left_1_led==0&&Right_1_led==0)
{
run(); //调用前进函数
}
if(Left_1_led==0&&Right_1_led==1) //左边检测到黑线
{
rightrun(); //调用小车右转 函数
}
if(Right_1_led==0&&Left_1_led==1) //右边检测到黑线
{
leftrun(); //调用小车左转 函数
}
}
}
}
void init()
{
TMOD=0x11;
TH0=0xfc;
TL0=0x18;
TR0=1;
ET0=1;
EA=1;
}
举报
更多回帖
rotate(-90deg);
回复
相关问答
超声波
两轮
平衡
小车
是用51
单片机
好还是stm32好?
2023-10-08
617
如何利用
STC89C
52
单片机
实现
智能
小车
的自动循迹
避
障
功能?
2021-09-23
2434
如何利用51
单片机
实现
智能
小车
的
避
障
功能?
2021-09-28
1619
如何利用
STC89c
52rc
单片机
实现
红外循迹
小车
的设计?
2021-10-20
1760
如何去
实现
一种基于
单片机
的
避
障
小车
及自动循迹的设计?
2021-07-19
1705
如何去制作一种基于stm32的
两轮
平衡
小车
?求过程
2021-07-09
1947
如何利用STM32去
实现
一种
两轮
自平衡车呢
2021-12-20
2120
请问有主控芯片是STM32F103
C
8T6的
两轮
平衡
小车
资料吗
2019-02-24
3230
谁有
STC89C
52
单片机
小车
程序
2013-11-15
3096
怎么用HC-SR04超声波测距
实现
小车
避
障
2015-04-23
6797
发帖
登录/注册
20万+
工程师都在用,
免费
PCB检查工具
无需安装、支持浏览器和手机在线查看、实时共享
查看
点击登录
登录更多精彩功能!
英国威廉希尔公司网站
william hill官网 版块
小组
免费开发板试用
ebook
直播
搜索
登录
×
20
完善资料,
赚取积分