Configuring the effects
※Introduction
In the previous chapter, we discussed how to configure different types of LED strips. In this chapter, we will explain in detail how to set up lighting effects.
Let's assume we have a VORON 2.4 printer.
On the Stealthburner toolhead, we have installed an LED strip containing 3 SK6812 LEDs, and we have correctly specified the pin, number of LEDs, and color order in the led_effects.cfg
file:
Additionally, we have installed two PCB strips on the frame, each containing 18 WS2812 LEDs. These strips are connected in parallel to the mainboard, with pin, LED count, and color order accurately configured in the led_effects.cfg
file.
Please note that the above configuration is for reference only. When configuring in practice, be sure to use the actual pin names, the actual number of LEDs in the strip, and the correct color order.
-Parallel Connection
In a parallel connection, all LED strips display the same effect synchronously, and it is not possible to control a single LED independently.
-Series Connection
In a series connection, each LED can be precisely controlled, allowing for unique effects to be defined for each light.
※Experiment
Now we want all LED devices to light up with a breathing effect when the printer successfully starts and connects to Klipper. We have written a configuration and added it to the led_effects.cfg
file, defining a custom lighting effect called light_start
:
After saving and restarting, you'll be pleasantly surprised to see that the configured LEDs all light up with a nearly white light, gradually increasing and decreasing in brightness, simulating the rhythm of breathing and creating a smooth brightness transition.
Next, we will break down the light_start
effect configuration line by line, helping you understand the creation of lighting effects in detail.
Line 1
[led_effect light_start]
Theled_effect
field is fixed. After the space, enter the name you want to define, using_
to replace spaces in the name.
Line 2
autostart: true
Entering true
indicates that this light effect will automatically start when the printer powers on.
Entering false
, which means the effect will not start automatically and will need to be activated manually.
Line 3 recalculate:false
Enable layer template recalculation on effect activation.
Line 4
frame_rate: 24
This sets the frame rate of the effect (in frames per second).
Line 5
leds:
Theleds
label is fixed. Below this line, list the LED strips you want to use, prefixed withneopixel:
followed by the LED name. For example, in the above configuration, we listedhotend_light
andframe_light
. You can choose to include one or more.Make sure there is no space between the colon and the LED strip name; otherwise, it may not be recognized.
You can also specify which specific LEDs to display the effect by providing their indices after the strip name. The indices can be given as a list or a range. You can even invert the range to change the effect. If no indices are specified, the entire strip will be used.Additionally, if needed, the same strip can be included multiple times in an effect, allowing for different emitters to be specified.
Ensure there is a space between the LED strip name and the uppercase parentheses ()
, or copy directly from here: ()
.
Example:
Line 8
layers:
Thelayers
label is fixed. Below this line, place the definitions for the lighting effect layers. Each line represents a layer, and you can define multiple layers and use special commands to blend them, a concept we can discuss in more detail later.
※Effect Layer Analysis in Line 8
In the effect layer, we use a combination of words and numbers, which may seem complex at first glance. However, it can actually be broken down into five fundamental modules, each contributing to form a complete effect layer:
Layer Name Each layer has a unique name for identification and referencing. In the table below, there are 24 example layer names, such as breathing or linearfade. As the names suggest, the breathing layer achieves a breathing effect, while linearfade creates a linear fade-in and fade-out effect.
Effect Rate For most layers, this parameter controls the speed of the effect’s updates, typically measured in frames. For instance, setting it to 10 means the effect updates 10 times per second. However, in some specific effect layers, this parameter might have a different function.
Cutoff The cutoff parameter sets the starting or ending point of the effect, determining when the effect should begin or stop. Similar to the effect rate, cutoff may have varied meanings depending on the effect layer type.
Blending Mode Blending mode defines how the current layer combines with other layers. Common blending modes include add (overlay), subtract (subtraction), and others, which allow more complex effects. This is a more advanced feature, so if interested, you may explore additional details after this section.
Color Palette The length of the palette is unlimited, with colors defined as groups of red, green, blue, and (optional) white. The white channel is only used for RGBW LEDs and will be ignored on RGB LEDs. The range for each color is a decimal number from 0.0 to 1.0. For white, you can use (1.0, 1.0, 1.0) on RGB LEDs or (0.0, 0.0, 0.0, 1.0) on RGBW LEDs.
Depending on the type of layer, you can fill one or more color values in the palette. Each color must be enclosed in parentheses and separated by commas, with each color group also enclosed in parentheses.
Example 1
For instance, when using the linearfade
layer, you can specify blue (0,0,1) and red (1,0,0). This will create a lighting effect that gradually transitions from blue to red over a 3-second period.
Example 2
When using the twinkle
layer, you can fill the palette with colors like red: (1,0,0), orange: (1,0.647,0), yellow: (1,1,0), green: (0,1,0), cyan: (0,1,1), blue: (0,0,1), and purple: (0.5,0,0.5). This will create a lighting effect that randomly twinkles through seven colors, resembling a disco effect, right?
※ Layer typical example
1. Regular Effect Layers
2. Heater Control Effect Layers
Specifies which heater to use for a heater effect. #Use extruder for the extruder heater and heater_bed for the bed heater. Example:
For temperature fans or sensors, include the type in quotes.
3. Stepper Control Effect Layer
Specifies the axis to be used for the stepper effect. Possible values are x, y, and z.
stepper
4
Number of trailing LEDs
4
Number of leading LEDs
Color values to blend
The first color in the palette represents the position of the specified stepper motor, with the remaining gradient colors mirrored on either side. As the stepper moves along the axis, the lights shift up and down the strip. The effect updates the position every half second based on the stepper's reported position, similar to the GET_POSITION
gcode command, but is not real-time. A negative effect rate
fills the strip up to the stepper’s position, while a negative cutoff
fills it after the position.
steppercolor
1
Scaling of position
0
Offset of position
DColor values to blend
The color of the LEDs are determined by the position of the stepper motor. The position is determined between 0 and 100 and is multiplied with the effect rate and the cutoff is added as offset. This then determines the value in the palette, that is calculated as a gradient over the specified color values.
progress
4
Number of trailing LEDs
4
Number of leading LEDs
Color values to blend
Exact same configuration as Stepper but instead of reporting stepper position, this layer reports print progress.
4. Limit Switch Trigger Effect Layer
Lists the endstops that the homing effect will trigger. You can specify multiple endstops as a comma-separated list. Possible values are x, y, z, and probe. #Example: endstops: x, y
homing
1
Determines decay rate. A higher number yields slower decay
0
Not used, but must be provided
Colors are cycled in order
Needs an endstop defined. LEDs turn on during homing when the endstop is triggered and fade out again. The effect rate determines the time for the fade out. If a palette of multiple colors is provided, it will cycle through those colors in order.
5. Button Trigger Effect Layer
Lists the pins that trigger the button effect. You can specify multiple pins as a comma-separated list, and the effect will trigger when any button is pressed. You can also use already assigned pins (like endstop pins) by employing duplicate_pin_override (refer to the Klipper documentation for more details). Example: button_pins: PC1, PC2.
switchbutton
1
Fade in time. Time until LEDs are on after button press
1
Fade out time. Time until LEDs are off after button release
Colors are cycled in order
Needs a button_pin defined. LEDs turn on when the button is pressed and turn off when the button is released again. Each press cycles through the colors of the palette.
togglebutton
1
Fade in time. Time to fade in next color
1
Fade out time. Time to fade out previous color
Colors are cycled in order
Needs a button_pin defined. Cycles through the colors with each button press. The transition times can be configured with the effect rate and cutoff parameters. Hint: Define (0,0,0) as a color if you want to toggle between on and off.
flashbutton
00.1
Fade in time. Time to fade in.
1
Fade out time. Time to fade out.
LEDs fade on with Colors are cycled in order
Needs a button_pin defined. When the button is pressed the LEDs fade on in the defined time and fade off immediately afterwards. If a palette of multiple colors is provided, it will cycle through those colors in order with each button press.
6.AnalogPin Effect Layers
Indicates the pin used for effects that rely on an analog signal.
analogpin
10
M10 Multiplier for input signal
40
Minimum threshold to trigger effect
Color values to blend
This effect uses the value read from an analog pin to determine the color. If multiple colors are specified in the palette, it chooses one based on the value of the pin. If only one color is specified, the brightness is proportional to the pin value. An example usage would be attaching an analog potentiometer that controls the brightness of an LED strip. Internally, input voltage is measured as a percentage of voltage vs aref. Another use could be to attach the RPM wire from a fan if the fan has a tachometer. It must be used with care as too much current or too high a voltage can damage a pin or destroy a controller board.
※Controlling the effects
Active vs. Inactive Effects
Active effects generate color data, while inactive effects do not.
Activating and Deactivating Effects
To activate an effect, use
SET_LED_EFFECT EFFECT=light_start
To replace all currently active effects with a new one, use
SET_LED_EFFECT EFFECT=light_start REPLACE=1
To stop a specific effect, use
SET_LED_EFFECT EFFECT=light_start STOP=1
To stop all effects, use
STOP_LED_EFFECTS
To stop effects on specific LEDs, specify the LEDs with
STOP_LED_EFFECTS LEDS="neopixel:panel_ring"
, or indicate LED indices, e.g.,STOP_LED_EFFECTS LEDS="neopixel:panel_ring (1-7)"
. Note: only one LED parameter can be specified per command.
Fading Effects
To fade an effect in or out, specify
FADETIME
:Fade in:
SET_LED_EFFECT EFFECT=light_start FADETIME=1.0
(one second).Fade out:
SET_LED_EFFECT EFFECT=light_start STOP=1 FADETIME=1.0
To fade out all effects, use
STOP_LED_EFFECTS FADETIME=1.0
Crossfade between effects by combining
REPLACE
andFADETIME
:SET_LED_EFFECT EFFECT=light_start REPLACE=1 FADETIME=1.0
Restarting Effects
To resume an effect from its last state, start it normally. To restart from the beginning, add
RESTART=1
:SET_LED_EFFECT EFFECT=light_start RESTART=1
.
Template Processing
Effect Layers as Templates
Effects use templates similar to Klipper macros, though this can increase processing load.
Layers are processed on effect creation. To re-evaluate layers each time an effect is activated, set
recalculate
totrue
.
Using Parameters
With
recalculate: true
, effects can accept parameters. For example:
To activate
param_effect
with custom parameters, use:SET_LED_EFFECT EFFECT=param_effect DURATION=3 CYCLE=0.2
.
Setting Default Values
Each parameter in the layers should have a default value, as effects are initially processed without GCode context.
Last updated