树莓派3 + HC-SR04超声波测距模块+LED报警

最终代码

# 适用于树莓派3b+HC-SR04
import RPi.GPIO as GPIO
import time

TRIG = 23  # 4
ECHO = 24  # 17
RED_LED = 26
pwm = None
INTERVAL = 5


def distanceInit():
    GPIO.setwarnings(False)
    #GPIO.setmode(GPIO.BCM)#该模式下LED常亮
    GPIO.setmode(GPIO.BOARD) #该模式下LED闪烁三次,闪烁结束后再次测量距离
    GPIO.setup(TRIG, GPIO.OUT)
    GPIO.setup(ECHO, GPIO.IN)


def distanceStart():
    # 发送trig信号,持续10us的方波脉冲
    GPIO.output(TRIG, 1)
    time.sleep(0.0001)
    GPIO.output(TRIG, 0)
#    print('1')


def wait_for_echo(value, timeout):
    count = timeout
    # 通过该代码持续获取ECHO的状态
    while GPIO.input(ECHO) != value and count > 0:
        count = count - 1


'''
计算距离
'''


def get_distance():
    # 发射
    distanceStart()
    # 接收高电平 1/True
    wait_for_echo(True, 1000)
    # 等待
    start = time.time()
    # 接收低电平
    wait_for_echo(False, 1000)
    finish = time.time()
    pulse_len = finish - start
    # distance_cm = pulse_len/0.0000058
    distance = (pulse_len * 3430000) / 2
    return distance

def ledStart():
    global pwm
    GPIO.setup(RED_LED, GPIO.OUT)
    GPIO.output(RED_LED, GPIO.HIGH)
    #print('3')
    # 创建一个 PWM 实例,需要两个参数,第一个是GPIO端口号,这里我们用26号
    # 第二个是频率(Hz),频率越高LED看上去越不会闪烁,相应对CPU要求就越高,设置合适的值就可以
    pwm = GPIO.PWM(RED_LED, 60)


    # 启用PWM,参数是占空比,范围:0.0<=占空比<=100.0
    pwm.start(0)
    for i in range(3):
        # 电流从小到大,LED由暗到亮
        for i in range(101):
            # 更改占空比
            pwm.ChangeDutyCycle(i)
            time.sleep(0.02)

        # 电流从大到小,LED由亮变暗
        for i in range(100, -1, -1):
            pwm.ChangeDutyCycle(i)
            time.sleep(0.02)
    pwm.stop()


try:
    distanceInit()
    while True:
        distance = get_distance()
        print("Distance:{}cm".format(distance))
        if distance < 17:
            print('2')
            ledStart()
        time.sleep(INTERVAL)
except KeyboardInterrupt:
    if pwm != None:
        pwm.stop()
    GPIO.cleanup()

树莓派接线如下:在这里插入图片描述
在这里插入图片描述

参考代码1:传感器

# 适用于树莓派3b+HC-SR04
import RPi.GPIO as GPIO
import time

TRIG = 23  # 4
ECHO = 24  # 17
RED_LED = 26
pwm = None
INTERVAL = 5


def distanceInit():
    print('Distance Measurement In Progress')
    GPIO.setwarnings(False)
    GPIO.setmode(GPIO.BCM)
    GPIO.setup(TRIG, GPIO.OUT)
    GPIO.setup(ECHO, GPIO.IN)


def distanceStart():
    # 发送trig信号,持续10us的方波脉冲
    GPIO.output(TRIG, 1)
    time.sleep(0.0001)
    GPIO.output(TRIG, 0)
#    print('1')


def wait_for_echo(value, timeout):
    count = timeout
    # 通过该代码持续获取ECHO的状态
    while GPIO.input(ECHO) != value and count > 0:
        count = count - 1


'''
计算距离
'''


def get_distance():
    # 发射
    distanceStart()
    # 接收高电平 1/True
    wait_for_echo(True, 1000)
    # 等待
    start = time.time()
    # 接收低电平
    wait_for_echo(False, 1000)
    finish = time.time()
    pulse_len = finish - start
    # distance_cm = pulse_len/0.0000058
    distance = (pulse_len * 3430000) / 2
    return distance

def ledStart():
    global pwm
    GPIO.setup(RED_LED, GPIO.OUT)
    # 创建一个 PWM 实例,需要两个参数,第一个是GPIO端口号,这里我们用26号
    # 第二个是频率(Hz),频率越高LED看上去越不会闪烁,相应对CPU要求就越高,设置合适的值就可以
    pwm = GPIO.PWM(RED_LED, 60)

    # 启用PWM,参数是占空比,范围:0.0<=占空比<=100.0
    pwm.start(0)
    for i in range(3):
        # 电流从小到大,LED由暗到亮
        for i in range(101):
            # 更改占空比
            pwm.ChangeDutyCycle(i)
            time.sleep(0.02)

        # 电流从大到小,LED由亮变暗
        for i in range(100, -1, -1):
            pwm.ChangeDutyCycle(i)
            time.sleep(0.02)
    pwm.stop()


try:
    distanceInit()
    while True:
        distance = get_distance()
        print("Distance:{}cm".format(distance))
        if distance < 10:
            ledStart()
        time.sleep(INTERVAL)
except KeyboardInterrupt:
    if pwm != None:
        pwm.stop()
    GPIO.cleanup()

参考代码2:传感器

#导入 GPIOimport RPi.GPIO as GPIO
import time
  
#设置 GPIO 模式为 BCM
GPIO.setwarnings(False)
GPIO.setmode(GPIO.BCM)
  
#定义 GPIO 引脚
GPIO_TRIGGER = 23
GPIO_ECHO = 24
  
#设置 GPIO 的工作方式 (IN / OUT)
GPIO.setup(GPIO_TRIGGER, GPIO.OUT)
GPIO.setup(GPIO_ECHO, GPIO.IN)
  
def distance():
    # 发送高电平信号到 Trig 引脚
    GPIO.output(GPIO_TRIGGER, True)
  
    # 持续 10 us 
    time.sleep(0.00001)
    GPIO.output(GPIO_TRIGGER, False)
  
    start_time = time.time()
    stop_time = time.time()
  
    # 记录发送超声波的时刻1
    while GPIO.input(GPIO_ECHO) == 0:
        start_time = time.time()
  
    # 记录接收到返回超声波的时刻2
    while GPIO.input(GPIO_ECHO) == 1:
        stop_time = time.time()
  
    # 计算超声波的往返时间 = 时刻2 - 时刻1
    time_elapsed = stop_time - start_time
    # 声波的速度为 343m/s, 转化为 34300cm/s。
    distance = (time_elapsed * 34300) / 2
  
    return distance
  
if __name__ == '__main__':
    try:
        while True:
            dist = distance()
            print("Measured Distance = {:.2f} cm".format(dist))
            time.sleep(1)
  
        # Reset by pressing CTRL + C
    except KeyboardInterrupt:
        print("Measurement stopped by User")
        GPIO.cleanup()

参考代码3:LED

# -*- coding: utf-8 -*-                     #通过声明可以在程序中书写中文
import RPi.GPIO as GPIO                     #引入RPi.GPIO库函数命名为GPIO
import time                                 #引入计时time函数
# BOARD编号方式,基于插座引脚编号
GPIO.setmode(GPIO.BOARD)                    #将GPIO编程方式设置为BOARD模式
# 输出模式
GPIO.setup(11, GPIO.OUT)                    #将GPIO引脚11设置为输出引脚

while True:                                 # 条件为真,下面程序一直循环执行     
        GPIO.output(11, GPIO.HIGH)          #将11引脚电压置高,点亮LED灯
        time.sleep(1)                       #延时1GPIO.output(11, GPIO.LOW)           #将11引脚电压置低,熄灭LED灯
        time.sleep(1)                       #延时1

参考代码1:https://blog.csdn.net/qq_36365528/article/details/108256742
参考代码2:https://shumeipai.nxez.com/2019/01/02/hc-sr04-ultrasonic-ranging-module-on-raspberry-pi.html
参考代码3:https://blog.csdn.net/weixin_43073852/article/details/82803314

  • 2
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
了解如何使用Raspberry Pi 4B进行超声波测距项目。 硬件部件: Raspberry Pi 4 B型×1个 超声波传感器-HC-SR04(通用)×1个 LED条形图阵列,绿色×1个 高亮度LED,白色×1个 4位7段LED显示屏×1个 电阻1k欧姆×1个 电阻2.21k欧姆×1个 电阻100欧姆×8 通孔电阻,150 ohm×10 电阻330欧姆×1个 无焊面包板全尺寸×1个 声音由通过介质(例如空气)的振荡波组成,其音高由这些波彼此之间的接近程度(频率)确定。人耳只能听到某些频谱(声波频率范围),这被定义为“声学”范围。低于声音的极低频声音被定义为“次声”,而高于声音的高频声音被定义为“超声”。 超声波传感器被设计为使用类似于雷达的超声波反射来感测物体的接近或范围,以计算反射传感器与固体物体之间的超声波所花费的时间。主要使用超声波是因为它无法被人耳听到,并且在短距离内相对准确。您当然可以为此使用声学声音,但是您将拥有一个嘈杂的机器人,每隔几秒钟会发出哔哔声……。 基本的超声波传感器由一个或多个超声波发射器(基本上是扬声器),接收器和控制电路组成。发射器发出高频超声波,该超声波会从附近的任何固体物体上反弹。某些超声波噪声被传感器上的接收器反射并检测到。然后,该返回信号由控制电路处理,以计算正在发送和接收的信号之间的时间差。随后可以将此时间与一些聪明的数学一起用于计算传感器与反射对象之间的距离。 我们将在本教程中为Raspberry Pi使用的HC-SR04超声波传感器具有四个引脚:接地(GND),回波脉冲输出(ECHO),触发脉冲输入(TRIG)和5V电源(Vcc)。我们使用Vcc为模块供电,使用GND将其接地,然后使用Raspberry Pi将输入信号发送到TRIG,这将触发传感器发送超声波脉冲。脉冲波从附近的任何物体反弹,并且一些反射回传感器。传感器检测到这些返回波,并测量触发和返回脉冲之间的时间,然后在ECHO引脚上发送5V信号。 在收到回波脉冲后,传感器被触发之前,ECHO将为“低”(0V)。找到返回脉冲后,在该脉冲持续时间内,将ECHO设置为“高”(5V)。脉冲持续时间是指传感器输出超声波脉冲与传感器接收器检测到返回脉冲之间的完整时间。因此,我们的Python脚本必须测量脉冲持续时间,然后从中计算出距离。 HC-SR04上的传感器输出信号(ECHO)的额定值为5V。但是,Raspberry Pi GPIO上的输入引脚的额定电压为3.3V。向该不受保护的3.3V输入端口发送5V信号可能会损坏您的GPIO引脚,这是我们要避免的事情!我们需要使用一个由两个电阻组成的小型分压器电路,以将传感器输出电压降低到我们的Raspberry Pi可以处理的水平。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值