我是靠谱客的博主 犹豫发箍,最近开发中收集的这篇文章主要介绍基于51单片机的红外避障小车前言一、任务书二、代码思路三、硬件四、部分代码五、联系我们喜欢请点赞哦!企鹅号,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

提示:记录2022年4月做的毕设

文章目录

  • 前言
  • 一、任务书
        • 1.1设计(研究)目标:
        • 1.2设计(研究)内容:
  • 二、代码思路
  • 三、硬件
  • 四、部分代码
  • 五、联系我们
  • 喜欢请点赞哦!企鹅号

前言

基于51单片机的红外避障小车,主控使用STC89C51。


一、任务书

1.1设计(研究)目标:

随着科技的进步,智能小车应用越来越广。智能小车可以替代人在如易燃易爆、有毒有害气体、阴暗潮湿等恶劣环境中工作,完成搬运和检测等工作。此外,智能小车在流分拣传送、餐厅送餐和无人工厂也有广泛的应用。设计智能避障小车包括微处理器技术、检测技术、电机控制技术等,综合性很强。
设计(研究)内容及具体要求:

1.2设计(研究)内容:

本系统可以实现小车的循迹、避障、跟随及蓝牙遥控的功能,主要是由单片机控制模块、电机驱动模块、红外避障模块、红外循迹模块、蓝牙模块以及电源模块组成。

  • 基于51单片机设计了一种自动循迹避障智能模型车系统
  • 通过红外传感器采集道路情况信息,并对检测的信息进行分析,自动控制车轮的转向,改变小车的行驶路径,避开障碍物,从而实现小车的稳定避障。
  • 小车基于自动引导机器人系统,实现小车循迹、避障、跟随及蓝牙遥控等功能。

二、代码思路

在这里插入图片描述

三、硬件

  • STC89C51
  • 蓝牙模块
  • 电池盒
  • 超声波模块
  • 避障模块(3引脚)
  • 小马达

四、部分代码

#define left_infrare  0
#define right_infrare 1
#define dj_state1        0X5F      //前进 
#define dj_state2        0X4F      //右转  
#define dj_state3        0X1F      //左转  
#define dj_state4        0X0F      //后退  
#define dj_state5        0XfF      //停车
#define light_off        0x0f      //关转向灯
#define left_light       0X5F      //左转向灯    两个是5f
#define right_light      0XaF      //右转向灯0xaf,两个是0xbf
#define back_light       0XcF      //刹车灯即后灯
#define front_light      0x3f      //前灯
#define light_on         0xff      //开所有灯
#define true  1
#define false 0
#define LCD_Data  P0
#define Busy  0x80            //用于检测LCD状态字中的Busy标识
sbit    c=P1^2;              //转向灯使能端
uchar code talk1[]={"backward"};
uchar code talk2[]={"forward"};
uchar code talk3[]={"Turnleft"};
uchar code talk4[]={"Turn right"};
uchar flage =0x00;
sbit  ledcs=P1^2;         //74H573的片选信号

void Delay5Ms(void)
{
 uint TempCyc = 5552;
 while(TempCyc--);
}
//400ms延时
void Delay400Ms(void)
{uchar TempCycA = 5;
 uint TempCycB;
 while(TempCycA--)
   { TempCycB=7269;
     while(TempCycB--);
    }
}
//LCD读状态
unsigned char ReadStatusLCD(void)
{
 LCD_Data = 0xFF;
 LCD_RS = 0;
 LCD_RW = 1;
 LCD_E = 0;
 LCD_E = 0;
 LCD_E = 1;
 while (LCD_Data & Busy);   //检测忙信号
 return(LCD_Data);
}
//LCD写数据
void WriteDataLCD(unsigned char WDLCD )
{
 ReadStatusLCD();  //检测忙
 LCD_Data = WDLCD;
 LCD_RS=1;
 LCD_RW =0;
 LCD_E = 0; //若晶振速度太高可以在这后加小的延时
 LCD_E = 0; //延时 ,为了安全
 LCD_E = 0; //延时
 LCD_E = 1;
}
//LCD写指令
void WriteCommandLCD(unsigned char WCLCD,BuysC)
{
 if (BuysC) ReadStatusLCD();   //根据需要检测忙,BuysC为0时忽略忙检测
 LCD_Data = WCLCD;
 LCD_RS= 0;
 LCD_RW= 0;
 LCD_E = 0;  //延时 ,为了安全
 LCD_E = 0;
 LCD_E = 0; //延时
 LCD_E = 1;
}
void LCDInit(void)         //LCD初始化
{
 Delay400Ms();
 LCD_Data = 0;
 WriteCommandLCD(0x38,0);  //三次显示模式设置,不检测忙信号
 Delay5Ms();
 WriteCommandLCD(0x38,0);
 Delay5Ms();
 WriteCommandLCD(0x38,0);
 Delay5Ms();

 WriteCommandLCD(0x38,1); //显示模式设置,开始要求每次检测忙信号
 WriteCommandLCD(0x08,1); //关闭显示
 WriteCommandLCD(0x01,1); //显示清屏
 WriteCommandLCD(0x06,1); // 显示光标移动设置
 WriteCommandLCD(0x0C,1); // 显示开及光标设置
}
//按指定位置显示一个字符
void DisplayOneChar(uchar X, uchar Y, uchar DData)
{
 Y &= 0x1;
 X &= 0xF;                 //限制X不能大于15,Y不能大于1
 if (Y)
 X |= 0x40;               //当要显示第二行时地址码+0x40;
 X |= 0x80;               // 算出LCD的指令码
 WriteCommandLCD(X, 0);   //这里不检测忙信号,发送地址码
 WriteDataLCD(DData);
}
//按指定位置显示一串字符(只能写一行);
void DisplayListChar(uchar X, uchar Y,uchar ListLength, uchar  *DData,uchar n)
{ uchar i;
 Y &= 0x01;
 X &= 0x0F;                 //限制X不能大于15,Y不能大于1
 for(i=0;i<ListLength;i++)
 { if (X <= 0x0F) //X坐标应小于0xF
    {   DisplayOneChar(X, Y, DData[i]); //显示单个字符
         if(n==true)Delay400Ms();
          X++;
    }
  }
}

void infrared_ray()interrupt 0  using 3
{  uchar i=90;
   flage=0x01;             //接受标志位
   while(i--);            //减小灵敏度
   EX0=0;               //关掉中断,等到发射方波后才开启,处于别动
}
// 延时子程序
void delay(uint n)
{
  while(--n);
}
//中断初始化
void Init0(void)
{  EA=1;
   IT0=1;
    }

void seng_wave(uchar timer,bit n)//timer通过载波发射信号的时间,n->左右发射管的选择
{  uchar i;
   P1 |= 0X04;      //ledcs=1为74ls573为11脚为高电平时数据直接输出,为低时把数据锁存住,即保持
   IE |= 0X01;
   P0 |=0x0c;   //04
   for(i=timer;i>0;i--)
     { if(n)P0^=0x08;                      // 右发射管通过载波发射信号//00
        else P0^=0x04;                    // 左发射管通过载波发射信号//0c
         delay(100);                     //这里控制着灵敏度(控制38khz的方波的多少)和距离
      }                                     //timer*delay(x)即为发射管得到的平均电流
    P1 &= 0Xfb;
    IE &= 0Xfe;
}

void light_control(uchar deng)
{   ledcs=1;
    P0 =deng;
    ledcs=0;  //11111011
}

void  control(uchar n,uchar dj_state,uchar light)
{   uchar i;
   // P1|=0x04;
     light_control(light);    //led转向指示灯
     delay(100);
     P2 =dj_state;              //电机的方向控制
    WriteCommandLCD(0x01,1); //LCD显示清屏

          switch(dj_state)
          { case dj_state2 :{ DisplayListChar(3,1,10,talk4,false);}break;
            case dj_state3: { DisplayListChar(3,1,8,talk3,false);}break;
            case dj_state4: { DisplayListChar(3,1,7,talk1,false); }break;
             default :break;
             }
          for(i=n;i>0;i--)
          {delay(2000);}
           P2=dj_state5;               //停车
         light_control(light_off);       //led关闭
        WriteCommandLCD(0x01,1); //LCD显示清屏
         P2=dj_state1;                     //前进
        if(dj_state1)
           { P1|=0X04;          //ledcs=1;
             P0=0x0f;
             P1&=0XFB;
             delay(100);
             DisplayListChar(0,0,7,talk2,false);
             }
     }

void move_car(void)
 {
   uchar temp =0x00;

       seng_wave(1,left_infrare);     //向下为中断开启有关闭后,要执行的语句
        if(flage==0x01){temp|=0x01;flage=0x00;}

         delay(30);
        seng_wave(1,right_infrare);    //向下为中断开启有关闭后,要执行的语句
        if(flage==0x01){temp|=0x02;flage=0x00;}

     if(temp==0x01){control(2,dj_state2,left_light); temp =0x00;}

      else if(temp==0x02) {control(2,dj_state3,right_light ); temp =0x00;}

        else if(temp==0x03) {control(10,dj_state4,back_light );
              control(5,dj_state2,right_light ); temp =0x00;}       

    }
void main(void)
{  Init0();       //中断初始化
   P1 |= 0X04;    //开锁存器的控制位
   P0 = 0xFf;     //数据口的清零
   P1&=0XFB;      //关锁存器的控制位
   LCDInit();     //LCD初始化
   WriteCommandLCD(0x01,1);   //显示清屏
   delay(100);
   P2=dj_state1;
   DisplayListChar(0,0,8,talk2,false);
 while(1)
   {    move_car();  //主要控制部分
        delay(200000);//延时
    }
 }

五、联系我们

承接stm32单片机、STC系列单片机设计、嵌入式。咨询liaxi“2424644692”(扣扣)

另外,我们在某宝有店铺噢~,店铺名:“晖亿科创”

喜欢请点赞哦!企鹅号

在这里插入图片描述

最后

以上就是犹豫发箍为你收集整理的基于51单片机的红外避障小车前言一、任务书二、代码思路三、硬件四、部分代码五、联系我们喜欢请点赞哦!企鹅号的全部内容,希望文章能够帮你解决基于51单片机的红外避障小车前言一、任务书二、代码思路三、硬件四、部分代码五、联系我们喜欢请点赞哦!企鹅号所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(53)

评论列表共有 0 条评论

立即
投稿
返回
顶部