找回密码
 立即注册

QQ登录

只需一步,快速开始

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

51单片机超声波测距代码,用的是数码管显示

[复制链接]
跳转到指定楼层
楼主
ID:291235 发表于 2018-10-9 09:17 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
测试能用,学会超声波又是一个进度

单片机源程序如下:
  1. /*   超声波模块的TRIG管脚接在单片机的P20口,ECHO管脚接在单片机的P21口 其他的电源管脚接在单片机
  2.                 开发板上电源口即可。      */


  3. #include"reg51.h"

  4. #include <intrins.h>
  5. sbit RX=P2^1;
  6. sbit TX=P2^0;
  7. unsigned int  time=0;
  8. unsigned int  timer=0;
  9. unsigned char posit=0;
  10. unsigned long S=0;
  11. bit      flag =0;
  12. //--定义使用的IO--//
  13. #define GPIO_DIG P0

  14. sbit LSA=P2^2;
  15. sbit LSB=P2^3;
  16. sbit LSC=P2^4;

  17. //--定义全局变量--//
  18. unsigned char code DIG_CODE[17]={
  19. 0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,
  20. 0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71};
  21. //0、1、2、3、4、5、6、7、8、9、A、b、C、d、E、F的显示码
  22. unsigned char disbuff[4]           ={ 0,0,0,0,};
  23. /*******************************************************************************
  24. * 函 数 名         : DigDisplay
  25. * 函数功能                   : 使用数码管显示
  26. * 输    入         : 无
  27. * 输    出         : 无
  28. *******************************************************************************/
  29. void DigDisplay()
  30. {
  31.         unsigned char i;
  32.         unsigned int j;
  33.         for(i=0;i<8;i++)
  34.         {
  35.                 switch(i)         //位选,选择点亮的数码管,
  36.                 {
  37.                         case(0):
  38.                                 LSA=0;LSB=0;LSC=0; break;//显示第0位
  39.                         case(1):
  40.                                 LSA=1;LSB=0;LSC=0; break;//显示第1位
  41.                         case(2):
  42.                                 LSA=0;LSB=1;LSC=0; break;//显示第2位
  43.                         case(3):
  44.                                 LSA=1;LSB=1;LSC=0; break;//显示第3位
  45.                         case(4):
  46.                                 LSA=0;LSB=0;LSC=1; break;//显示第4位
  47.                         case(5):
  48.                                 LSA=1;LSB=0;LSC=1; break;//显示第5位
  49.                         case(6):
  50.                                 LSA=0;LSB=1;LSC=1; break;//显示第6位
  51.                         case(7):
  52.                                 LSA=1;LSB=1;LSC=1; break;//显示第7位       
  53.                 }
  54.                 GPIO_DIG=disbuff[i];//发送段码
  55.                 j=10;                                                 //扫描间隔时间设定
  56.                 while(j--);       
  57.                 GPIO_DIG=0x00;//消隐
  58.         }
  59. }
  60. /********************************************************/
  61.     void Conut(void)
  62.         {
  63.          time=TH0*256+TL0;
  64.          TH0=0;
  65.          TL0=0;
  66.        
  67.          S= (long)(time*0.17);     //算出来是CM
  68.          if((S>=4000)||flag==1) //超出测量范围显示“ERR0”
  69.          {         
  70.           flag=0;
  71.           disbuff[0]=0x3f;           //“-”
  72.           disbuff[1]=0x50;           //“-”
  73.           disbuff[2]=0x50;           //“-”
  74.           disbuff[3]=0x79;           //“-”
  75.          }
  76.          else
  77.          {
  78.           disbuff[3]=DIG_CODE[S%10000/1000];
  79.           disbuff[2]=DIG_CODE[S%1000/100];
  80.           disbuff[1]=DIG_CODE[S%100/10];
  81.           disbuff[0]=DIG_CODE[S%10/1];
  82.          }
  83.         }
  84. /********************************************************/
  85.      void zd0() interrupt 1                  //T0中断用来计数器溢出,超过测距范围
  86.   {
  87.     flag=1;                                                         //中断溢出标志
  88.   }
  89. /********************************************************/
  90.    void  zd3()  interrupt 3                  //T1中断用来扫描数码管和计800MS启动模块
  91.   {
  92.          TH1=0xf8;
  93.          TL1=0x30;
  94.          DigDisplay();
  95.          timer++;
  96.          if(timer>=100)
  97.          {
  98.           timer=0;
  99.           TX=1;                                        //800MS  启动一次模块
  100.           _nop_();
  101.           _nop_();
  102.           _nop_();
  103.           _nop_();
  104.           _nop_();
  105.           _nop_();
  106.           _nop_();
  107.           _nop_();
  108.           _nop_();
  109.           _nop_();
  110.           _nop_();
  111.           _nop_();
  112.           _nop_();
  113.           _nop_();
  114.           _nop_();
  115.           _nop_();
  116.           _nop_();
  117.           _nop_();
  118.           _nop_();
  119.           _nop_();
  120.           _nop_();
  121.           TX=0;
  122.          }
  123.   }
  124. /*********************************************************/

  125.         void  main(  void  )

  126.   {  
  127.     TMOD=0x11;                   //设T0为方式1,GATE=1;
  128.         TH0=0;
  129.         TL0=0;         
  130.         TH1=0xf8;                   //2MS定时
  131.         TL1=0x30;
  132.         ET0=1;             //允许T0中断
  133.         ET1=1;                           //允许T1中断
  134.         TR1=1;                           //开启定时器
  135.         EA=1;                           //开启总中断

  136.         while(1)
  137.         {
  138.          while(!RX);                //当RX为零时等待
  139.          TR0=1;                            //开启计数
  140.          while(RX);                        //当RX为1计数并等待
  141.          TR0=0;                                //关闭计数
  142.      Conut();                        //计算
  143.         }

  144.   }
复制代码

所有资料51hei提供下载:
51单片机的超声波测距.rar (16.47 KB, 下载次数: 49)


评分

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

查看全部评分

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

使用道具 举报

沙发
ID:407566 发表于 2018-11-8 15:15 | 只看该作者
怎么连线
回复

使用道具 举报

板凳
ID:443640 发表于 2018-12-11 17:12 | 只看该作者
有实物图吗?
回复

使用道具 举报

地板
ID:290892 发表于 2022-1-8 23:08 | 只看该作者
请问这个程序有没有遇到过,1米和一米三之间测量不出来的问题,我用的普中例程,发现有段测量不出来
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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