LED Warning Light Configuration
The LED warning light (three-color signal light) is used to visually display the printer's operating status. This article introduces its wiring method and Klipper configuration.
LED warning lights come in various input voltage specifications. This article uses the 24V version as an example. Please verify voltage compatibility based on the actual model used.
Wiring Instructions
Cable Color Definition
| Color | Function | Wiring Location |
|---|---|---|
| Gray | Common positive | Connect to 24V power positive terminal (e.g., 24V fan supply) |
| Red | Red light control | Connect to the mainboard fan control signal pin |
| Green | Green light control | Connect to the mainboard fan control signal pin |
| Yellow | Yellow light control | Connect to the mainboard fan control signal pin |
Control Polarity
FLY printer mainboards default to using negative control:
- The positive terminal (gray wire) of the LED warning light connects to 24V power
- The control wires (red/green/yellow) of the LED warning light connect to the mainboard GPIO pins
- When the mainboard outputs a low level, the corresponding color lights up
Klipper Configuration
[output_pin led_red]
pin: PD12 # Red light control pin
pwm: False
value: 0 # Default off
shutdown_value: 1 # Automatically turns on the red light when Klipper errors
[output_pin led_green]
pin: PD13 # Green light control pin
pwm: False
value: 0
[output_pin led_yellow]
pin: PD14 # Yellow light control pin
pwm: False
value: 0
The above uses PD12, PD13, and PD14 as example pins. Please modify them according to the available GPIO on your actual mainboard.
The red light implements a fail-safe mechanism via shutdown_value: 1:
- Normal Operation: The red light is controlled by macros and remains off under normal conditions
- Error/Disconnection: When Klipper enters a Shutdown state, the red light is automatically set to on without any macro intervention.
- This is a hardware-level safety mechanism. Even if macro logic fails, the red light correctly indicates a fault.
Status Macros
[gcode_macro LED_STATUS]
description: Set LED warning light status
gcode:
{% set STATUS = params.STATUS|default("idle")|lower %}
# First turn off all lights
SET_PIN PIN=led_red VALUE=0
SET_PIN PIN=led_green VALUE=0
SET_PIN PIN=led_yellow VALUE=0
# Set lights according to status (active low: VALUE=1 means pin outputs low level, light on)
{% if STATUS == "printing" %}
SET_PIN PIN=led_green VALUE=1
SET_PIN PIN=led_yellow VALUE=1
{% elif STATUS == "ready" %}
SET_PIN PIN=led_green VALUE=1
{% elif STATUS == "warning" %}
SET_PIN PIN=led_yellow VALUE=1
{% elif STATUS == "error" %}
SET_PIN PIN=led_red VALUE=1
{% endif %}
Status Description
| Status Parameter | Light Effect | Use Case |
|---|---|---|
printing | Green + Yellow on | Currently printing |
ready | Green on | Klipper connected, printer ready |
warning | Yellow on | Warning state (e.g., abnormal temperature but no error) |
error | Red on | Error occurred, requires attention |
idle | All off | Idle state (default) |
Call example: LED_STATUS STATUS=printing
Automatic State Detection (Optional)
To automatically detect Klipper status without modifying print macros, use the following configuration.
# Status variable macro (for recording the last state to avoid flickering from repeated updates)
[gcode_macro _LED_STATE]
variable_last_status: "unknown"
gcode:
# This macro only stores variables, no action needed
# Automatic state detection
[delayed_gcode LED_AUTO_UPDATE]
initial_duration: 1
gcode:
{% set idle = printer.idle_timeout.state|string|upper %}
{% set printing = printer.print_stats.state|string|upper %}
{% set current = "unknown" %}
# Determine current state
{% if printing == "PRINTING" or printing == "PAUSED" %}
{% set current = "printing" %}
{% elif idle == "READY" or idle == "IDLE" %}
{% set current = "ready" %}
{% endif %}
# Only update LED when state changes to avoid flickering
{% set last = printer["gcode_macro _LED_STATE"].last_status %}
{% if current != last %}
SET_GCODE_VARIABLE MACRO=_LED_STATE VARIABLE=last_status VALUE='"{current}"'
LED_STATUS STATUS={current}
{% endif %}
# Continue polling
UPDATE_DELAYED_GCODE ID=LED_AUTO_UPDATE DURATION=1
State Determination Logic
| Klipper State | Detection Condition | LED Effect |
|---|---|---|
| Printing | print_stats.state = printing/paused | Green + Yellow on |
| Connected | idle_timeout.state = ready/idle | Green on |
| Error | Klipper enters Shutdown | Red on (handled automatically by shutdown_value) |
| Other | State not detected above | All off |
How It Works
- The
_LED_STATEmacro stores the last state for comparison LED_AUTO_UPDATEchecks the Klipper state every secondLED_STATUSis called to update the lights only when the state changes, preventing flickering- When Klipper errors and enters Shutdown,
shutdown_valueautomatically takes over the red light