蓝桥杯单片机必备知识—–(9)超声波测距

蓝桥杯单片机必备知识—–(9)超声波测距

蓝桥杯单片机必备知识—–(9)超声波测距

超声波测距原理:

超声波发射器向某一方向发射超声波,在发射时刻的同时开始计时,超声波在空气中传播,途中碰到障碍物就立即返回来,超声波接收器收到反射波就立即停止计时。超声波在空气中的传播速度为340m/s,根据计时器记录的时间t,就可以计算出发射点距障碍物的距离(s),即:s=340t/2 。这就是所谓的时间差测距法。
超声波测距的原理是利用超声波在空气中的传播速度为已知,测量声波在发射后遇到障碍物反射回来的时间,根据发射和接收的时间差计算出发射点到障碍物的实际距离。由此可见,超声波测距原理与雷达原理是一样的。
测距的公式表示为:L=C×T
式中L为测量的距离长度;C为超声波在空气中的传播速度;T为测量距离传播的时间差(T为发射到接收时间数值的一半)。
超声波测距主要应用于倒车提醒、建筑工地、工业现场等的距离测量,虽然目前的测距量程上能达到百米,但测量的精度往往只能达到厘米数量级。
由于超声波易于定向发射、方向性好、强度易控制、与被测量物体不需要直接接触的优点,是作为液体高度测量的理想手段。在精密的液位测量中需要达到毫米级的测量精度,但是目前国内的超声波测距专用集成电路都是只有厘米级的测量精度。

核心代码:

//切记,计算距离不使用分频
sbit TX = P1^0;  //发射引脚
sbit RX = P1^1;  //接收引脚

void main(void)
{
   
  cls();
	AUXR = 0x80;
  TMOD = 0x10;  //配置定时器工作模式
  TH0 = 0xcd;
  TL0 = 0xd4;  
  TH1 = 0;
  TL1 = 0;  
  TR0 = 1;  //启动定时器
  EA = 1;
  ET0 = 1;  //打开定时器0中断
  while(1)
  {
   
        /** 100毫秒更新一次数据 */
		if(s_flag)
    {
   
      s_flag = 0;
      send_wave();  //发送方波信号
      TR1 = 1;  //启动计时
			while((RX == 1) && (TF1 == 0));  //等待收到脉冲,没有计满溢出
			TR1 = 0;  //关闭计时

			//发生溢出
			if(TF1 == 1)
			{
   
				TF1 = 0;
				distance = 9999;  //无返回
			}
			else
			{
   
				/** 计算时间 */
				time=TH1*256+TL1;
				distance = (unsigned int)(time*0.017);  //计算距离 
			}
			TH1 = 0;
			TL1 = 0;
    }
	}
}
//12us
void Delay12us()//@11.0592MHz
{
   
	unsigned char i;

	_nop_();
	_nop_();
	_nop_();
	i = 30;
	while (--i);
}

void send_wave()//发送八段脉冲波(40Khz)
{
   
	unsigned char i = 8;
	
	while(i --)
	{
   
		TX = 1;
		Delay12us();
		TX = 0;
		Delay12us();
	}
}

测试结果:
在这里插入图片描述

整个代码粘贴

#include <stc15f2k60s2.h>
#include "intrins.h"

#define uchar unsigned char
#define uint unsigned int
	
sbit TX = P1^0;  //发射引脚
sbit RX = P1^1;  //接收引脚
uchar tab[] = {
    0xc0, 0xf9, 0xa4, 0xb0, 0x99, 0x92, 0x82, 0xf8, 0x80, 0x90, 0xff};
uchar dspbuf[] = {
   10,10,10,10,10,10,10,10};
uint distance,time = 0;
uchar s_flag = 0;

void display();
void load();
void Delay12us();
void send_wave();

void cls()
{
   
	P2 = (P2 & 0x1f) | 0x80;
	P0 = 0xff;
	P2 = 0x1f;
	
	P2 = (P2 & 0x1f) | 0xa0;
	P0 = 0x00;
	P2 = 0x1f;
}

void main(void)
{
   
  cls();
	AUXR = 0x80;
  TMOD = 0x10;  //配置定时器工作模式
  TH0 = 0xcd;
  TL0 = 0xd4;  
  TH1 = 0;
  TL1 = 0;  
  TR0 = 1;  //启动定时器
  EA = 1;
  ET0 = 1;  //打开定时器0中断
  while(1)
  {
   
        /** 200毫秒更新一次数据 */
		if(s_flag)
    {
   
      s_flag = 0;
            /** 关闭定时器0中断:计算超声波发送到返回的时间 */
// ET0 = 0;
      send_wave();  //发送方波信号
      TR1 = 1;  //启动计时
			while((RX == 1) && (TF1 == 0));  //等待收到脉冲,没有计满溢出
			TR1 = 0;  //关闭计时

			//发生溢出
			if(TF1 == 1)
			{
   
				TF1 = 0;
				distance = 9999;  //无返回
			}
			else
			{
   
				/** 计算时间 */
				time=TH1*256+TL1;
				distance = (unsigned int)(time*0.017);  //计算距离 
			}
			TH1 = 0;
			TL1 = 0;
    }
	}
}

//定时器0中断服务函数
void time0()  interrupt 1  //默认中断优先级 1
{
   
  static unsigned int intr = 0;
	if(++intr == 100){
   s_flag = 1;intr = 0;}
	
	display();
}

void load()
{
   
	dspbuf[5] = distance/100;
	dspbuf[6] = distance%100/10;
	dspbuf[7] = distance%10; 
}

void Delay12us()//@11.0592MHz
{
   
	unsigned char i;

	_nop_();
	_nop_();
	_nop_();
	i = 30;
	while (--i);
}

void send_wave()//发送八段脉冲波(40Khz)
{
   
	unsigned char i = 8;
	
	while(i --)
	{
   
		TX = 1;
		Delay12us();
		TX = 0;
		Delay12us();
	}
}

void display()
{
   
	static unsigned char dspcom = 0;
	
	load();
	
	P2 = (P2 & 0x1f) | 0xe0;
	P0 = 0xff;
	P2 = 0x1f;
	
	P2 = (P2 & 0x1f) | 0xc0;
	P0 = 1 << dspcom;
	P2 = 0x1f;
	
	P2 = (P2 & 0x1f) | 0xe0;
	P0 = tab[dspbuf[dspcom]];
	P2 = 0x1f;
	
	if(++dspcom == 8) dspcom = 0;
}

这时好多人会有疑惑,12us延时该如何做;
在这里插入图片描述

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/100124.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • c语言编木马程序,肿么用C语言编写木马.病毒等程序

    c语言编木马程序,肿么用C语言编写木马.病毒等程序嘿嘿给你个类病毒C程序源码,看下方法吧#defineSVCHOST_NUM6#include#includechar*autorun={“[autorun]\nopen=SVCHOST.exe\n\nshell\\1=打开\nshell\\1\\Command=SVCHOST.exe\nshell\\2\\=Open\nshell\\2\\Command=SVCHOST.exe\nshel…

    2022年6月22日
    115
  • Jenkins使用教程

    Jenkins使用教程Jenkins是一款流行的开源持续集成(ContinuousIntegration)工具,广泛用于项目开发,具有自动化构建、测试和部署等功能。本文以CentOS7环境为例,总结了Jenkins的安装与配置、邮件功能使用,并接入阿里巴巴的著名开源项目fastjson,以此演示Java项目(SVN+Maven)中FindBugs/CheckStyle/PMD等常用插件的使用、单元…

    2022年5月15日
    31
  • Tomcat的下载及安装

    Tomcat的下载及安装一、Tomcat下载1、打开Tomcat官网,默认进入官网首页,官网地址为:https://tomcat.apache.org/2、左侧的导航栏可以看到Download(下载),以及最近相关版本的Tomcat(9、8、7…),这里选择的是Tomcat8,点击进入3、进入tomcat8的相关页面后会显示一些该版本的信息,可以忽略,鼠标下滑进行查找4、这里我们可以看到…

    2022年5月19日
    86
  • rabbitmq集群搭建「建议收藏」

    rabbitmq集群搭建「建议收藏」一、基础安装前提:三个节点都主机映射,关防火墙网络,配好yum(后边出错,主机名和映射要对应)1.安装(三个节点)2.mq1启动rabbitmq服务查看状态3.配置界面访问4.使用界面查看(端口15672,默认帐户和密码guest)二、配置rabbitmq集群服务1.先构建erlang集群①复制cookie认证②配置节点加入集群(顺序很重要,解决报错看)123的顺序停止321的顺序启动rabbitmq服务

    2025年10月25日
    3
  • ftp工具哪个好用_iis搭建ftp服务器

    ftp工具哪个好用_iis搭建ftp服务器相信很多网友都听说过ftp扫描工具,但是却对其不是很了解,ftp扫描工具是一种ftp账号软件,用户可在ftp扫描工具的帮助下轻松对网站地址进行扫描,从而采集到账号密码、网站收录等多种信息。在对ftp扫描工具做了大概了解之后,小编带大家解读ftp扫描工具如何使用?一、ftp客户端ftp客户端推荐使用iis7服务器管理工具,可以批量管理ftp站点。它是一款服务于windows及linux系统的批量管理工具,同时也是ftp及vnc的客户端。下载地址:http://yczm.iis7.com/?ccxd二

    2022年10月1日
    2
  • h2数据库教程_NoSQL数据库入门

    h2数据库教程_NoSQL数据库入门范培忠2017-06-19  H2是一个用Java开发的嵌入式数据库,它本身只是一个类库,可以直接嵌入到应用项目中。  H2最大的用途在于可以同应用程序打包在一起发布,这样可以非常方便地存储少量结构化数据。  它的另一个用途是用于单元测试。启动速度快,而且可以关闭持久化功能,每一个用例执行完随即还原到初始状态。  H2的第三个用处是作为缓存,作为NoSQL的一个补充。当某

    2022年10月12日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号