找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 1400|回复: 1
收起左侧

单片机超声波循迹小车源代码(PWM版)程序错误 求帮助

[复制链接]
ID:508291 发表于 2019-7-29 15:02 | 显示全部楼层 |阅读模式
Trig -------  P2^1;
Echo -------  P2^0;
VCC  -------- +5v
GND  -------- GND

请在上电之前,检查好接线是否正确。

单片机源程序如下:

  1. #include <reg51.h>
  2. #include <intrins.h>        
  3. #include "lcd.h"

  4. sbit Trig = P2^1;
  5. sbit Echo = P2^0;

  6. sbit IN1 = P1^0;                             
  7. sbit IN2 = P1^1;                           

  8. sbit IN3 = P1^3;                  
  9. sbit IN4 = P1^4;                           

  10. sbit EN1 = P1^2;                  
  11. sbit EN2 = P1^5;

  12. unsigned char PuZh[]=" Pechin Science ";
  13. unsigned char code ASCII[15] =    {'0','1','2','3','4','5','6','7','8','9','.','-','M'};

  14. static unsigned char DisNum = 0; //显示用指针                                 
  15.        unsigned int  time=0;
  16.            unsigned long S=0;
  17.            bit      flag =0;
  18.            unsigned char disbuff[4]           ={ 0,0,0,0,};
  19. /*******************************************************************************
  20. * 函 数 名         : main
  21. * 函数功能                   : 主函数
  22. * 输    入         : 无
  23. * 输    出         : 无
  24. *******************************************************************************/


  25. void delay(int In,int Out)                          
  26. {
  27. int i,j;
  28. for(i=0;i<In;i++)
  29. {
  30.   for(j=0;j<Out;j++)
  31.   {;}
  32. }
  33. }

  34. void forward(void)                                                 //前进
  35. {
  36.   EN1 = 1;
  37.         EN2 = 1;
  38.   IN1 = 1;
  39.   IN2 = 0;                                      //左车轮的正转                 

  40.   IN3 = 1;
  41.   IN4 = 0;
  42. }                                              //右车轮的正转         

  43. void backward(void)                                                 //前进
  44. {
  45.         EN1 = 1;
  46.         EN2 = 1;
  47.   IN1 = 0;
  48.   IN2 = 1;         //左车轮的正转                 

  49.   IN3 = 0;
  50.   IN4 = 1;
  51. }                                              //右车轮的正转         

  52. void stop(void)                                            //停车
  53. {
  54.           EN1 = 1;
  55.         EN2 = 1;
  56. IN1 = 0;
  57. IN2 = 0;                                       //左电机不动           

  58. IN3 = 0;
  59. IN4 = 0;                                       

  60. }

  61. void right(void)                                        //向右           
  62. {
  63.   EN1 = 1;
  64.         EN2 = 1;
  65.   IN1 = 1;
  66.   IN2 = 0;                                     //智能小车左车轮正转           
  67.         
  68.   IN3 = 0;
  69.   IN4 = 1;                                     //智能小车右车轮反转        
  70. }   
  71.                  void Conut(void)
  72.         {
  73.          time=TH0*256+TL0;
  74.          TH0=0;
  75.          TL0=0;
  76.         
  77.          S=(time*1.7)/100;     //算出来是CM
  78.          if((S>=700)||flag==1) //超出测量范围显示“-”
  79.          {         
  80.           flag=0;
  81.          
  82.           DisplayOneChar(0, 1, ASCII[11]);
  83.           DisplayOneChar(1, 1, ASCII[10]);        //显示点
  84.           DisplayOneChar(2, 1, ASCII[11]);
  85.           DisplayOneChar(3, 1, ASCII[11]);
  86.           DisplayOneChar(4, 1, ASCII[12]);        //显示M
  87.          }
  88.          else
  89.          {
  90.           disbuff[0]=S%1000/100;
  91.           disbuff[1]=S%1000%100/10;
  92.           disbuff[2]=S%1000%10 %10;
  93.           DisplayOneChar(0, 1, ASCII[disbuff[0]]);
  94.           DisplayOneChar(1, 1, ASCII[10]);        //显示点
  95.           DisplayOneChar(2, 1, ASCII[disbuff[1]]);
  96.           DisplayOneChar(3, 1, ASCII[disbuff[2]]);
  97.           DisplayOneChar(4, 1, ASCII[12]);        //显示M
  98.          }
  99. }
  100.         void gogogo()
  101.         {
  102.                           if(S>35&&S<1000)
  103.                                 {
  104.                 backward();
  105.                                                                 delay(200,200);
  106.                 stop();
  107.                                 }
  108.         
  109.      else if(S<35&&S>=15)
  110.         {
  111.            right();
  112.                                         delay(200,200);         
  113.                                         stop();
  114.         }
  115.                                    else if(S<15&&S>10)
  116.                                                                 {
  117.                                                                         forward();
  118.                                                                         delay(200,200);
  119.                                                                         stop();
  120.                                                                 }
  121.       
  122.                                                                 else
  123.                                                                         {
  124.                                                                          stop();
  125.                                                                         }
  126.         }

  127. void zd0() interrupt 1                  //T0中断用来计数器溢出,超过测距范围
  128.   {
  129.     flag=1;                                                         //中断溢出标志
  130.   }

  131. void  StartModule()                          //启动模块
  132.   {
  133.           Trig=1;                                             //启动一次模块
  134.           _nop_();
  135.           _nop_();
  136.           _nop_();
  137.           _nop_();
  138.           _nop_();
  139.           _nop_();
  140.           _nop_();
  141.           _nop_();
  142.           _nop_();
  143.           _nop_();
  144.           _nop_();
  145.           _nop_();
  146.           _nop_();
  147.           _nop_();
  148.           _nop_();
  149.           _nop_();
  150.           _nop_();
  151.           _nop_();
  152.           _nop_();
  153.           _nop_();
  154.           _nop_();
  155.           Trig=0;
  156.   }



  157. void delayms(unsigned int ms)
  158. {
  159.         unsigned char i=100,j;
  160.         for(;ms;ms--)
  161.         {
  162.                 while(--i)
  163.                 {
  164.                         j=10;
  165.                         while(--j);
  166.                 }
  167.         }
  168. }

  169. void main(void)
  170. {

  171.          TMOD=0x01;                   //设T0为方式1,GATE=1;
  172.          TH0=0;
  173.          TL0=0;         
  174.          ET0=1;             //允许T0中断
  175.          EA=1;                           //开启总中断        

  176.         InitLcd1602();
  177.         LcdShowStr(0,0,PuZh);
  178.         while(1)
  179.         {
  180.                  StartModule();
  181.              while(!Echo);                //当RX为零时等待
  182.              TR0=1;                            //开启计数
  183.              while(Echo);                        //当RX为1计数并等待
  184.              TR0=0;                                //关闭计数
  185.          Conut();                        //计算
  186.                 delayms(80);
  187.                 gogogo();
  188.                  delayms(80);
  189.                  delayms(80);
  190.                  
  191.         }
  192.                         
  193. }
  194. void zd0() interrupt 3                  //T0中断用来计数器溢出,超过测距范围
  195.   {
  196.    
  197.                
  198.   }
复制代码

所有资料51hei提供下载:
超声波循迹小车(PWM版).7z (20.35 KB, 下载次数: 16)

评分

参与人数 1黑币 +50 收起 理由
admin + 50 共享资料的黑币奖励!

查看全部评分

回复

使用道具 举报

ID:927341 发表于 2021-7-28 14:18 | 显示全部楼层
程序错误
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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