迪文科技论坛

 找回密码
 立即注册
搜索
查看: 213|回复: 1

【分享】声声慢超声波测距离运用到广泛的领域

[复制链接]

1

主题

0

回帖

30

积分

新手上路

Rank: 1

积分
30
发表于 2024-1-22 19:54:26 | 显示全部楼层 |阅读模式
一、使用的材料

1.开发使用的开发板EKT043E和超声波传感器

二、超声波时序图

三、工作原理
采用Trig引脚触发,给至少10us的高电平脉冲信号,模块自动发送8个40kHz的方波,自动检测是否有信号返回有信号返回,
通过Echo引脚输出一个高电平脉冲,高电平脉冲持续的时间就是超声波从发射到反射返回的时间可以通过定时器算出。
距离=(高电平脉冲时间*340)/2。超声波在空中的时间就是TH1和TL1合并起来表示定时器1的总计数值。
四、设计思路
1.迪文屏和超声波传感器硬件电路连接:Trig连接P2^1, Echo连接P2^0, VCC连接5V, GND接地
2.代码编写
配置文件
P2MDOUT = 0x02; //开TRIG、ECHO P2.0和P2.1为推挽输出
PORTDRV = 0x02; //输出电流16mA
触发蜂鸣器
sys_write_vp(0x00A0,(u8*)&str,1);//调用sys_write_vp函数,16进制的转换(调整至蜂鸣器报警)
五、UI设计

生成32.icl文件,设置地址变量2000x。
六、代码展示(添加注释版)
  1. #include "sys.h"
  2. #include "stdio.h"

  3. //// 使用位寻址寄存器定义 TRIG 和 ECHO 为位变量
  4. sbit TRIG = P2^1;//TRIG引脚
  5. sbit ECHO = P2^0;//ECHO引脚

  6. //全局变量
  7. float distance1,time;//一开始算出的距离是一个浮点数
  8. u16 distance[5];//一个距离的数组(用于求出距离的平均值,更加精确)
  9. u16 distance2;//将第一个算出的距离浮点型进行转换成整型
  10. u16 valu;//变量(初始值)
  11. u16 str[1];//长度为1的数组(16进制转换,触发蜂鸣器)
  12. u8 j;//计数器
  13. u16 i;//状态的标志(距离小于15 i为1,通过 sys_write_vp() 函数,报警和写入内存 距离大于15,i为0)
  14. //初始化定时器1进行延迟
  15. void time1_init()   //定时0s
  16. {
  17.         TMOD &= 0X0F;        //清除TOMD的前四位
  18.         TMOD |= 0X10;        //定时器选择16位
  19.         TR1 = 0; //停止定时器1
  20.         ET1 = 1; //启动定时器1中断
  21.         EA        = 1;//启动全局中断

  22.         TH1 = 0;//初始化定时器1高字节
  23.         TL1 = 0;//初始化定时器1低字节
  24. }

  25. //初始化HC-SR04超声波传感器引脚(配置)
  26. void hc_sr04_init()
  27. {
  28.         P2MDOUT = 0x02; //开TRIG、ECHO P2.0和P2.1为推挽输出
  29.         PORTDRV = 0x02; //输出电流16mA
  30. }
  31. //使用HC_SR04传感器测量距离
  32. void wite_distence(){
  33.         u8 k;
  34.         k=0;
  35.   for(k;k<5;k++) {
  36.         TRIG = 0;//将 TRIG 引脚置为逻辑低电平。这个步骤是为了确保超声波发射器开始时处于空闲状态。
  37.         TRIG = 1;//将 TRIG 引脚置为逻辑高电平。这个步骤触发了超声波发射器,开始发送超声波脉冲。
  38.         sys_delay_about_us(20);//
  39.         TRIG = 0;        //将 TRIG 引脚再次置为逻辑低电平,停止触发,结束超声波的脉冲发送。
  40.                 /*****************测距***************/
  41.         while(ECHO==0);//等待超声波发射并被目标反射回来(已经发射)
  42.         TR1 = 1;// ECHO 引脚状态为逻辑高电平,定时器1开始计时
  43.         while(ECHO==1);//等待超声波的返回脉冲结束(已返回)
  44.         TR1 = 0;// ECHO 引脚状态为逻辑低电平,停止计时。
  45.         //即:TH1和TL1合并起来表示定时器1的总计数值(超声波的飞行时间)
  46.         distance1 = 9/(11.0592*14)*0.017*(TH1*256+TL1);
  47.          sys_delay_about_us(20);//
  48.             distance[k]=(u16)(distance1*100);//将距离数组乘以100,转换成整型
  49.                  distance2+=distance[k];//在一个for循环中,将每一次算出的距离放到整型距离中
  50.                         sys_delay_ms(20);//
  51.         }
  52. }
  53. //对HC-SR04数据进行处理并发出警报的条件
  54. void hc_sr04()
  55. {
  56.         distance2 /= 5; //平均值(测量五次取其中的平均值)
  57.         sys_delay_about_us(5);//延迟
  58.         
  59.         /*****************报警***************/
  60.                 sys_write_vp(0x2000,(u8*)&distance2,1);        //调用sys_write_vp函数将求出的平均值发送到我们自己给的特定内存地址(0X2000)
  61.                
  62.                 sys_delay_about_us(50);//延迟
  63.         if(distance2<1500)                                                                                                                        //小于15cm
  64.         {
  65.                 while(j)//距离满足小于15,j的值就会从20递减到0,延时的一个效果
  66.                         j--;
  67.                 i=1;
  68.                 sys_write_vp(0x5000,(u8*)&i,1);//调用sys_write_vp函数将i给特定内存地址(0X5000)发送信号               
  69.                 sys_delay_ms(6);//延迟
  70.                 sys_write_vp(0x00A0,(u8*)&str,1);//调用sys_write_vp函数,16进制的转换(调整至蜂鸣器报警)
  71.           j=20;//一共是循环20次,相当于一个延迟的操作
  72.         }else{//大于15cm
  73.                 i=0;
  74.                 sys_delay_ms(6);//延迟
  75.           sys_write_vp(0x5000,(u8*)&i,1);//调用sys_write_vp函数将i给特定内存地址(0X5000)发送信号,但是不触发警报
  76.         }
  77.         distance2 = 0;//经过一次数据处理后重新给距离赋值0
  78.         //将定时器1的计数值清零
  79.         TH1 = 0;
  80.         TL1 = 0;
  81. }

  82. void main(void)
  83. {

  84.         sys_init();//系统初始化
  85.         time1_init();//定时器1初始化
  86.         hc_sr04_init();//初始化HC-SR04超声波传感器引脚(配置)
  87.         valu=200;//初始值
  88.         i=0;//初始化0,后面进行一个无限循环
  89.         str[0]=0x10;//数组,第一个元素初始化为0x10
  90.         while(1)//无限循环
  91.         {
  92.                 wite_distence();//调用HC_SR04传感器测量距离函数   
  93.                 sys_delay_about_us(50);
  94.                 hc_sr04();//调用对HC-SR04数据进行处理并发出警报的条件函数
  95.                 sys_delay_about_us(50);
  96.   }
  97. }
  98. void time1() interrupt 3
  99. {
  100.         
  101. }
复制代码


[url=]声声慢超声波测距.zip[/url]

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0

主题

2

回帖

37

积分

新手上路

Rank: 1

积分
37
发表于 2024-1-23 12:04:16 | 显示全部楼层
哇塞,这个写的太详细了吧,谢谢楼主的代码。
回复

使用道具 举报

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

本版积分规则

QQ|Archiver|手机版|小黑屋|迪文科技论坛 ( 京ICP备05033781号-1 )

GMT+8, 2024-11-25 20:47 , Processed in 0.067374 second(s), 24 queries .

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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