Color Mixer With Arduino

by tliguori330 in Circuits > Arduino

4423 Views, 22 Favorites, 0 Comments

Color Mixer With Arduino

color_mixer_gif.gif
color mixer demo

A color mixer is a great project for anyone working and growing with Arduino. By the end of this instructable you will be able to mix and match almost every color imaginable by turning 3 knobs. The skill level is low enough that even a complete rookie can complete it successfully, but also interesting enough to be enjoyable for a seasoned vet. The cost of this project is next to nothing and most Arduino kits come with the materials needed. At the core of this code are some fundemental arduino functions that anyone using arduino will want to understand. We will go into depth about the analogRead() and analogWrite() functions as we as another usual function called map(). These links bring you to the arduino reference pages for these functions.

Parts and Componets

20180108_111529.jpg
20180110_130123.jpg
20180108_110511.jpg
220_ohm_ resistor.jpg

Arduino Uno

Potentiometer (x3)

RGB LED

220 ohm resistor (x3)

Jumper wires (x12)

Bread board

Plan Your Progress

color_mixer_flow.png

It can be very helpful to plan how you will complete your project. Coding is all about the logical progression from one step to the next. I made a flow chart that outlines how I want my sketch to run. The overall goal is to have 3 knobs (potentiometers) control each of the three colors of an RGB LED. In order to accomplish this we will need to create a sketch matching the flow chart. We will want to....

1) Read 3 different potentiometers and save their values in variables.

2) We will convert those values to match the range of the RGB LED.

3) Then finally we will write those converted values to each of the colors of the RGB.

How to Use Potentiometers

20180110_130123.jpg
20171101_101049.jpg

One of the most basic components in a electronics kits, the potentiometer can be used in many different projects. potentiometers function by allowing the user to physically change the resistance of the circuit. The most farmilar example of a potentiometer is a light dimmer. sliding or turning a knob changes the length of the circuit. a longer path results in more resistance. The increased resistance inversely lowers the current and the light dims. These can come in all different shaped and sized but most has the same basic set up. A student asked for help fixing his guitar and we found out the knobs on it were exactly the same as potentiometers. In general you was the outside legs connected to 5 volts and ground and the middle leg goes to an analog pin like A0

Wiring Schematic for (3x) Potentiometer

pot_schematic.jpg
pot_3_schematic.jpg
20180108_110628.jpg
20180108_110754.jpg
20180108_110636.jpg
20180108_110835.jpg
20180108_111319.jpg
20180108_111106.jpg
20180108_110921.jpg
20180108_111358.jpg
20180108_111504.jpg
20180108_111515.jpg

The left most leg will be connected to 5v and the right most leg will be connected to GND. You can actually reverse these two steps and it will not hurt the project very much. All that would change is turning the knob all the way to the left will be full brightness instead of all the way off. The middle leg will be connected to one of the analog pins on the Arduino. Since we will have three knobs, we will want to triple up on the work we just did. Each knob needs 5v and GND so those can be shared using a bread board. The red strip on the bread board is connected to 5 Volts and the blue strip is connected to ground. Each knobs needs its own analog pin so they are connected to A0, A1, A2.

Using AnalogRead() and Variables

With you potentiometer set up correctly we are ready to read those values. When every we want to do this we use the analogRead() function. The correct syntax is analogRead(pin#); so to read our middle potentiometer we would analogRead(A1); In order to work with the numbers being sent from the knob to the Arduino, we will want to also save those numbers in a variable. The line of code will accomplish this task as we read the potentiometer and save its current number in the integer variable "val"

int val = analogRead(A0);

Using the Serial Monitor With 1 Knob

arduino serial monitor example

Currently we are able to get values from the knobs and store them in a variable, but it would be helpful if we could see these values. To do this we need to make use of the built in serial monitor. The code below is the first sketch we will actually run in the Arduino IDE which can be downloaded at their site. In the void setup() we will activate the analog pins connected to each middle leg as an INPUT and activate the Serial monitor using Serial.begin(9600); next we read only one of the knobs and store it in a variable like before. The change now is we added a line that prints what number is stored in the variable. If you compile and run the sketch you can then open your Serial monitor and see numbers scrolling on the screen. Each time the code loops we are reading and printing another number. If you turn the knob connected to A0 you should see values ranging from 0-1023. later on the goal will be to read all 3 potntiometers which would require 2 more analogReads and 2 different variables to save and print.

void setup(){
	pinMode(A0,INPUT);
	pinMode(A1,INPUT);
	pinMode(A2,INPUT);
	
	Serial.begin(9600);
}

void loop(){
	int val = analogRead(A0);
	Serial.println(val);
}

Using the RGB LED

20180108_112419.jpg
20180108_112426.jpg
20180108_112532.jpg
20180108_112437.jpg
20180108_112520.jpg
20180108_111555.jpg
20180108_112639.jpg

The 4 Legged RGB LED i one of my favorite components for Arduino. I find The way it is able to create endless colors from mixtures of 3 of basic colors fascinating. The set up is similar to any regular LED but here we basically have a red, blue and green LEDs combined together. The short legs will each be controlled by one of the PWM pins on the arduino. The longest leg will be connected to 5 volts or ground, depending if yours in a common anode or common cathode LED. You will need to try out both ways to problem solve this. We will already have 5v and GND connected to the breadboard to it should be easy to change. The diagram above shows using 3 resistors as well. I actually skip this step often as I haven't had and LED blow out on me.

To make colors we will use the analogWrite() function to control how much red, blue,or green to add. To use this function you need to say which pin# we will talk to and a number between 0-255. 0 is completely off and 255 is the highest amount of one color. Lets connect the red leg to pin 9, green to pin 10 and blue to pin 11. This might take some trial and error to figure out which leg is which color. If i wanted to make a purple hue I could do a lot of red, no green, and maybe half strength of blue. I encourage you to tinker with these numbers, its really exciting. Some common examples are in the pictures above

void setup(){
	pinMode(9,OUTPUT);
	pinMode(10,OUTPUT);
	pinMode(11,OUTPUT);
}

void loop(){
	analogWrite(9,255);
	analogWrite(10,0);
	analogWrite(11,125)
}

Using Potentiometers to Control RGB LED (with One Bug)

20180108_111916.jpg
20180108_111744.jpg
20180108_111754.jpg
20180108_111631.jpg
color_mixer_schematic.png

It is time to start fusing our two codes together. You should have just enough room on a standard breadboard to fit all 3 knobs and the RGB LED. The idea is instead of typing in the values for red blue and green, we will be using the values saved from each poteniometer to constantly change the colors. we will need 3 variables in this case. the redval, greenval, blueval are all different variables. Keep in mind you can name these variables anything you want. if you turn the "green" knob and the red amount changes, you can switch the names to match correctly. you can now turn each knob and control the colors!!

void setup(){
pinMode(A0,INPUT);
pinMode(A1,INPUT);
pinMode(A2,INPUT);

pinMode(9,OUTPUT);
pinMode(10,OUTPUT);
pinMode(11,OUTPUT);
}

void setup(){
int redVal = analogRead(A0);
int greenVal = analogRead(A1);
int blueVal = analogRead(A2);

analogWrite(9,redVal);
analogWrite(10,greenVal);
analogWrite(11,blueVal);
}

BONUS: Map() Function and Cleaner Code

You may notice that as you start turning the knob for one color up it will grow and then suddenly drop down to off. This pattern of growing and then quickly shutting off repeats 4 times as you turn the knob all the way up. If you recall we said the potentiometers can read values between 0 and 1023. The analogWrite() function only accepts values between 0 and 255. once the potentiometer goes over 255 it basically starts over at 0. There is a nice function to help with the bug called map(). you can convert one range of numbers into another range of numbers in one step. we will convert numbers from 0-1023 to numbers from 0-255. For example if the knob was set to half way it should read about 512. that number would be changed to 126 which is half strength for the LED. In this final sketch i named the pins with variable names for my convenience. You now have a completed color mixer to experiment with!!!

// variable names for potentiometer pins
int redPot = A0;
int greenPot = A1;
int bluePot = A2
// variable names for RGB pins
int redLED = 9;
int greenLED = 10;
int blueLED = 11;

void setup(){
pinMode(redPot,INPUT);
pinMode(greenPOT,INPUT);
pinMode(bluePot,INPUT);

pinMode(redLED,OUTPUT);
pinMode(greenLED,OUTPUT);
pinMode(blueLED,OUTPUT);

Serial,begin(9600);
}

void loop(){
// read and save values from potentiometers
int redVal = analogRead(redPot);
int greenVal = analogRead(greenPot);
int blueVal - analogRead(bluePot);

//convert the values from 0-1023 to 0-255 for the RGB LED
redVal = map(redVal,0,1023,0,255);
greenVal = map(greenVal,0,1023,0,255);
blueVal = map(blueVal,0,1023,0,255);

// write these converted values to each color of the RGB LED
analogWrite(redLED,redVal);
anaogWrite(greenLED,greenVal);
analogWrite(blueLED,blueVal);

//show the values on the Serial monitor
Serial.print("red:");
Serial.print(redVal);
Serial.print("green:");
Serial.print(greenVal);
Serial.print("blue:");
Serial.println(blueVal);
}