RGB LED control
These functions control LED brightness.
rotary2Brightness()
Standard incremental encoder in the rotary2bit category. Rotating CW will give a button pulse, rotating CCW will give a button pulse with a button number 1 value higher.
Holding the modButton will make this encoder adjust the LED brightness level up and down by increments of 2%.
void rotary2Brightness(int row, int column, bool reverse)
For an encoder with pins A and B to columns 3 and 4. Common pin to row 2:
rotary2Brightness(2, 3, false);
The button numbers used is determined by the number written in the block for the A pin. B pin block will not be read. If button number was set to 15, the switch will use buttons 15 and 16. The reverse part of the function will switch the button numbers if set to true.
- 2 button numbers 
- modButton() 
funkyBrightness()
Standard incremental encoder in the funkyRotary category. Rotating CW will give a button pulse, rotating CCW will give a button pulse with a button number 1 value higher.
Holding the modButton will make this encoder adjust the LED brightness level up and down by increments of 2%.
void funkyBrightness(int Arow, int Acol, int Bcol, bool reverse)
For an encoder with pins A and B to columns 3 and 4. Common pin to row 2:
funkyBrightness(2, 3, 4, false);
The button numbers used is determined by the number written in the block for the A pin. B pin block will not be read. If button number was set to 15, the switch will use buttons 15 and 16. The reverse part of the function will switch the button numbers if set to true.
- 2 button numbers 
- modButton() 
PEC11Brightness()
Standard incremental encoder in the PEC11 category. Rotating CW will give a button pulse, rotating CCW will give a button pulse with a button number 1 value higher.
Holding the modButton will make this encoder adjust the LED brightness level up and down by increments of 2%.
void PEC11Brightness(int row, int column, bool reverse)
For an encoder with pins A and B to columns 3 and 4. Common pin to row 2:
PEC11Brightness(2, 3, false);
The button numbers used is determined by the number written in the block for the A pin. B pin block will not be read. If button number was set to 15, the switch will use buttons 15 and 16. The reverse part of the function will switch the button numbers if set to true.
- 2 button numbers 
- modButton() 
rotaryPulseBrightness()
Standard incremental encoder in the rotaryPulse category. Rotating CW will give a button pulse, rotating CCW will give a button pulse with a button number 1 value higher.
Holding the modButton will make this encoder adjust the LED brightness level up and down by increments of 2%.
void rotaryPulseBrightness(int row, int column, bool reverse)
For an encoder with pins A and B to columns 3 and 4. Common pin to row 2:
rotaryPulseBrightness(2, 3, false);
The button numbers used is determined by the number written in the block for the A pin. B pin block will not be read. If button number was set to 15, the switch will use buttons 15 and 16. The reverse part of the function will switch the button numbers if set to true.
- 2 button numbers 
- modButton() 
rotaryAnalogBrightness()
12 - position switch. Absolute.
Produces no button presses, but the position of the switch is still detected by the firmware and can be used for conditional coding or rotaryInject. The switch works like a volume knob for your LEDs, and you can adjust how big impact is has on the brightness.
void rotaryAnalogBrightness(int analogChannel, int startBrightness, endBrightness int pos1, int pos2, int pos3, int pos4, int pos5, int pos6, int pos7, int pos8, int pos9, int pos10, int pos11, int pos12, bool reverse)
Switch setup with explainations:
rotaryAnalogBrightness(
2, <- The analog channel used
5, <- The lowest brightness setting (position 1 on the switch)
70, <- The highest brightness setting (position 12 on the switch)
16, 107, 200, 291, 383, 474, 566, 657, 749, 841, 932, 1023, <- Switch position values
false); <- Direction is not reversed, so CW rotation increasese button number.
- This switch has "reverse" set to true, which can be a good idea if it is placed horizontally on the right side. Turning it CCW will now increase the brightness instead of reducing. So typed out in 30_Switches.ino: 
rotaryAnalogBrightness(2, 5, 70, 16, 107, 200, 291, 383, 474, 566, 657, 749, 841, 932, 1023, false);
This switch will set the brightness to 5% in position 1 and 70% in position 12. The positions in between will be a gradual increase from 5 to 70%.
- None 
rotaryAnalogBrightness12()
12 - position switch. Absolute.
Works similar to rotaryAnalogSimple(), but with the added feature of setting the LED brightness if rotating this switch while the modButton is held. Adjustments with increments of 2%.
void rotaryAnalogBrightness12(int analogChannel, int pos1, int pos2, int pos3, int pos4, int pos5, int pos6, int pos7, int pos8, int pos9, int pos10, int pos11, int pos12, bool reverse)
Switch setup with explainations:
rotaryAnalogBrightness12(
2, <- The analog channel used
16, 107, 200, 291, 383, 474, 566, 657, 749, 841, 932, 1023, <- Switch position values
false); <- Direction is not reversed, so CW rotation increasese button number.
- This switch has "reverse" set to true, which can be a good idea if it is placed horizontally on the right side. Turning it CCW will now increase the brightness instead of reducing. So typed out in 30_Switches.ino: 
rotaryAnalogBrightness12(2, 16, 107, 200, 291, 383, 474, 566, 657, 749, 841, 932, 1023, false);
- 12 button numbers 
- modButton() 
Last updated