找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 1892|回复: 0
打印 上一主题 下一主题
收起左侧

ZY08-C超声波避障 51单片机程序

[复制链接]
跳转到指定楼层
楼主
ID:823251 发表于 2020-9-25 18:53 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
  1. /*****************ZY08-C智能循迹、遥控、避障、寻光机器人*****************
  2. *  ZY08-C智能循迹、遥控、避障、寻光机器人 + Keil U4 + STC89C52
  3. *  ******************************************************************/
  4. #include <at89x51.h>        
  5. #include <intrins.h>

  6. #define  TX  P2_1
  7. #define  RX  P2_0

  8. #define Forward_L_DATA  180//当前进不能走直线的时候,请调节这两个参数,理想的时候是100,100,最大256,最小0。0的时候最慢,256的时候最快
  9. #define Forward_R_DATA  180        //例如小车前进的时候有点向左拐,说明右边马达转速过快,那可以取一个值大一点,另外一个值小一点,例如 200  190
  10.                             //直流电机因为制造上的误差,同一个脉宽下也不一定速度一致的,需要自己手动调节

  11. /*****按照原图接线定义******/
  12. sbit L293D_IN1=P0^0;
  13. sbit L293D_IN2=P0^1;
  14. sbit L293D_IN3=P0^2;
  15. sbit L293D_IN4=P0^3;

  16. sbit L293D_EN1=P0^4;
  17. sbit L293D_EN2=P0^5;

  18. sbit BUZZ=P1^5;


  19. void Delay400Ms(void);//延时400毫秒函数


  20. unsigned char disbuff[4]={0,0,0,0};//用于分别存放距离的值0.1mm、mm、cm和m的值

  21. void Count(void);//距离计算函数
  22.                           
  23. unsigned int  time=0;//用于存放定时器时间值
  24. unsigned long S=0;//用于存放距离的值
  25. bit  flag =0; //量程溢出标志位
  26. bit  turn_right_flag;


  27. //**********************************************************
  28. //函数名称:Delay1ms(unsigned int i)
  29. //函数功能:延时i*1ms的子程序(对应于22.1184Mhz晶振)   
  30. //形式参数:unsigned int i
  31. //行参说明:无
  32. //返回参数:无
  33. //使用说明:i为要延时的时间长度,单位是MS,最大可以延时65536 ms
  34. //**********************************************************
  35. void Delay1ms(unsigned int i)
  36. {
  37. unsigned char j,k;
  38. do{
  39.   j = 10;
  40.   do{
  41.    k = 50;
  42.    do{
  43.     _nop_();
  44.    }while(--k);     
  45.   }while(--j);
  46. }while(--i);

  47. }
  48. //**********************************************************
  49. //函数名称:Delay10us(unsigned char i)
  50. //函数功能:延时i*10us的子程序(对应于22.1184Mhz晶振)   
  51. //形式参数:无
  52. //行参说明:无
  53. //返回参数:无
  54. //使用说明:i为要延时的时间长度,单位是US,最大可以延时250 ms
  55. //**********************************************************
  56. void Delay10us(unsigned char i)
  57. {
  58.    unsigned char j;
  59. do{
  60.   j = 10;
  61.   do{
  62.    _nop_();
  63.    }while(--j);
  64. }while(--i);
  65. }  

  66. //=========================================================================================================================
  67. void Forward()//           前进
  68. {

  69.          L293D_IN1=1;
  70.          L293D_IN2=0;
  71.          L293D_IN3=1;
  72.          L293D_IN4=0;
  73. //     PWM_Set(255-Speed_Right,255-Speed_Left);
  74. }
  75. void Stop(void)        //刹车
  76. {

  77.      L293D_IN1=0;
  78.          L293D_IN2=0;
  79.          L293D_IN3=0;
  80.          L293D_IN4=0;
  81. //         PWM_Set(0,0);
  82. }
  83. void Turn_Retreat()         //后
  84. {
  85.     L293D_IN1=0;
  86.         L293D_IN2=1;
  87.         L293D_IN3=0;
  88.         L293D_IN4=1;
  89. //        PWM_Set(255-Speed_Right,255-Speed_Left);
  90. }

  91. void Turn_left()         //左
  92. {
  93.     L293D_IN1=0;
  94.         L293D_IN2=1;
  95.         L293D_IN3=1;
  96.         L293D_IN4=0;
  97. //        PWM_Set(255-Speed_Right,255-Speed_Left);
  98. }

  99. //=========================================================================================================================
  100. /********距离计算程序***************/
  101.     void Conut(void)
  102.         {
  103.          time=TH1*256+TL1;
  104.          TH1=0;
  105.          TL1=0;
  106.         
  107.          //此时time的时间单位决定于晶振的速度,外接晶振为11.0592MHZ时,
  108.                     //time的值为0.54us*time,单位为微秒
  109.                                 //那么1us声波能走多远的距离呢?1s=1000ms=1000000us
  110.                                 // 340/1000000=0.00034米
  111.                                 //0.00034米/1000=0.34毫米  也就是1us能走0.34毫米
  112.                                 //但是,我们现在计算的是从超声波发射到反射接收的双路程,
  113.                                 //所以我们将计算的结果除以2才是实际的路程

  114.         S=time*2;//先算出一共的时间是多少微秒。
  115.            S=S*0.17;//此时计算到的结果为毫米,并且是精确到毫米的后两位了,有两个小数点
  116.          if(S<=300)         //
  117.          {        
  118.             if(turn_right_flag!=1)
  119.                 {
  120.                     Stop();
  121.                     Delay1ms(5);//发现小车自动复位的时候,可以稍微延长一点这个延时,减少电机反向电压对电路板的冲击。
  122.                 }
  123.                 turn_right_flag=1;
  124.                
  125.                 P1_7=0;
  126.                 P2_0=0;
  127.                 P0_6=0;

  128.                 Delay1ms(10);
  129.                
  130.                 P1_7=1;
  131.                 P2_0=1;
  132.                 P0_6=1;

  133.            // Turn_Right(120,120);
  134.            
  135.            Delay1ms(5);         // 关键点  延时5MS  
  136.          //  Delay1ms(500);           //后退500MS
  137.            Turn_left();
  138.            Delay1ms(10);           //左转800MS

  139.          }
  140.          else
  141.          {
  142.             turn_right_flag=0;
  143.             //Forward(Forward_R_DATA,Forward_L_DATA);
  144.                 Forward();


  145.          }
  146.          //=======================================
  147.          if((S>=5000)||flag==1) //超出测量范围
  148.          {        
  149.           flag=0;
  150.       //DisplayListChar(0, 1, table1);
  151.          }
  152.          else
  153.          {
  154.       disbuff[0]=S%10;
  155.           disbuff[1]=S/10%10;
  156.           disbuff[2]=S/100%10;
  157.           disbuff[3]=S/1000;
  158.          }
  159.         }

  160. /********************************************************/
  161.      void zd0() interrupt 3                  //T0中断用来计数器溢出,超过测距范围
  162.   {
  163.     flag=1;                         //中断溢出标志
  164.         RX=0;
  165.   }

  166. /********超声波高电平脉冲宽度计算程序***************/
  167. void Timer_Count(void)
  168. {
  169.                  TR1=1;                            //开启计数
  170.              while(RX);                        //当RX为1计数并等待
  171.              TR1=0;                                //关闭计数
  172.          Conut();                        //计算

  173. }
  174. /********************************************************/
  175.    void  StartModule()                          //启动模块
  176.   {
  177.           TX=1;                                             //启动一次模块
  178.       Delay10us(2);
  179.           TX=0;
  180.   }
  181. /********************************************************/

  182. /*************主程序********************/
  183. void main(void)
  184. {
  185.     unsigned char i;
  186.         unsigned int a;
  187.         //cmg88();//关数码管
  188.         Delay1ms(400); //启动等待,等LCM讲入工作状态
  189. //        LCMInit(); //LCM初始化
  190.         Delay1ms(5);//延时片刻
  191.    TMOD=TMOD|0x10;//设T0为方式1,GATE=1;
  192.     EA=1;
  193.     TH1=0;
  194.     TL1=0;         
  195.     ET1=1;             //允许T0中断
  196.                                    //开启总中断
  197.         //===============================
  198.         //PWM_ini();
  199.         //===============================
  200.         turn_right_flag=0;
  201.         //=================================
  202. B:                for(i=0;i<50;i++) //判断K3是否按下
  203.                 {
  204.                    Delay1ms(1);        //1ms内判断50次,如果其中有一次被判断到K3没按下,便重新检测
  205.                    if(P3_2!=0 )//当K3按下时,启动小车
  206.                    goto B; //跳转到标号B,重新检测
  207.                 }
  208.         //蜂鸣器响一声
  209.         BUZZ=0;        //50次检测K3确认是按下之后,蜂鸣器发出“滴”声响,然后启动小车。
  210.         Delay1ms(50);
  211.         BUZZ=1;//响50ms后关闭蜂鸣器
  212.         //=======================================================================================================================                        
  213.          while(1)
  214.           {
  215.                 RX=1;
  216.             StartModule();
  217.         for(a=951;a>0;a--)
  218.             {
  219.                   
  220.                if(RX==1)
  221.                    {
  222.            Timer_Count();
  223.                    }
  224.              }
  225.            }
  226. }



  227.                
复制代码


分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖 顶 踩
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表