欧美极品高清xxxxhd,国产日产欧美最新,无码AV国产东京热AV无码,国产精品人与动性XXX,国产传媒亚洲综合一区二区,四库影院永久国产精品,毛片免费免费高清视频,福利所导航夜趣136

標題: 超聲波測距程序 lcd1602液晶顯示 [打印本頁]

作者: zpxing    時間: 2016-5-25 11:02
標題: 超聲波測距程序 lcd1602液晶顯示
超聲波測距1602顯示程序

Trig -------  P2^1;
Echo -------  P2^0;
VCC  -------- +5v
GND  -------- GND

請在上電之前,檢查好接線是否正確。


超聲波程序:
  1. /*******************************************************************************
  2. * 實 驗 名                 : 矩陣鍵盤實驗
  3. * 使用的IO             : 數碼管使用P0,鍵盤使用P3.0、P3.1、P3.2、P3.3
  4. * 實驗效果       : 按矩陣鍵盤分別顯示在數碼管上面顯示十六進制的0到F。
  5. * 注    意                 :
  6. *******************************************************************************/
  7. #include<reg51.h>
  8. #include<intrins.h>       
  9. #include"lcd.h"

  10. sbit Trig = P2^1;
  11. sbit Echo = P2^0;



  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 Conut(void)
  26.         {
  27.          time=TH0*256+TL0;
  28.          TH0=0;
  29.          TL0=0;
  30.        
  31.          S=(time*1.7)/100;     //算出來是CM
  32.          if((S>=700)||flag==1) //超出測量范圍顯示“-”
  33.          {         
  34.           flag=0;
  35.          
  36.           DisplayOneChar(0, 1, ASCII[11]);
  37.           DisplayOneChar(1, 1, ASCII[10]);        //顯示點
  38.           DisplayOneChar(2, 1, ASCII[11]);
  39.           DisplayOneChar(3, 1, ASCII[11]);
  40.           DisplayOneChar(4, 1, ASCII[12]);        //顯示M
  41.          }
  42.          else
  43.          {
  44.           disbuff[0]=S%1000/100;
  45.           disbuff[1]=S%1000%100/10;
  46.           disbuff[2]=S%1000%10 %10;
  47.           DisplayOneChar(0, 1, ASCII[disbuff[0]]);
  48.           DisplayOneChar(1, 1, ASCII[10]);        //顯示點
  49.           DisplayOneChar(2, 1, ASCII[disbuff[1]]);
  50.           DisplayOneChar(3, 1, ASCII[disbuff[2]]);
  51.           DisplayOneChar(4, 1, ASCII[12]);        //顯示M
  52.          }
  53.         }

  54. void zd0() interrupt 1                  //T0中斷用來計數器溢出,超過測距范圍
  55.   {
  56.     flag=1;                                                         //中斷溢出標志
  57.   }

  58. void  StartModule()                          //啟動模塊
  59.   {
  60.           Trig=1;                                             //啟動一次模塊
  61.           _nop_();
  62.           _nop_();
  63.           _nop_();
  64.           _nop_();
  65.           _nop_();
  66.           _nop_();
  67.           _nop_();
  68.           _nop_();
  69.           _nop_();
  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.           Trig=0;
  83.   }



  84. void delayms(unsigned int ms)
  85. {
  86.         unsigned char i=100,j;
  87.         for(;ms;ms--)
  88.         {
  89.                 while(--i)
  90.                 {
  91.                         j=10;
  92.                         while(--j);
  93.                 }
  94.         }
  95. }

  96. void main(void)
  97. {
  98.          P1 = 0xF0;
  99.          TMOD=0x01;                   //設T0為方式1,GATE=1;
  100.          TH0=0;
  101.          TL0=0;         
  102.          ET0=1;             //允許T0中斷
  103.          EA=1;                           //開啟總中斷       

  104.         InitLcd1602();
  105.         LcdShowStr(0,0,PuZh);
  106.         while(1)
  107.         {
  108.                  StartModule();
  109.              while(!Echo);                //當RX為零時等待
  110.              TR0=1;                            //開啟計數
  111.              while(Echo);                        //當RX為1計數并等待
  112.              TR0=0;                                //關閉計數
  113.          Conut();                        //計算
  114.                  delayms(80);
  115.         }
  116.                        
  117. }
復制代碼


10.超聲波測距1602顯示.7z

1.69 MB, 下載次數: 83, 下載積分: 黑幣 -5

超聲波測距


作者: 1490895262    時間: 2018-12-18 15:38
可惜沒有仿真圖啊

作者: 扶桑神木    時間: 2021-5-31 12:16
下載程序后不能自動測距
作者: TLO--A    時間: 2021-9-28 16:13
有仿真圖嗎xd




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