博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
传感器之超声波测距HC-SR04
阅读量:4582 次
发布时间:2019-06-09

本文共 1899 字,大约阅读时间需要 6 分钟。

一.前言

       

       HC-SR04超声波测距模块可提供2cm-400cm的非接触式距离感测功能,测距精度可达高到3mm;模块包括超声波发射器、接收器与控制电路。像智能小车的测距以及转向,或是一些项目中,常常会用到。智能小车测距可以及时发现前方的障碍物,使智能小车可以及时转向,避开障碍物,所以,我们今天就来学习一下这个传感器。

二.工作原理

      1.给超声波模块接入电源和地。

      2.给脉冲触发引脚(trig)输入一个长为20us的高电平方波

      3.输入方波后,模块会自动发射8个40KHz的声波,与此同时回波引脚(echo)端的电平会由0变为1;(此时应该启动定时器计时)

      4.当超声波返回被模块接收到时,回波引 脚端的电平会由1变为0;(此时应该停止定时器计数),定时器记下的这个时间即为超声波由发射到返回的总时长。
      5.根据声音在空气中的速度为344米/秒,即可计算出所测的距离。

      要学习和应用传感器,学会看懂传感器的时序图是很关键的,所以我们来看一下HC-SR04的时序触发图。

   

 

    我们来分析一下这个时序图,先由触发信号启动HC-RS04测距模块,也就是说,主机要先发送至少10us的高电平,触发HC-RS04,模块内部发出信号是传感器自动回应的,我们不用去管它。输出回响信号是我们需要关注的。信号输出的高电平就是超声波发出到重新返回接收所用的时间。用定时器,可以把这段时间记录下来,算出距离,别忘了结果要除于2,因为总时间是发送和接收的时间总和。

三.程序

#include<reg52.h>

#define uchar unsigned char  

#define uint  unsigned int

 sbit Echo=P3^2;  

sbit Trig=P1^5;

 bit flag=0;

 /***********************************    函数:void Delay5us()  ----------------------    说明:5微秒延时函数    参数:无  返回值:无 ***********************************/

void Delay5us()

{  uchar i;  i--;  i--;  i--;  i--;  i--;  i--; }

void DelayMs(uint ms)

{  uint x,y;  for(x=ms;x>0;x--)  

 for(y=110;y>0;y--); }

 

void  Init() 

{    

TMOD=0x21;  

SCON = 0x50;  

EA=1;  

ES=1;

ET0=1;  

ET1=1;  

TH1=0Xfd;  

TL1=0xfd;  

TR1=1;

}

void Send(uint dat)

{  

SBUF=(dat/100)+ 48;   // 发送 百 位  

while(!TI);  

TI=0;  

SBUF=(dat%100/10)+48;  // 发送 十 位  

while(!TI);  TI=0;  

SBUF=(dat%10)+48;   // 发送 个 位

 while(!TI);  TI=0;

}

uint Conut(void)

{  

uint time;            // 用于记录测得的时间  

uint ss;      // 用于记录测得的距离

 time = (TH0*256+TL0)*1.09;  // 总时间    

TH0=0;  TL0=0;

 if(flag==1)         // 如果超出测量距离,则不传输数据

 {   flag=0;   ss=0;  }  

else  

{   

ss=time*1.7/100;      // 空气中声音的速度是340m/s

 }  

return ss; }

     void main(void)     {

    uint ss;     Init();

     while(1)   

{          

Trig=1;    

  Delay5us();     

Delay5us();         

Trig=0;     

while(!Echo);     

TR0=1;     

while(Echo);     

TR0=0;     

ss=Conut();   // 计算    

Send(ss);   // 将计算的值通过串口发送出去    

DelayMs(800);

              }

 

四.总结

     上面这个程序的功能就是从测距传感器获得距离的数值,进行单位的转化后用串口进行输出,显示在串口助手中,转化后的单位为厘米,还有一点需要注意的是,触发输入和回响输出端在不同的板子上是不一样的,大家要根据自己的原理图及单片机自己修改,有什么问题可以互相交流0.0

 

 

    }

 void zd0() interrupt 1 {  flag=1;     }

        

   

转载于:https://www.cnblogs.com/sjsxk/p/5356210.html

你可能感兴趣的文章
realsense blog 国外某人
查看>>
点击按钮将内容赋值到粘贴板
查看>>
DevExpress12.2.6 安装顺序记录
查看>>
.Net基础篇_学习笔记_第四天_switch-case02
查看>>
linux之基本命令讲解
查看>>
DAG上dp思想
查看>>
写文件
查看>>
HDU5367 思维map // 动态线段树
查看>>
洛谷P1501 动态树(LCT)
查看>>
usaco Shuttle Puzzle
查看>>
SQLServer数据库的状态一直都是正在还原
查看>>
EM算法总结
查看>>
剑指Offer——二叉树的下一个节点
查看>>
关于virtualenvwrapper的python, pip 的版本的问题
查看>>
iOS获取APP的版本号和名称
查看>>
如何用keytool导入证书
查看>>
[转]linux14.04下caffe的安装步骤
查看>>
重操JS旧业第十弹:闭包
查看>>
JSP 自动刷新
查看>>
ORACLE 如何产生一个随机数
查看>>