找回密码
 立即注册

QQ登录

只需一步,快速开始

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

51智能小车遥控与测距合起来失败了,求指点

[复制链接]
跳转到指定楼层
楼主
ID:265318 发表于 2018-1-21 20:48 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
50黑币
  1. 单独分开使用的时候问题不大(测距超过70后会变成133,我不太明白为啥,感觉是传感的问题)
复制代码


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

使用道具 举报

沙发
ID:265318 发表于 2018-1-22 10:13 | 只看该作者
  1. #include "reg52.h"                         //此文件中定义了单片机的一些特殊功能寄存器
  2. #include <intrins.h>       

  3. typedef unsigned int u16;          //对数据类型进行声明定义
  4. typedef unsigned char u8;
  5. sbit IRIN=P3^2;
  6. u8 IrValue[6];
  7. u8 Tim;
  8. u8 code smgduan[17]={
  9. 0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,
  10. 0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71,0X76};
  11. //0、1、2、3、4、5、6、7、8、9、A、b、C、d、E、F、H的显示码

  12. unsigned int  time=0;
  13. unsigned int  timer=0;
  14. unsigned char posit=0;
  15. unsigned long S=0;
  16. unsigned long S1=0;
  17. unsigned long S2=0;
  18. bit      flag =0;
  19. sbit in1=P1^0;
  20. sbit in2=P1^1;
  21. sbit in3=P1^2;
  22. sbit in4=P1^3;
  23. sbit RX=P2^1;
  24. sbit TX=P2^0;
  25. sbit LSA=P2^2;
  26. sbit LSB=P2^3;
  27. sbit LSC=P2^4;
  28. sbit beep=P1^5;
  29. unsigned char disbuff[4]={ 0,0,0,0,};

  30. /*******************************************************************************
  31. * 函 数 名         : delay
  32. * 函数功能                   : 延时函数,i=1时,大约延时10us
  33. *******************************************************************************/
  34. void delay(u16 i)
  35. {
  36.         while(i--);       
  37. }
  38. void zhixing()
  39. { in1=1;
  40.   in2=0;
  41.   in3=1;
  42.   in4=0;
  43.   delay(10);
  44.    



  45. }
  46. void daotui()
  47. {in1=0;
  48. in2=1;
  49. in3=0;
  50. in4=1;

  51. }
  52. void zhuozhuan()
  53. {in1=0;
  54. in2=1;
  55. in3=0;
  56. in4=1;
  57. }
  58. void youzhuan()
  59. {
  60. }
  61. void tingzhi()
  62. {in1=0;
  63. in2=0;
  64. in3=0;
  65. in4=0;
  66. }
  67. void control()
  68. {if(IrValue[2]==0x0b)
  69. {zhixing();}
  70. else if(IrValue[2]==0x0d)
  71. {tingzhi();}
  72. else if(IrValue[2]==0x11)
  73. {youzhuan();}
  74. else if(IrValue[2]==0x10)
  75. {zhuozhuan();}
  76. else if(IrValue[2]==0x0e)
  77. {daotui();}

  78. }


  79. /*******************************************************************************
  80. * 函数名         :DigDisplay()
  81. * 函数功能                 :数码管显示函数
  82. * 输入           : 无
  83. * 输出                  : 无
  84. *******************************************************************************/
  85. void xianshi()
  86. {
  87.         u8 i,j;
  88.         for(i=0;i<3;i++)
  89.         {
  90.                 switch(i)         //位选,选择点亮的数码管,
  91.                 {
  92.                         case(0):
  93.                                 LSA=0;LSB=0;LSC=0; break;//显示第0位
  94.                         case(1):
  95.                                 LSA=1;LSB=0;LSC=0; break;//显示第1位
  96.                         case(2):
  97.                                 LSA=0;LSB=1;LSC=0; break;//显示第2位       
  98.                 }
  99.                 P0=0x00;
  100.                 P0=disbuff[i];
  101.                 j=10;
  102.                 while(j--); //间隔一段时间扫描       
  103.                 P0=0x00;//消隐
  104.         }               
  105. }


  106. /*******************************************************************************
  107. * 函数名         : IrInit()
  108. * 函数功能                   : 初始化红外线接收
  109. * 输入           : 无
  110. * 输出                  : 无
  111. *******************************************************************************/




  112. /*******************************************************************************
  113. * 函 数 名       : main
  114. * 函数功能                 : 主函数
  115. * 输    入       : 无
  116. * 输    出             : 无
  117. *******************************************************************************/
  118. /*********************************************************/
  119. void Count()
  120. {    time=TH0*256+TL0;
  121.          S1= time*0.17;     //算出来是CM
  122.      S2=time*0.17;
  123.      TH0=0x00;
  124.      TL0=0x00;
  125.      S=(S1+S2)/4;
  126.          if((S>=4000)||flag==1) //超出测量范围显示“ERR0”
  127.          {         
  128.           flag=0;
  129.           disbuff[0]=0x3f;           //“-”
  130.           disbuff[1]=0x50;           //“-”
  131.           disbuff[2]=0x50;           //“-”
  132.          }
  133.          else
  134.          {
  135.           disbuff[2]=smgduan[S%1000/100];
  136.           disbuff[1]=smgduan[S%100/10];
  137.           disbuff[0]=smgduan[S%10/1];
  138.          }
  139.          
  140.         }
  141. /********************************************************/


  142. void main()
  143. {       
  144.     IT0=1;//下降沿触发
  145.         EX0=1;//打开中断0允许
  146.         IRIN=1;//初始化端口;
  147.         TMOD=0x11;                   //设T0为方式1,GATE=1;
  148.         TH0=0;
  149.         TL0=0;         
  150.         TH1=0xf8;                   //2MS定时
  151.         TL1=0x30;
  152.         ET0=1;             //允许T0中断
  153.         ET1=1;                           //允许T1中断
  154.         TR1=1;                           //开启定时器
  155.         EA=1;                           //开启总中断
  156.         while(1)
  157.         {
  158.      
  159.          while(!RX);                //当RX为零时等待
  160.          TR0=1;                            //开启计数
  161.          while(RX);                        //当RX为1计数并等待
  162.          Count();
  163.          TR0=0;                                //关闭计数
  164.          control();               
  165.         }               
  166. }

  167. /*******************************************************************************
  168. * 函数名         : ReadIr()
  169. * 函数功能                   : 读取红外数值的中断函数
  170. * 输入           : 无
  171. * 输出                  : 无
  172. *******************************************************************************/

  173. void ReadIr() interrupt 0
  174. {
  175.         u8 j,k;
  176.         u16 err;
  177.         Tim=0;                                         
  178.         delay(700);        //7ms
  179.         if(IRIN==0)                //确认是否真的接收到正确的信号
  180.         {         
  181.                
  182.                 err=1000;                                //1000*10us=10ms,超过说明接收到错误的信号
  183.                 /*当两个条件都为真是循环,如果有一个条件为假的时候跳出循环,免得程序出错的时
  184.                 侯,程序死在这里*/       
  185.                 while((IRIN==0)&&(err>0))        //等待前面9ms的低电平过去                 
  186.                 {                       
  187.                         delay(1);
  188.                         err--;
  189.                 }
  190.                 if(IRIN==1)                        //如果正确等到9ms低电平
  191.                 {
  192.                         err=500;
  193.                         while((IRIN==1)&&(err>0))                 //等待4.5ms的起始高电平过去
  194.                         {
  195.                                 delay(1);
  196.                                 err--;
  197.                         }
  198.                         for(k=0;k<4;k++)                //共有4组数据
  199.                         {                               
  200.                                 for(j=0;j<8;j++)        //接收一组数据
  201.                                 {

  202.                                         err=60;               
  203.                                         while((IRIN==0)&&(err>0))//等待信号前面的560us低电平过去
  204.                                         {
  205.                                                 delay(1);
  206.                                                 err--;
  207.                                         }
  208.                                         err=500;
  209.                                         while((IRIN==1)&&(err>0))         //计算高电平的时间长度。
  210.                                         {
  211.                                                 delay(10);         //0.1ms
  212.                                                 Tim++;
  213.                                                 err--;
  214.                                                 if(Tim>30)
  215.                                                 {
  216.                                                         return;
  217.                                                 }
  218.                                         }
  219.                                         IrValue[k]>>=1;         //k表示第几组数据
  220.                                         if(Tim>=8)                        //如果高电平出现大于565us,那么是1
  221.                                         {
  222.                                                 IrValue[k]|=0x80;
  223.                                         }                  
  224.                                         Tim=0;                //用完时间要重新赋值                                                       
  225.                                 }
  226.                         }
  227.                 }
  228.                 if(IrValue[2]!=~IrValue[3])
  229.                 {
  230.                         return;
  231.                 }

  232. }                               
  233. }
  234. /********************************************************/
  235.      void zd0() interrupt 1                  //T0中断用来计数器溢出,超过测距范围
  236.   {
  237.     flag=1;                                                         //中断溢出标志
  238.   }
  239. /********************************************************/
  240.    void  zd3()  interrupt 3                  //T1中断用来扫描数码管和计800MS启动模块
  241.   {
  242.          TH1=0xf8;
  243.          TL1=0x30;
  244.          xianshi();
  245.          timer++;
  246.          if(timer>=100)
  247.          {
  248.           timer=0;
  249.           TX=1;                                        //800MS  启动一次模块
  250.           _nop_();
  251.           _nop_();
  252.           _nop_();
  253.           _nop_();
  254.           _nop_();
  255.           _nop_();
  256.           _nop_();
  257.           _nop_();
  258.           _nop_();
  259.           _nop_();
  260.           _nop_();
  261.           _nop_();
  262.           _nop_();
  263.           _nop_();
  264.           _nop_();
  265.           _nop_();
  266.           _nop_();
  267.           _nop_();
  268.           _nop_();
  269.           _nop_();
  270.           _nop_();
  271.           TX=0;
  272.          }
  273.   }
复制代码
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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