找回密码
 立即注册

QQ登录

只需一步,快速开始

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

好用的单片机超声波测距装置程序

[复制链接]
跳转到指定楼层
楼主
上个学期做得一个超声波测距装置,运行无错误,需要的师兄欢迎下载使用

单片机源程序如下:
  1. /*
  2. 实验说明:
  3.         根据自己使用的LCD1602是否带有转接板,如果带有转接板的即为4位,需在LCD.H头文件中
  4.         将宏#define LCD1602_4PINS打开,我们这里使用的LCD1602是8位,所以默认将该宏注释。        
  5. 实验接线:
  6.         LCD1602液晶模块-->单片机管脚
  7.         参考LCD1602液晶显示实验接线(开发攻略内在对应的实验章节内实验现象有接线说明)
  8.         超声波模块-->单片机管脚
  9.         TRIG-->P21
  10.         ECHO-->P20

  11. 实验现象:
  12.         LCD1602上显示超声波检测的距离,单位mm
  13. */


  14. #include <reg52.h>
  15. #include<intrins.h>        
  16. #include"lcd.h"

  17. sbit Trig = P2^3;
  18. sbit Echo = P2^4;
  19. sbit beep=P1^4;



  20. unsigned char PuZh[]=" Pechin Science ";
  21. unsigned char code ASCII[15] =    {'0','1','2','3','4','5','6','7','8','9','.','-','M'};
  22. static unsigned char DisNum = 0; //显示用指针                                 
  23.        unsigned int  time=0;
  24.            unsigned long S=0;
  25.            bit      flag =0;
  26.            unsigned char disbuff[4]           ={ 0,0,0,0,};
  27. /*******************************************************************************
  28. * 函 数 名         : main
  29. * 函数功能                   : 主函数
  30. * 输    入         : 无
  31. * 输    出         : 无
  32. *******************************************************************************/
  33. void Conut(void)
  34.         {
  35.          time=TH0*256+TL0;
  36.          TH0=0;
  37.          TL0=0;
  38.         
  39.          S=(time*1.7)/100;     //算出来是CM
  40.          if((S>=500)||flag==1) //超出测量范围显示“-”
  41.          {         
  42.           flag=0;
  43.          
  44.           DisplayOneChar(0, 1, ASCII[11]);
  45.           DisplayOneChar(1, 1, ASCII[10]);        //显示点
  46.           DisplayOneChar(2, 1, ASCII[11]);
  47.           DisplayOneChar(3, 1, ASCII[11]);
  48.           DisplayOneChar(4, 1, ASCII[12]);        //显示M
  49.          }
  50.          else
  51.          {
  52.           disbuff[0]=S%1000/100;
  53.           disbuff[1]=S%1000%100/10;
  54.           disbuff[2]=S%1000%10 %10;
  55.           DisplayOneChar(0, 1, ASCII[disbuff[0]]);
  56.           DisplayOneChar(1, 1, ASCII[10]);        //显示点
  57.           DisplayOneChar(2, 1, ASCII[disbuff[1]]);
  58.           DisplayOneChar(3, 1, ASCII[disbuff[2]]);
  59.           DisplayOneChar(4, 1, ASCII[12]);        //显示M
  60.          }
  61. }
  62.         

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

  67. void  StartModule()                          //启动模块
  68.   {
  69.           Trig=1;                                             //启动一次模块
  70.           _nop_();
  71.           _nop_();
  72.           _nop_();
  73.           _nop_();
  74.           _nop_();
  75.           _nop_();
  76.           _nop_();
  77.           _nop_();
  78.           _nop_();
  79.           _nop_();
  80.           _nop_();
  81.           _nop_();
  82.           _nop_();
  83.           _nop_();
  84.           _nop_();
  85.           _nop_();
  86.           _nop_();
  87.           _nop_();
  88.           _nop_();
  89.           _nop_();
  90.           _nop_();
  91.           Trig=0;
  92.   }



  93. void delayms(unsigned int ms)
  94. {
  95.    uint i,j;   
  96.       for(i=ms;i>0;i--);
  97.            for(j=114;j>0;j--);
  98. }

  99. void delay10us(void)   
  100. {
  101.     unsigned char a,b;
  102.     for(b=1;b>0;b--)
  103.         for(a=2;a>0;a--);
  104. }



  105. void main(void)
  106. {

  107.          TMOD=0x01;                   //设T0为方式1,GATE=1;
  108.          TH0=0;
  109.          TL0=0;         
  110.          ET0=1;             //允许T0中断
  111.          EA=1;                           //开启总中断        

  112.         LcdInit();
  113.         LcdShowStr(0,0,PuZh);
  114.         while(1)
  115.         {
  116.                  StartModule();
  117.              while(!Echo);                //当RX为零时等待
  118.              TR0=1;                            //开启计数
  119.              while(Echo);                        //当RX为1计数并等待
  120.              TR0=0;                                //关闭计数
  121.          Conut();                        //计算
  122.                  delayms(80);
  123. /*******************************************************/
  124.          beep=~beep;
  125.          if(S>=300)
  126.          {
  127.                  beep=0;
  128.                  delay10us();
  129.          }
  130.          else
  131.          {
  132.                  if((S<300)&&(S>50))
  133.                  {
  134.                          beep=1;
  135.                          delayms(8000);
  136.                          beep=0;
  137.                          delayms(2000);
  138.                  }
  139.                  else
  140.                  {
  141.                          if((S>=0)&&(S<=50))
  142.                          {
  143.                                  beep=1;
  144.                                  delayms(1000000);
  145.                                  beep=0;
  146.                                  delayms(500000);
  147.                          }
  148.          }
  149.         }
  150. /*************************************************************/
  151.         }               
  152. }
复制代码

以上代码51hei提供下载:
程序.zip (69.14 KB, 下载次数: 10)


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

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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