超声波模块SR04使用配置

模块介绍

该模块有四个引脚,两个通信引脚,两个电源引脚。

按照官方手册时序图进行配置GPIO 以及获取高电平时间即可算出模块回响距离

时序图

图中TRIG为信号触发引脚,设置GPIO为输入模式

图中ECHO为信号回响引脚,设置GPIO为输出模式

代码

SR04.c

#include "SR04.h"

void SR04_init(void)
{
    /* 硬件使能 */
    RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE);
    RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM2, ENABLE);

    /* GPIO */
    GPIO_InitTypeDef GPIO_InitStruct;
    GPIO_InitStruct.GPIO_Mode = GPIO_Mode_Out_PP;
    GPIO_InitStruct.GPIO_Pin = GPIO_Pin_2;
    GPIO_InitStruct.GPIO_Speed = GPIO_Speed_50MHz;
    GPIO_Init(GPIOA, &GPIO_InitStruct);
    GPIO_InitStruct.GPIO_Mode = GPIO_Mode_IN_FLOATING; // 浮空
    GPIO_InitStruct.GPIO_Pin = GPIO_Pin_3;
    GPIO_InitStruct.GPIO_Speed = GPIO_Speed_50MHz;
    GPIO_Init(GPIOA, &GPIO_InitStruct);

    /* 初始化定时器 */
    TIM_InternalClockConfig(TIM2);
    TIM_TimeBaseInitTypeDef TIM_TimeBaseInitStruct;
    TIM_TimeBaseInitStruct.TIM_ClockDivision = TIM_CKD_DIV1;
    TIM_TimeBaseInitStruct.TIM_CounterMode = TIM_CounterMode_Up;
    TIM_TimeBaseInitStruct.TIM_Period = 50000; // 周期  
    TIM_TimeBaseInitStruct.TIM_Prescaler = 72; // 预分频器
    TIM_TimeBaseInitStruct.TIM_RepetitionCounter = 0;
    TIM_TimeBaseInit(TIM2, &TIM_TimeBaseInitStruct);

    /* 不开启定时器 */
    TIM_Cmd(TIM2, DISABLE);
}

uint16_t SR04_get_distance(void)
{
    uint16_t temp;
    uint16_t distance;

    // PA2输出低电平
    GPIO_WriteBit(GPIOA, GPIO_Pin_2, 0);
    Delay_us(8);

    /* PA2输出高电平 */
    GPIO_WriteBit(GPIOA, GPIO_Pin_2, 1);
    Delay_us(20);

    /* PA2输出低电平 */
    GPIO_WriteBit(GPIOA, GPIO_Pin_2, 0);

    /* 将计数值设置为0 */
    TIM2->CNT = 0;

    /* 等待PA3高电平到来 */
    while (GPIO_ReadInputDataBit(GPIOA, GPIO_Pin_3) == 0)
    {
    }

    /* 使能定时器计数 */
    TIM_Cmd(TIM2, ENABLE);

    /* 等待PA3低电平到来 */
    while (GPIO_ReadInputDataBit(GPIOA, GPIO_Pin_3) == 1)
    {
    }

    /* 记录计数值 */
    temp = TIM2->CNT;

    /* 关闭定时器 */
    TIM_Cmd(TIM2, DISABLE);

    /* 通过公式计算超声波距离 */
    /* 此时单位为cm */
    distance = temp / 58;

    return distance;
}

SR04.h

#ifndef __SR04_H_
#define __SR04_H_

#include "stm32f10x.h"
#include "Delay.h"

void SR04_init(void);
uint16_t SR04_get_distance(void);

#endif

main.c

#include "stm32f10x.h" // Device header
#include "Delay.h"
#include "OLED.h"
#include "SR04.h"

int main(void)
{
	uint16_t distance = 0;

	OLED_Init();
	SR04_init();

	while (1)
	{

		/* 获取距离 */
		distance = SR04_get_distance();

		/* 显示距离参数 */
		OLED_ShowString(1, 1, "distance:");
		OLED_ShowNum(1, 10, distance, 4);
		Delay_ms(200);
	}
}

  • 10
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
HC-SR04超声波模块32下载是指下载HC-SR04超声波模块在32位微控制器上运行所需要的相应驱动程序或者代码。HC-SR04超声波模块是一种常见的测距传感器,通过发射超声波并接收其回波来测量与目标物体的距离。32位微控制器是一种高性能的嵌入式处理器,能够提供更强大的计算能力和更多的内存空间。 要实现HC-SR04超声波模块在32位微控制器上的运行,首先需要找到对应的驱动程序或者代码。可以通过互联网搜索HC-SR04超声波模块在32位微控制器上的驱动程序或者示例代码,通常这些资源可以在相关的开发者论坛、技术社区或者官方网站上找到。 下载驱动程序或者代码后,将其导入到开发环境中。通常,32位微控制器的开发环境会提供相应的工具和接口来导入和配置外部驱动程序。根据开发工具的不同,将下载的驱动程序或者代码添加到项目中,并进行相应的配置和编译,以便在32位微控制器上正确运行HC-SR04超声波模块。 一旦配置和编译完成,就可以通过编写适当的代码来控制HC-SR04超声波模块在32位微控制器上的操作。通过读取模块的引脚状态或者使用相应的库函数,可以实现超声波的发射和接收,并计算出目标物体与模块的距离。 总之,HC-SR04超声波模块32下载是指在32位微控制器上下载相应的驱动程序或者代码,以实现超声波模块的正常工作。下载完成后,需要导入、配置和编译驱动程序,然后编写适当的代码来控制模块的操作,并实现距离测量功能。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值