DDC
  • Welcome
    • Introduction
    • Supported hardware
  • 1: Project planning
    • Switch inputs
      • Switch table
      • Direct
      • Shift register
      • Port expander
    • Analog inputs
      • External ADC
    • RGB LED
    • Digital outputs
    • PWM / Circuit control
    • EEPROM
    • Processing and memory
  • 2. Wiring
    • Switch inputs
      • Matrix
      • Direct
      • Shift register
      • Port expander
    • Analog
      • Analog switches
      • External ADC
    • RGB LED
    • Digital outputs
    • PWM / Circuit control
    • EEPROM
  • 3. Coding
    • Essentials
      • 02_Board.ino
      • 08_Joystick
      • 10_TableAndAnalog.ino
        • Switch table
        • Analog channels
      • 30_Switches.ino
    • Peripherals
      • RGB LED
        • Firmware control
          • LED functions
          • Color
          • Brightness
          • Presets
        • SimHub control
      • Digital outputs
        • Setup
        • SimHub control
        • Firmware control
      • PWM / Circuit control
        • Setup
        • Calibrate
        • Switch control
        • Trigger control
      • Shift register
      • I2C devices
        • ADS1115
        • PCA9555
        • CAT24C512
    • Advanced
      • Analog inject
      • Conditional coding
        • Triggers
        • Editors
      • Field placement
      • Presets
        • 31_RunningPresets.ino
        • 32_Presets.ino
        • Example
    • Upload
    • Naming the controller
  • 4. Connect to SimHub
    • LED control
    • Controller settings and properties
      • How to connect?
      • How does it work?
      • How to control it?
      • Property list
  • Switch library
    • Pushbutton
    • Function switches
    • Toggle switches
    • Hat switches
    • Car control functions
      • QuickSwitch
      • BrakeMagic
      • ThrottleHold
      • Handbrake
    • Pedals & paddles
      • Brake/throttle
      • Clutch
      • Bite point & launch
      • Filtered curves
      • Shifter
    • Funky switch
      • Directional
      • Center push
    • Encoders
      • rotary2Bit
      • rotary4Bit
      • funkyRotary
      • wildEncoder
      • E18
      • rotaryPulse
      • PEC11
    • Rotary switches
      • rotaryAnalog
      • quickRotary
      • SW1
      • Editing functions
    • Multiswitch complexes
      • Hybrid rotary
      • Multifunction rotary
      • Modded encoder
      • Stacked encoder
    • Preset
    • DDS
    • RGB LED control
    • PWM / Circuit control
    • Utility
  • Fast DDC
    • Buttons and LED
    • 4 encoders, buttons and LED
    • Dual clutches, 4 encoders, buttons and LED
    • Dual clutches, 6 encoders, button matrix and LED
  • CB1
    • Ordering
      • Order together
      • Order yourself
        • 1. Open in EasyEDA
        • 2. Export files
        • 3. Edit Pick&Place
        • 4. Pin headers and jumper
        • 5. Order from JLCPCB
    • Wiring
    • Code
      • Essentials
      • Complete project
      • Settings
    • Circuit
    • Shields
      • Robin
  • Collaboration
Powered by GitBook
On this page
  1. Switch library

RGB LED control

PreviousDDSNextPWM / Circuit control

Last updated 1 year ago

These functions control

rotary2Brightness()

Standard incremental encoder in the rotary2bit . 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 . 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 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 . 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 or . 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.

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()

Works similar to, but with the added feature of setting the LED brightness if rotating this switch while the modButton is held. Adjustments with increments of 2%.

LED brightness.
conditional coding
category
category
category.
category
rotaryInject
rotaryAnalogSimple()