標題: 基于單片機的超聲波測距程序設計與制作 1602液晶顯示 [打印本頁]

作者: 廠白小    時間: 2021-1-17 15:55
標題: 基于單片機的超聲波測距程序設計與制作 1602液晶顯示
該設計控制器使用的是單片機STC89C52, STC89C52單片機在工控、測量、儀器儀表中應用還是比較廣泛的。顯示模塊是用LCD1602實現(xiàn)距離顯示。蜂鳴器用來實現(xiàn)當測量距離超過設定的上限時的報警功能。附件中包含源程序,原理圖,PCB,元件清單和一份資料。大家盡管下載學習,包你學會。


實物測試圖如下,,最遠測試距離為5m。程序流程圖如下

本次設計的超聲波測距采用的是超聲波模塊HC-SR04,HC-SR04超聲波模塊性能穩(wěn)定,測度距離精確,模塊高精度,盲區(qū)小。 產(chǎn)品應用領域: 常用于機器人避障、物體測距、液位檢測、公共安防、停車場檢測等場所。
該設計控制器使用的是單片機STC89C52, STC89C52單片機在工控、測量、儀器儀表中應用還是比較廣泛的。顯示模塊是用LCD1602實現(xiàn)距離顯示。蜂鳴器用來實現(xiàn)當測量距離超過設定的上限時的報警功能。

測試分為三部分,第一部分為測試距離小于50cm;第二部分為測試距離小于200cm,大于50cm;第三部分為測試距離大于200cm。
測試距離小于50cm如圖5-1所示;
測試距離小于200cm,大于50cm如圖5-2所示;
測試距離大于200cm如圖5-2所示;

圖5-1測試距離小于50cm
圖5-2測試距離小于200cm,大于50cm
圖5-3測試距離大于200cm
5.2數(shù)據(jù)分析
通過多次測量,得到最終的距離測試范圍0~500cm,但測量出來的距離與實際距離有±1-2cm的誤差。經(jīng)過查資料了解,是因為超聲波在空氣中的傳播速度與溫度有關,如果溫度變化不大,則可認為聲速是基本不變的;但實際中溫度總會變化,所以測出的距離與實際會有誤差。如果要解決溫度對超聲波速度的影響,可采用溫度補償。

部分單片機代碼如下:

  1. #include <reg52.h>
  2. #include<intrins.h>        
  3. #include"lcd.h"
  4. sbit Trig = P2^3;
  5. sbit Echo = P2^4;
  6. sbit beep=P1^4;
  7. unsigned char PuZh[]=" 3172052052208 ";
  8. unsigned char code ASCII[15] =    {'0','1','2','3','4','5','6','7','8','9','.','-','M'};
  9. static unsigned char DisNum = 0; //顯示用指針                          
  10.        unsigned int  time=0;
  11.            unsigned long S=0;
  12.            bit      flag =0;
  13.            unsigned char disbuff[4]           ={ 0,0,0,0,};
  14. void Conut(void)
  15.         {
  16.          time=TH0*256+TL0;
  17.          TH0=0;
  18.          TL0=0;
  19.          S=(time*1.7)/100;     //算出來是CM
  20.          if((S>=500)||flag==1) //超出測量范圍顯示“-”
  21.          {         
  22.           flag=0;
  23.           DisplayOneChar(0, 1, ASCII[11]);
  24.           DisplayOneChar(1, 1, ASCII[10]);        //顯示點
  25.           DisplayOneChar(2, 1, ASCII[11]);
  26.           DisplayOneChar(3, 1, ASCII[11]);
  27.           DisplayOneChar(4, 1, ASCII[12]);        //顯示M
  28.          }
  29.          else
  30.          {
  31.           disbuff[0]=S%1000/100;
  32.           disbuff[1]=S%1000%100/10;
  33.           disbuff[2]=S%1000%10 %10;
  34.           DisplayOneChar(0, 1, ASCII[disbuff[0]]);
  35.           DisplayOneChar(1, 1, ASCII[10]);        //顯示點
  36.           DisplayOneChar(2, 1, ASCII[disbuff[1]]);
  37.           DisplayOneChar(3, 1, ASCII[disbuff[2]]);
  38.           DisplayOneChar(4, 1, ASCII[12]);        //顯示M
  39.          }
  40. }
  41. void zd0() interrupt 1                  //T0中斷用來計數(shù)器溢出,超出測距范圍
  42.   {
  43.     flag=1;                                                         //中斷溢出標志
  44.   }
  45. void  StartModule()                          //啟動模塊
  46.   {
  47.           Trig=1;                                             //啟動一次模塊
  48.           _nop_();
  49.           _nop_();
  50.           _nop_();
  51.           _nop_();
  52.           _nop_();
  53.           _nop_();
  54.           _nop_();
  55.           _nop_();
  56.           _nop_();
  57.           _nop_();
  58.           _nop_();
  59.           _nop_();
  60.           _nop_();
  61.           _nop_();
  62.           _nop_();
  63.           _nop_();
  64.           _nop_();
  65.           _nop_();
  66.           _nop_();
  67.           _nop_();
  68.           _nop_();
  69.           Trig=0;
  70.   }
  71. void delayms(unsigned int ms)
  72. {
  73.    uint i,j;   
  74.       for(i=ms;i>0;i--);
  75.            for(j=114;j>0;j--);
  76. }
  77. void delay10us(void)   
  78. {
  79.     unsigned char a,b;
  80.     for(b=1;b>0;b--)
  81.         for(a=2;a>0;a--);
  82. }
  83. void main(void)
  84. {

  85.          TMOD=0x01;                   //設T0為方式1,GATE=1;
  86.          TH0=0;
  87.          TL0=0;         
  88.          ET0=1;             //允許TO中斷
  89.          EA=1;                           //開啟總中斷        
  90. LcdInit();
  91.         LcdShowStr(0,0,PuZh);
  92.         while(1)
  93.         {
  94.                  StartModule();
  95.              while(!Echo);                //當RX為零時等待
  96.              TR0=1;                            //開啟計數(shù)
  97.              while(Echo);                        //當RX為1計數(shù)并等待
  98.              TR0=0;                                //關閉計算
  99.          Conut();                        //計算
  100.                  delayms(80);
  101.          beep=~beep;
  102.          if(S>=200)
  103.          {
  104.                  beep=0;
  105.                  delay10us();
  106.          }
  107.          else
  108.          {
  109.                  if((S<200)&&(S>50))
  110.                  {
  111.                          beep=1;
  112.                          delayms(8000);
  113.                          beep=0;
  114.                          delayms(2000);
  115.                  }
  116.                  else
  117.                  {
  118.                          if((S>=0)&&(S<=50))
  119.                          {
  120.                                  beep=1;
  121.                                  delayms(1000000);
  122.                                  beep=0;
  123.                                  delayms(500000);
  124.                          }
  125.          }
  126.         }
  127.         }               
  128. }
復制代碼


全部資料51hei下載地址:
超聲波測距.zip (2.07 MB, 下載次數(shù): 62)





歡迎光臨 (http://www.torrancerestoration.com/bbs/) Powered by Discuz! X3.1