HCSR04 With Built in RGB LED RUS-04 Module

by mahmoodmustafashilleh in Circuits > Sensors

1122 Views, 3 Favorites, 0 Comments

HCSR04 With Built in RGB LED RUS-04 Module

3.jpg
8.jpg
Screen Shot 2023-01-20 at 8.25.22 AM.png

Background:

The HC-SR04 5V Ultrasonic Sensor is one of the most popular robotic sensors used to measure distance in DIY applications for Raspberry Pi and Arduino. It is very easy to use and has just 4 pins.

I found this new version of the sensor online that is essentially the same thing, except it has an RGB input that allows for a beautiful display of colors within the transmitter and receiver cylinders, containing a total of 6 LEDs (3 per cylinder). This is essentially the same sensor as the RUS-04 (which you can find with a google search).

Using the ultrasonic module was super easy as there are many examples online of how to use it with MicroPython and the Pico W because it works the same as the regular HC-SR04. However, in terms of the RGB module, it took me some digging to figure it out because nobody has used this sensor in MicroPython given that it is relatively new.

After some research, I realized that the only example of this sensor online was this gentleman who demonstrated how to use it with Arduino... but I needed it for MicroPython. I eventually found out it followed the WS2812 lighting standard so I eventually found a library I slightly modified for the Pico W which I link here:

Github Link For NeoPixel Library for Raspberry Pi Pico W

But do not be discouraged if you are not using the Pico or Arduino, WS2812 capable libraries are found all over the internet for different devices and coding languages. It is a pretty popular standard so you should not have issues if you are using other forms of the Raspberry Pi or any other controllers with GPIO capability. Even an amateur hobbyist like me could figure it out, and so could you ;)

I thought I would share the code I used and explain it, which will help people use this low-documented device in the future. I encourage hobbyists to get this sensor for a visual effect.

Other Important Notes:

Like the regular HC-SR04, this uses 5V logic, using the Pico or Pico W, which are 3.3 V devices is not recommended without a 5V power supply and voltage shifters. Otherwise, you can risk damaging your device and also having inconsistencies in your ultrasonic readings. I disregard that for the purpose of simplicity for this tutorial

If you do find this useful please like comment and subscribe:

Supplies

7.jpg

1-) An HC-SR04 Module with RGB


Amazon


2-) Jumper Wires. I bought these:


Amazon


3-) Raspberry Pi Pico or and other 5V devices (Raspberry Pis, Arduinos, etc)

Physical Setup for RBG Pin

mock_fritzing.png

1-) Connect 3 pins as follows, this will be enough to get your RGB input powered. I use GPIO28 on the pico but the others should work as well.

2-) To setup the ultrasonic portion you can view this video or article:

https://www.youtube.com/watch?v=AwRwlCAQlH4

https://www.upesy.com/blogs/tutorials/hc-sr04-ultrasonic-sensor-on-rpi-pico-with-micropython-tutorial


That is all you need in terms of the physical setup

Code Libraries

1-) Get the neopixel lib I used and add it to the directory in your device saved as neopixel.py

https://github.com/shillehbean/youtube-channel/blob/main/neopixel.py

Based on another example I found online with a small modification

2-) Add the following code to a file of your choosing:

from machine import Pin, time_pulse_us
import random
import time


from neopixel import Neopixel


# You can change the pins you use
SOUND_SPEED=340
TRIG_PULSE_DURATION_US=10
TRIG_PIN = Pin(15, Pin.OUT)
ECHO_PIN = Pin(14, Pin.IN)
# Set params for Neopixel
NUMPIX = 6
PIXELS = Neopixel(NUMPIX, 0, 28)
YELLOW = (255, 100, 0)
ORANGE = (255, 50, 0)
GREEN = (0, 255, 0)
BLUE = (0, 0, 255)
RED = (255, 0, 0)
LAVENDER = (230, 230, 250)
# You can add as many colors as you want
COLOR_DICT = {0: YELLOW, 1: ORANGE, 2: GREEN, 3: BLUE, 4: RED, 5: LAVENDER}


def get_distance():
    '''Returns distance in CM'''
    TRIG_PIN.value(0)
    time.sleep_us(5)
    TRIG_PIN.value(1)
    time.sleep_us(TRIG_PULSE_DURATION_US)
    TRIG_PIN.value(0)
    ultrason_duration = time_pulse_us(ECHO_PIN, 1, 30000)
    distance_cm = SOUND_SPEED * ultrason_duration / 20000
    print(f"Distance : {distance_cm} cm")
    return distance_cm


def change_color_with_distance():
    '''Can be used to change color depending on distance'''
    while True:
        distance = get_distance()
        if distance < 10:
            color = RED
        elif distance < 20:
            color = YELLOW
        else:
            color = GREEN
        # I set all 6 LEDs to the same value
        # Note that they can all be toggled individually
        for i in range(NUMPIX):
            PIXELS.set_pixel(i, color)
        PIXELS.show()
        time.sleep(1)
        
    return


def fun():
    '''Loops through random colors you assigned in the constants
       You can also play with the brightness, see neopixel.py code
       for more details ;)'''
    
    while True:
        # we select a random led, we have a total of 6 (0-5)
        random_led = random.randint(0, 5)
        # we get a random color from the dictionary and assign it to
        # that random LED
        random_color = random.randint(0, len(COLOR_DICT) - 1)
        print(random_led, COLOR_DICT[random_color])
        PIXELS.set_pixel(random_led, COLOR_DICT[random_color])
        PIXELS.show()
        time.sleep(0.5)
        

How to Use the Code

IMG_4572.jpg
IMG_4575.jpg

There are two primary functions you can call in this code, fun() or change_color_with_distance().

1-) fun()

For this, you do not need the trigger or echo pins to set up it just randomly changes the colors of any of the 6 LEDs onboard the device, so it can make for some fun colors to look at.

Also, this helps you get a better idea of how the lights are triggered. You just need to set the LED of your choice with an RGB value and that is the premise of how the whole thing works at a high level. I demonstrate this above in the photos, you can see the random assortment of colors. I only used 6 for this demonstration but you can play around with RGB values!

2-) change_color_with_distance()

This function is a cool way to combine the RGB with the Ultrasonic. If you have your trigger and echo pins set up properly, you can use if statements to change the color based on how far the object is. I demonstrate this in the clip attached.

It is a nice way to know the distance of an object and can have some practical use cases in terms of the visual aspect of a robot, or help in dark spaces.


Note that there are other things you can do with the library such as change the brightness and play around with an assortment of colors, and of course, you can create your functions as well. This is just to get you started.

Hope this was clear, this should be all you need to get started, once again you can get the sensor here if you are interested!

Let me know if you have any questions or concerns below yall.