基于STM32F4的US-100超声波电平触发测距

还是上次那个芯片是STM32F4的iCore板子,上次用了串口,这次使用US-100的电平触发测距

使用电平触发测距,在给模块上电前,先把模式选择那里的跳线帽去掉,datasheet中的介绍如下
电平触发工作方式
在检测到回波信号后开始定时器计时,这样就可以完成测量,代码如下
distance.h

#ifndef __distance_h__
#define __distance_h__
#include "sys.h"

#define Trig PHout(2)

void device_init(void);
float distance(void);

#endif

distance.c

#include "..\include\distance.h"
#include "..\include\sys.h"
#include "..\include\delay.h"
#include "..\include\timer3.h"
#include "..\include\usart.h"
#include "..\fwlib\inc\stm32f4xx_gpio.h"
#include "..\fwlib\inc\stm32f4xx_rcc.h"
#include "..\fwlib\inc\stm32f4xx_tim.h"

//Trig	PH2	右2行2列
//Echo	PH3	右2行1列

void device_init(void)
{
	GPIO_InitTypeDef  GPIO_InitStructure;

	RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOH, ENABLE);//使能GPIOH时钟

	//GPIOF9,F10初始化设置
	GPIO_InitStructure.GPIO_Pin = GPIO_Pin_2;
	GPIO_InitStructure.GPIO_Mode = GPIO_Mode_OUT;//普通输出模式
	GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;//推挽输出
	GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP;          //上拉
	GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;//50MHz
	GPIO_Init(GPIOH, &GPIO_InitStructure);//初始化
	GPIO_ResetBits(GPIOH,GPIO_Pin_2);

	
	GPIO_InitStructure.GPIO_Pin = GPIO_Pin_3;
	GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN;//普通输入模式
	GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL;//
	GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;//50MHz
	GPIO_Init(GPIOH, &GPIO_InitStructure);//初始化

}
float distance(void)
{
	float length = 0,sum = 0;
	float tim;
	unsigned int i = 0;
	while(i != 5)
	{
		GPIO_SetBits(GPIOH,GPIO_Pin_2);
		delay_us(20);
		GPIO_ResetBits(GPIOH,GPIO_Pin_2);
		
		while(GPIO_ReadInputDataBit(GPIOH,GPIO_Pin_3) == RESET);	//等待高电平
		TIM_Cmd(TIM3,ENABLE);
		while(GPIO_ReadInputDataBit(GPIOH,GPIO_Pin_3) == SET);		//等待低电平
		TIM_Cmd(TIM3,DISABLE);
		
		
		tim = TIM_GetCounter(TIM3);
		length = (tim + counter*1000)/1000*170;		//(定时器不满一次计数 + 重装载次数 * 重装载数)(us)/1000/1000(s)*(340000(mm)/2)
		i += 1;
		sum = length + sum;
		TIM3->CNT = 0;
		counter = 0;
		delay_ms(20);
	}
	length = sum/5;
	return length;
}

计算方式那里,我的定时器设置的是1us加一次,重装1000次,这样每次计数就是1ms,得到了length的公式,然后计5次取平均值,大家可以根据自己定时器适当修改公式
然后是main函数

int main(void)
{
	delay_init(168);
	
	float i;
	char buffer[20];
	led.initialize();
	timer3.initialize();
	device_init();
	EXTIX_Init();
	usart4.initialize(9600);
	usart4.printf("初始化完成\r\n");        //串口4输出
	while(1)
	{
		PIout(5) = !PIout(5);
		i = distance();
		usart4.printf("dis:%f mm\r\n",i);
		delay_ms(1000);
	}
}
  • 1
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
您好!对于基于STM32F4超声波测距,您可以按照以下步骤进行操作: 1. 硬件连接:将超声波传感器的Trig引脚连接到STM32F4的一个GPIO引脚,Echo引脚连接到另一个GPIO引脚。同时,将传感器的Vcc引脚连接到STM32F4的3.3V电源,GND引脚连接到STM32F4的地线。 2. 初始化GPIO:使用STM32CubeMX或者手动编写代码,初始化STM32F4的GPIO引脚,设置Trig引脚为输出模式,Echo引脚为输入模式。 3. 定时器配置:使用STM32CubeMX或手动编写代码,配置一个定时器,用于测量Echo引脚的高电平时间。 4. 发送触发信号:将Trig引脚置高一段时间,然后再置低,以触发超声波传感器发送出一段超声波。 5. 测量回波时间:启动定时器,并等待Echo引脚变高。当Echo引脚变高时,使用定时器的计数器值来计算回波时间。 6. 距离计算:根据声速和回波时间,可以计算出物体与传感器之间的距离。通常情况下,声速为340m/s。 7. 数据处理:根据需要,您可以对测量到的距离进行进一步处理,例如显示在LCD上或者通过串口发送至PC。 请注意,以上步骤仅为简单的示例,具体的实现方式可能因您使用的超声波传感器、开发环境和工具链等因素而有所不同。在实际应用中,您可能还需要考虑到传感器的精度、噪声滤波、多次测量取平均等问题。希望对您有所帮助!如果您有任何进一步的问题,请随时提问。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值