Remotely Controlled RGB Desktop Lights
by RitankarP in Circuits > Electronics
1003 Views, 5 Favorites, 0 Comments
Remotely Controlled RGB Desktop Lights
data:image/s3,"s3://crabby-images/b546f/b546f7a14da2436b60bee03a3f3864c85d26508f" alt="WhatsApp Image 2020-04-06 at 19.56.25 (3).jpeg".jpeg)
data:image/s3,"s3://crabby-images/78257/7825732998857e87c33f0d8e308fc1b675178457" alt="WhatsApp Image 2020-04-06 at 23.18.33.jpeg"
This project demonstrates the use of firebase as a server for controlling and manipulating the led lights along the backside of my table.
Supplies
- ESP8266.
- Led Strips WS2812B.
- Power supply with at least 10W@5V rating.
- An app for controlling the LED Strips.
Get the Strips in the Right Place
data:image/s3,"s3://crabby-images/ff6e5/ff6e53d77ed547f68b42461401caeae69145e34e" alt="WhatsApp Image 2020-04-06 at 19.56.25 (2).jpeg".jpeg)
data:image/s3,"s3://crabby-images/e6f20/e6f20ae4ca695115e57f993601b693e177b5b6c2" alt="WhatsApp Image 2020-04-06 at 19.56.25 (1).jpeg".jpeg)
data:image/s3,"s3://crabby-images/074e0/074e0f3c6e2dc599adca190ebdc5b97596d5588c" alt="WhatsApp Image 2020-04-06 at 19.56.25.jpeg"
I choose my bland old computer table for this project so I used some sticky tapes and fixed up my WS2812b led strips along the backside of it and connected the VCC, GND, DATA lines with a few wires as demonstrated in the pictures
Make the Little Connections
data:image/s3,"s3://crabby-images/e6c38/e6c38397dc8d27b1d07e81ee01754e4ccc3e23bc" alt="WhatsApp Image 2020-04-06 at 21.54.09.jpeg"
Connect the power supply to the ESP8266 [Note* - I used a board that I used for Home Automation but we only need the ESP8266]
Connect as follow:
- D5(Pin 14) -> Data Pin of LED strip
- Interconnect the GND pin of ESP8266, Power Supply, LED Strips.
That's for the hardware, now lets jump into coding board.
Firebase Rules and Database Schema
data:image/s3,"s3://crabby-images/d435b/d435b3e330b4b068bf4fa2410aaac2a611f01d7a" alt="firebase_rules.png"
data:image/s3,"s3://crabby-images/059bd/059bd50e69c048e3eb8ebc6b9863191f280b5ffb" alt="firebase_schema.png"
The Database Schema is simple.
- (user)
- neopixels
- 0
- {r:12, g:220, b:120}
- 1
- {r:112, g:150, b:200}
- 0
- token
- public : {token}
- private: {token}
- neopixels
This Schema represents a simple structures a list of Led values
Token sections represents a simple authentication system where the public and private section matches if authenticated.
Code for the Setup
data:image/s3,"s3://crabby-images/65f32/65f32cb2dc32126bcc1f9e985f3f09a2c0110bd1" alt="voidsetup.png"
data:image/s3,"s3://crabby-images/81e4d/81e4d4e65d6dba4286208b16c092d8d155dc8580" alt="voidloop.png"
data:image/s3,"s3://crabby-images/09a29/09a294a6909be946dd9f746df80d2b15d2697926" alt="helperfunctions.png"
The code is pretty self-descriptive.
- Include the required libraries.
- Setup the authentication token of database
- Provide WiFI credentials
- Setup the firebase stream to neopixels changes and start listening for changes in the data triggered by the client-side.
- In the loop keep on checking for the events and send the incoming data to the helper functions.
- The helper function takes the data and checks wheater the neopixel update was trigger for a:
- A single LED
- A range of LED numbers
- All of the LEDs.
The Autoroom App
data:image/s3,"s3://crabby-images/07141/071416a53a4394720e0f867e7cfc8b34d0d7e818" alt="WhatsApp Image 2020-04-06 at 22.28.58.jpeg"
data:image/s3,"s3://crabby-images/d82a0/d82a03bcd30a6d45592c10bff1c0e3c70cbae31c" alt="WhatsApp Image 2020-04-06 at 22.26.24.jpeg"
data:image/s3,"s3://crabby-images/06484/06484c894e6bcd3319a9cd8883504280a1b39c17" alt="WhatsApp Image 2020-04-06 at 22.25.56.jpeg"
data:image/s3,"s3://crabby-images/9023b/9023b9ec8d792cc953afae70a7e7a58ded75d14e" alt="WhatsApp Image 2020-04-06 at 22.25.56 (1).jpeg".jpeg)
data:image/s3,"s3://crabby-images/22dea/22dea49d891341572863d58a1e0dbc0b53bb7c8a" alt="WhatsApp Image 2020-04-06 at 22.25.56 (2).jpeg".jpeg)
data:image/s3,"s3://crabby-images/72b4d/72b4df253528918434bccc2b06fa121c15f362e0" alt="WhatsApp Image 2020-04-06 at 22.27.51 (1).jpeg".jpeg)
data:image/s3,"s3://crabby-images/d0109/d0109f657917e535fa440c3c054a5d839321e3bc" alt="WhatsApp Image 2020-04-06 at 22.27.51.jpeg"
data:image/s3,"s3://crabby-images/37005/37005b2ba83a975f1370efe7e3975e4a303ec446" alt="Controlling WS2812B Led Strip with a Flutter app and Firebase RTLD"
I made an app called "Autoroom" in Flutter using the Dart Programming Language, the controls the LED Lights.
Here are example results to that.
- First, log in with the credentials in my case it's (xritzx)
- Select the color and the range and hit update.
- Or maybe color the entire range by selecting -1.