RGB LEDs are light-emitting diodes that mix red, green, and blue to create many different hues of light. In this codelab, learn how to control an RGB LED with your Raspberry Pi. Whether you're building a fun alert system or adding light effects to a DIY project, you can integrate a RGB LEDs into your Viam project quickly using a prebuilt module.
What You'll Build
A common cathode RGB LED that can display a specific color or light effect.
Prerequisites
A computer with MacOS, Windows, or Linux to flash your Raspberry Pi and configure the device's components using the Viam app
1 - optional: solder, heat shrink tubing, and electrical tape
What You'll Need
All the hardware components listed in prerequisites.
Sign up for a free Viam account, and then sign in to the Viam app
What You'll Learn
How to configure and test a hardware component using Viam
How to use modules from the Viam registry
How to use pulse width modulation (PWM) to control an RGB LED light
Watch the Video
See a demonstration of controlling the RGB LED in this video.
The Raspberry Pi boots from a USB flash drive (or microSD card). You need to install Raspberry Pi OS on a USB flash drive that you will use with your Pi. For more details about alternative methods of setting up your Raspberry Pi, refer to the Viam docs.
Install Raspberry Pi OS
Connect the USB flash drive (or microSD card) to your computer.
Click CHOOSE DEVICE. Select your model of Pi, which is Raspberry Pi 4.
Click CHOOSE OS. Select Raspberry Pi OS (64-bit) from the menu.
Click CHOOSE STORAGE. From the list of devices, select the USB flash drive you intend to use in your Raspberry Pi.
Configure your Raspberry Pi for remote access. Click Next. When prompted to apply OS customization settings, select EDIT SETTINGS.
Check Set hostname and enter the name you would like to access the Pi by in that field, for example, test.
Select the checkbox for Set username and password and set a username (for example, your first name) that you will use to log into the Pi. If you skip this step, the default username will be pi (not recommended for security reasons). And specify a password.
Connect your Pi to Wi-Fi so that you can run viam-server wirelessly. Check Configure wireless LAN and enter your wireless network credentials. SSID (short for Service Set Identifier) is your Wi-Fi network name, and password is the network password. Change the section Wireless LAN country to where your router is currently being operated.
Select the SERVICES tab, check Enable SSH, and select Use password authentication.
Save your updates, and confirm YES to apply OS customization settings. Confirm YES to erase data on the USB flash drive. You may also be prompted by your operating system to enter an administrator password. After granting permissions to the Imager, it will begin writing and then verifying the Linux installation to the USB flash drive.
Remove the USB flash drive from your computer when the installation is complete.
Connect with SSH
Place the USB flash drive into your Raspberry Pi and boot the Pi by plugging it in to an outlet. A red LED will turn on to indicate that the Pi is connected to power.
Once the Pi is started, connect to it with SSH. From a command line terminal window, enter the following command. The text in <> should be replaced (including the < and > symbols themselves) with the user and hostname you configured when you set up your Pi.
ssh <USERNAME>@<HOSTNAME>.local
If you are prompted "Are you sure you want to continue connecting?", type "yes" and hit enter. Then, enter the password for your username. You should be greeted by a login message and a command prompt.
Update your Raspberry Pi to ensure all the latest packages are installed
sudo apt update
sudo apt upgrade
Add your RGB LED
Review the wiring diagram: The LED can be controlled via a GPIO pin on the Raspberry Pi. Refer to the following wiring diagram to see how to connect the Raspberry Pi to the RGB LED, using the breadboard and also resistors to control the flow of electricity.
Pin 12 (GPIO 18) to Blue
Pin 32 (GPIO 12) to Green
Pin 33 (GPIO 13) to Red
Pin 34 (GND) to Common
Review the LED orientation: A common cathode RGB LED has four legs:
Common Cathode (GND): The longest leg should be connected to ground.
Red (R): Typically the leg next to the common cathode (to the left as shown below).
Green (G): The leg on the other side of the cathode (to the right as shown below).
Blue (B): The farthest leg from the cathode.
Wire the RGB LED to the Raspberry Pi: The breadboard simplifies the wiring process by providing a secure platform to connect components without soldering. Connect the longest leg of the LED (common cathode) to the ground (GND) pin (physical pin 34) on the Raspberry Pi. Then, connect the red, green, and blue legs of the LED to resistors (68Ω for red, 10Ω for green, and 10Ω for blue). These resistors should then be connected to pins 33, 32, and 12, respectively. Double-check connections to ensure correct polarity and avoid miswiring.
Now that you have physically connected the hardware components, let's configure the software in the next section.
Configure your machine
In the Viam app under the LOCATIONS tab, create a machine by typing in a name and clicking Add machine.
Click View setup instructions.
To install viam-server on the Raspberry Pi device that you want to use to communicate with and control your webcam, select the Linux / Aarch64 platform for the Raspberry Pi, and leave your installation method as viam-agent.
Use the viam-agent to download and install viam-server on your Raspberry Pi. Follow the instructions to run the command provided in the setup instructions from the SSH prompt of your Raspberry Pi.
The setup page will indicate when the machine is successfully connected.
Configure your Raspberry Pi board
To access the GPIO pins, let's add our Raspberry Pi board to our machine in the Viam app.
Click the + icon in the left-hand menu and select Component.
Select board, and find the raspberry-pi:rpi4 module. This adds the module for working with the Raspberry Pi 4's GPIO pins. Leave the default name board-1 for now.
Notice adding this module adds the board hardware component called board-1. The collapsible card on the right corresponds to the part listed in the left sidebar.
Click Save in the top right to save and apply your configuration changes.
Expand the TEST section of the panel to experiment with writing to physical pin 12. For example, try setting a High signal.
Set the signal to Low (for each pin previously set to High) to turn off the LED.
You can manually and programmatically use the GPIO pins of the board component to send PWM signals to control your LED. However, to streamline the following steps, let's use a prebuilt module from the Viam registry in the next section.
Configure your RGB LED
In the Viam app under the CONFIGURE tab, click the + icon in the left-hand menu and select Component.
Select generic, and find the led:rgbled module. This adds the module for controlling your RGB LED. Name the component rgb-led.
In the new rgb-led panel, configure your component by adding the following attributes in the CONFIGURE field. This tells your LED component to use specific pins on a specific board (called board-1 in the Viam app).
Click Save to apply your configuration changes. This may take a moment.
Since we are using a generic component, let's test it out under the CONTROL tab. Find your rgb-led component on this page. Expand the DO COMMAND field, input the following code, and hit Execute.
You are executing a DoCommand on a generic component that has been predefined to accept parameters within a control_rgb_led command, such as red, green, blue, and duration. With these values, red will be at 80% brightness, green at 50% brightness, blue at 20% brightness - displaying a pulsating mixed color for a total duration of 2 seconds.
Experiment with different numerical values in those fields to see what happens when you execute the command again. If you have extra time, try sending the following Do command.
{
"ripple": {
"duration": 7.0
}
}
What is the primary purpose for using PWM (Pulse Width Modulation) to control an RGB LED?
To provide a constant high voltage to the LED.To control the brightness and color of the LED by adjusting the signal duty cycle.To make sure the LED operates at full brightness without additional wiring.To power the LED directly from a USB port.
Now that your RGB LED is working the way you want it, it's time to tidy up our project so it's not a loose jumble of wires and parts.
Assemble an enclosure for the Pi: 3D print (or buy) an enclosure for your Raspberry Pi. I found an existing design that I liked to fit a Raspberry Pi 4 Model B that provides access to the GPIO pins. You can additionally modify an existing design to include a built-in mount for your LED.
Assemble an LED display: 3D print (or buy) a display for your RGB LED. I found these mushrooms that I liked originally designed for wireless LEDs, but could contain the LED and wires, and also function as a lamp shade to illuminate more surface area.
Position the LED: The LED can be placed as near or far to the Raspberry Pi as your jumper wires allow.
What you learned
How to configure and test a hardware component using Viam
How to use modules from the Viam registry
How to use pulse width modulation (PWM) to control an RGB LED
Advanced scenarios for your Raspberry Pi projects
At this point, you have configured and tested your machine and LED to turn on, but nothing is happening automatically. You can create automatic processes that trigger actions when certain conditions are met, such as in the following examples.
RGB LEDs are small, but powerful components used in industries that require dynamic lighting and visual feedback. Their applications include:
Alarms and Notifications: RGB LEDs provide visual alerts in security systems, home automation setups, and medical devices by changing colors to indicate different statuses or warnings.
Interactive Robotics: Robots use RGB LEDs to signal task completion, indicate operational status, or prompt user interaction with color-coded feedback.
Home Automation: Smart home devices use RGB LEDs for ambient lighting, mood setting, and visual notifications, such as turning red when a door is left open or blue for incoming notifications.
Gaming and Toys: RGB LEDs are widely used in gaming consoles, controllers, and interactive toys to create immersive experiences with customizable lighting effects.