找回密码
 立即注册

QQ登录

只需一步,快速开始

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

单片机+LCD1602+HR-04显示屏显示超声波测距工作原理 仿真程序

[复制链接]
ID:692965 发表于 2020-8-30 07:04 | 显示全部楼层 |阅读模式
1.基本工作原理
(1)采用IO口TRIG触发测距,给最少10us的高电平信号。
(2)模块自动发送8个40khz的方波,自动检测是否有信号返回。
(3)有信号返回,通过IO口ECHO输出一个高电平,高电平持续时间就是超声波从发射到返回的时间,测试距离=(高电平时间*声速(340M/s)/2(发射和回来的时间,所以要除以2))

参数.jpg
模块参数.jpg

2.模块实物图
u=596697535,1187657376&fm=26&gp=0.jpg
3.驱动程序
文章下面有链接,由于proteus里面没有HR04模块,所以在仿真的时候可以用另一个单片机模拟HR-04模块,然后单片机和单片机进行通信,不能用串口通信,因为超声波测距在用定时器进行着计时,而设置波特率用到定时器1,没办法用定时器1来设置波特率。过程有点麻烦,我就没搭建,其他的搭建好。
4.效果图
IMG_20200829_233115.jpg IMG_20200829_233026.jpg

AT89C52单片机源程序如下:
  1. /*
  2. 实验说明:
  3.          STC89C52 晶振:12Mhz 模块:HR04  LCD1602
  4.         LCD1602液晶模块-->单片机管脚
  5.         参考LCD1602液晶显示实验接线(开发攻略内在对应的实验章节内实验现象有接线说明)
  6.         超声波模块-->单片机管脚
  7.         TRIG-->P21
  8.         ECHO-->P20
  9.         LCD1602_RW-->P2^5
  10.         LCD1602_RS-->P2^6
  11.     LCD1602_E-->P2^7
  12.     因为proteus里面没有HR04模块,HR04是一个模拟信号,我们可以用一个模拟信号代替HR04,处理方法是一样的
  13.    
  14. 实验现象:
  15.         LCD1602上显示超声波检测的距离,单位mm
  16.         仅限用于交流学习
  17. */


  18. #include<reg51.h>
  19. #include<intrins.h>        
  20. #include"lcd.h"

  21. sbit Trig = P2^1;
  22. sbit Echo = P2^0;



  23. unsigned char PuZh[]=" Pechin Science ";//显示距离
  24. unsigned char code ASCII[15] =    {'0','1','2','3','4','5','6','7','8','9','.','-','M'};

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

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

  69. void  StartModule()                          //启动模块
  70.   {
  71.           Trig=1;                                             //启动一次模块
  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.           _nop_();
  92.           _nop_();
  93.           Trig=0;
  94.   }



  95. void delayms(unsigned int ms)
  96. {
  97.         unsigned char i=100,j;
  98.         for(;ms;ms--)
  99.         {
  100.                 while(--i)
  101.                 {
  102.                         j=10;
  103.                         while(--j);
  104.                 }
  105.         }
  106. }

  107. void main(void)
  108. {

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

  114.         LcdInit();
  115.         LcdShowStr(0,0,PuZh);
  116.         while(1)
  117.         {
  118.                  StartModule();
  119.              while(!Echo);                //当RX为零时等待
  120.              TR0=1;                            //开启计数
  121.              while(Echo);                        //当RX为1计数并等待
  122.              TR0=0;                                //关闭计数
  123.          Conut();                        //计算
  124.                  delayms(80);
  125.         }
  126.                         
  127. }
复制代码

所有资料51hei提供下载:
proteus和HR04.zip (467.49 KB, 下载次数: 53)

评分

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

查看全部评分

回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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