STM32——超声波模块

模块介绍

超声波模块一般使用的都是HC-SR04来进行测距

1)产品特点

HC-SR04 超声波测距模块可提供 2cm-400cm 的非接触式距离感测功能,测
距精度可达高到的非接触式距离感测功能,测距精度可达高到 3mm ;模块包括超声波发射器、接收器与控制电路。

2)基本工作原理

(1)采用 IO 口 TRIG 触发测距,给最少 10us 的高电平信呈。
(2)模块自动发送 8 个 40khz 的方波,自动检测是否有信号返回;
(3)有信号返回,通过 IO 口 ECHO 输出一个高电平,高电平持续的时间就是超声
波从发射到返回的时间。测试距离=(高电平时间*声速(340M/S))/2;

3)接线

  • Vcc:+5V电源供电
  • Trig:输入触发信号(可以触发测距)
  • Echo:传出信号回响(可以传回时间差)
  • Gnd:接地

2.超声波工作原理

在这里插入图片描述

二,编程要点

1)触发信号Trig很简单直接通过IO输出和延时给一个大于10us的高电平即可触发。Echo引脚需要接收并记录高电平的持续时间。
2)思路讲解:在发送触发信号后,Echo响应后(上升沿)触发外部中断,开启定时器计时直到Echo变为低电平,关闭定时器记录下计时时间。

三,HC-SR04超声波模块程序设计

    在了解了上述内容后,我们便可以根据上述知识便可以编写驱动程序了。触发信号Trig很简单直接通过IO输出和延时给一个大于10us的高电平即可触发。Echo引脚需要接收并记录高电平的持续时间,大致有3种实现的思路:

(1)在发送触发信号后一直等待Echo引脚的响应(变为高电平)并打开定时器计时直到Echo变为低电平,关闭定时器记录下计时时间。

(2)在发送触发信号后,Echo响应后(上升沿)触发外部中断,开启定时器计时直到Echo变为低电平,关闭定时器记录下计时时间。

(3)在发送触发信号后,通过定时器的输入捕获引脚抓取Echo引脚上升沿,开启定时器计时直到Echo变为低电平,关闭定时器记录下计时时间。

第一种方式完全在主进程中完成,比较占用主进程资源,比较适合于超声波模块的测试应用。第二种和第三种方式在主进程中发送触发信号中断中处理接收计算距离比较适合于实际项目的应用。

 下面为第二种方式的驱动程序:

hc_sr04.h

#ifndef __HC_SR04_H
#define __HC_SR04_H
 
#include "stm32f10x.h"
 
#define HC_SR04_TRIG_CLK   RCC_APB2Periph_GPIOA
#define HC_SR04_TRIG_PORT  GPIOA
#define HC_SR04_TRIG_PIN   GPIO_Pin_4
 
#define HC_SR04_ECHO_CLK   RCC_APB2Periph_GPIOA
#define HC_SR04_ECHO_PORT  GPIOA
#define HC_SR04_ECHO_PIN   GPIO_Pin_5
 
#define HC_SR04_ECHO_EXTI_PORT_SOURCE   GPIO_PortSourceGPIOA
#define HC_SR04_ECHO_EXTI_PIN_SOURCE  GPIO_PinSource5
 
extern float Distance;
 
 
void HC_SR04_init(void);
void HC_SR04_start(void);
 
 
#endif /* __HC_SR04_H*/

hc_sr04.c

#include "hc_sr04.h"
#include "delay.h"
#include "usart.h"
#include "timer.h"
 
float Distance;
 
 
 
void HC_SR04_init(void)
{
	GPIO_InitTypeDef  GPIO_InitStructure;
	EXTI_InitTypeDef EXTI_InitStructure;
	NVIC_InitTypeDef NVIC_InitStructure;
 
	RCC_APB2PeriphClockCmd(HC_SR04_TRIG_CLK, ENABLE);	 //使能PC端口时钟
	RCC_APB2PeriphClockCmd(RCC_APB2Periph_AFIO,ENABLE);//外部中断,需要使能AFIO时钟
 
	GPIO_InitStructure.GPIO_Pin = HC_SR04_TRIG_PIN;				 // 脉冲触发端口(Trig)配置
	GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP; 		 //推挽输出
	GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;		 //IO口速度为50MHz
	GPIO_Init(HC_SR04_TRIG_PORT, &GPIO_InitStructure);					 //根据设定参数初始化端口
	//GPIO_ResetBits(HC_SR04_TRIG_PORT,HC_SR04_TRIG_PIN);						 //端口初始化为低电平
 
	GPIO_InitStructure.GPIO_Pin = HC_SR04_ECHO_PIN;				 // 回波接收端口(Echo)配置
	GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IPD; 		 //上拉输入
	GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;		 //IO口速度为50MHz
	GPIO_Init(HC_SR04_ECHO_PORT, &GPIO_InitStructure);					 //根据设定参数初始化端口
 
 
	//接收端口 中断线以及中断初始化配置
	GPIO_EXTILineConfig(GPIO_PortSourceGPIOA,GPIO_PinSource5);
 
	EXTI_InitStructure.EXTI_Line=EXTI_Line5;
	EXTI_InitStructure.EXTI_Mode = EXTI_Mode_Interrupt;	
	EXTI_InitStructure.EXTI_Trigger = EXTI_Trigger_Rising;//上升沿触发
	EXTI_InitStructure.EXTI_LineCmd = ENABLE;
	EXTI_Init(&EXTI_InitStructure);	 	//根据EXTI_InitStruct中指定的参数初始化外设EXTI寄存器
 
	NVIC_InitStructure.NVIC_IRQChannel = EXTI9_5_IRQn;			//使能按键所在的外部中断通道
	NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0x02;	//抢占优先级2, 
	NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0x01;					//子优先级1
	NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;								//使能外部中断通道
	NVIC_Init(&NVIC_InitStructure);
 
	TIM3_Int_Init(49999,7199);  //初始化TIM3定时器,计数一次为1/10000S(0.1ms),每500ms触发一次定时中断
  //TIM_Cmd(TIM3,DISABLE);
}
	
//发送20us的脉冲触发信号
void HC_SR04_start(void)
{
	GPIO_SetBits(HC_SR04_TRIG_PORT,HC_SR04_TRIG_PIN);
	delay_us(20);
	GPIO_ResetBits(HC_SR04_TRIG_PORT,HC_SR04_TRIG_PIN);
	delay_ms(10);
}
 
 
 
void EXTI9_5_IRQHandler(void)
{			
	delay_us(10);
	
	if(EXTI_GetITStatus(EXTI_Line5) != RESET)
	{
		//while(GPIO_ReadInputDataBit(GPIOA,GPIO_Pin_5) == RESET);
		TIM_SetCounter(TIM3,0);  //计数清零
		TIM_Cmd(TIM3,ENABLE);  //使能TIM3定时器
		
		while(GPIO_ReadInputDataBit(GPIOA,GPIO_Pin_5));  //等待电平变为低电平
		
		TIM_Cmd(TIM3,DISABLE); //关闭定时器
		
		Distance = TIM_GetCounter(TIM3)*340/200.0;  //计算距离:cnt * 1/10000 * 340 / 2(单位:m)
		
		//printf("Counter:%d\n",TIM_GetCounter(TIM3));
		printf("Distance:%f cm\r\n",Distance);
			
		EXTI_ClearITPendingBit(EXTI_Line5);
	}  
}
 

  • 22
    点赞
  • 179
    收藏
    觉得还不错? 一键收藏
  • 8
    评论
HC-SR04超声波测距模块是一种常用的测距传感器,可以通过发送超声波脉冲并接收回波信号来测量距离。在STM32库函数版中,可以通过以下步骤来使用HC-SR04超声波测距模块: 1. 首先,需要包含"sys.h"头文件,并初始化HC_SR04超声波模块,可以使用HC_SR04_Init()函数进行初始化。\[1\] 2. 在测距之前,需要向Trig控制端输入至少10us的高电平触发信号,可以使用HC_SR04_start()函数发送20us的脉冲触发信号。\[1\] 3. HC-SR04模块内部会发送8个40KHz的方波并检测回波信号,一旦检测到回波信号,Echo接收端会输出高电平回响信号,高电平的持续时间就是超声波从发射到返回的时间。根据公式:距离=高电平时间*声速(340M/S)/2,可以计算出测得的距离。\[2\] 总结来说,使用STM32库函数版的HC-SR04超声波测距模块,需要初始化模块并发送触发信号,然后根据回响信号的高电平时间计算出距离。 #### 引用[.reference_title] - *1* *2* [STM32——库函数版——超声波测距模块](https://blog.csdn.net/qq_45844792/article/details/111215858)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [STM32连接HC-SR04超声波测距(结合STM32CubeMX和HAL库函数)](https://blog.csdn.net/wuwenbin12/article/details/118575989)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值