找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 1980|回复: 0
收起左侧

超声波1602显示距离资料分享!

[复制链接]
ID:102056 发表于 2016-12-13 13:22 | 显示全部楼层 |阅读模式
IMG_20161213_132047.jpg

部分源码预览:
  1. /*******************************************************************************
  2. * 实 验 名                 : 超声波实验
  3. * 使用的IO             : LCD1602使用P0,P3.3 P3.4,P3.5  超声波模块使用VCC,GND, TringP2.6,         Echo  P2.7
  4. * 实验效果       : 测距显示
  5. * 注    意                 :
  6. *******************************************************************************/
  7. #include<reg51.h>
  8. #include<intrins.h>       
  9. #include"lcd.h"
  10. sbit dula=P1^7;
  11. sbit wela=P1^6;

  12. sbit Trig = P2^6;
  13. sbit Echo = P2^7;



  14. unsigned char PuZh[]=" Pechin Science ";
  15. unsigned char code ASCII[15] =    {'0','1','2','3','4','5','6','7','8','9','.','-','M'};

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

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

  60. void  StartModule()                          //启动模块
  61.   {
  62.           Trig=1;                                             //启动一次模块
  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.           _nop_();
  83.           _nop_();
  84.           Trig=0;
  85.   }



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

  98. /* ***************************************************** */
  99. // 函数名称:CloseDigTube()
  100. // 函数功能:关数码管(免打扰模式)
  101. // 入口参数:无
  102. // 出口参数:无
  103. /* ***************************************************** */
  104. void CloseDigTube(void)
  105. {
  106.         wela = 1;
  107.         P0 = 0xff;
  108.         wela =0;
  109.         dula = 1;
  110.         P0 = 0x00;
  111.         dula =0;
  112. }               

  113. void main(void)
  114. {

  115.          TMOD=0x01;                   //设T0为方式1,GATE=1;
  116.          TH0=0;
  117.          TL0=0;         
  118.          ET0=1;             //允许T0中断
  119.          EA=1;                           //开启总中断       
  120.         CloseDigTube();
  121.         InitLcd1602();
  122.         LcdShowStr(0,0,PuZh);
  123.         while(1)
  124.         {
  125.                  StartModule();
  126.              while(!Echo);                //当RX为零时等待
  127.              TR0=1;                            //开启计数
  128.              while(Echo);                        //当RX为1计数并等待
  129.              TR0=0;                                //关闭计数
  130.          Conut();                        //计算
  131.                  delayms(80);
  132.         }
  133.                        
  134. }
复制代码

0.png

超声波模块1602显示程序.zip

52.33 KB, 下载次数: 49, 下载积分: 黑币 -5

评分

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

查看全部评分

回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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