Comment on page
Configuración Klipper en laminadores
Klipper es un firmware de impresoras 3D increíblemente flexible que podemos configurar basándonos en ficheros de configuración.
Los laminadores disponen de una opción para indicar el tipo de gcode (G-Code flavor) que queremos generar.
Normalmente, estos usan por defecto Marlin que funciona bien con Klipper al igual que Smoothieware.
Nuestro laminador favorito, SuperSlicer o Bambu Studio/OrcaSlicer (PrusaSlicer lo tendrá disponible a partir de la versión 2.6) tiene una opción específica para Klipper que podemos encontrar en el perfil de impresora General/Firmware:

A continuación tenéis links a grupos de laminadores en Telegram por si necesitáis más información:
Laminadores como Cura necesitan de ciertos ajustes para evitar que generen ciertos gcodes que pueden no llevarse bien con Klipper, de igual forma laminadores con G-Code flavor Marlin2 pueden ocasionar problemas similares
Volviendo a Cura, os aconsejamos utilizar el script del compañero Pedro Lamas donde con su post-processing script podemos añadir cualquier ajuste para mejorar el funcionamiento con Klipper.
Bambu Studio/OrcaSlicer (fork del primero con opciones interesantes añadidas):
Bambu Studio utiliza ARC, significa que usa los gcodes G2/G3, por defecto en algunos perfiles y que funcione correctamente necesitaremos activar el soporte ARC en nuestro Klipper.
IMPORTANTE!!! por la forma de funcionar de Klipper ARC no proporciona mejoras en la calidad de las piezas y si más carga al procesar el gcode. Os aconsejamos ir a la parte final y deshabilitar las funciones ARC del laminador.
Lo ideal es crear un nuevo fichero de configuración, bambu_studio.cfg por ejemplo, y añadirlo como include en nuestro printer.cfg.
bambu_studio.cfg
[gcode_arcs]
resolution: 0.1
[gcode_macro m201]
gcode:
{% if 'X' in params or 'Y' in params %}
{% set accel = (params.X|default(params.Y)|float,
params.Y|default(params.X)|float)|min %}
SET_VELOCITY_LIMIT ACCEL={accel} ACCEL_TO_DECEL={accel * 0.5}
{% else %}
SET_VELOCITY_LIMIT
{% endif %}
[gcode_macro m203]
gcode:
{% if 'X' in params or 'Y' in params %}
{% set speed = (params.X|default(params.Y)|float,
params.Y|default(params.X)|float)|min %}
SET_VELOCITY_LIMIT VELOCITY={speed}
{% else %}
SET_VELOCITY_LIMIT
{% endif %}
[gcode_macro M205]
gcode:
{% if 'X' in params or 'Y' in params %}
{% set corner_speed = (params.X|default(params.Y)|float,
params.Y|default(params.X)|float)|min %}
SET_VELOCITY_LIMIT SQUARE_CORNER_VELOCITY={corner_speed}
{% else %}
SET_VELOCITY_LIMIT
{% endif %}
[gcode_macro M900]
gcode:
SET_PRESSURE_ADVANCE ADVANCE={params.K}
Tenéis un ejemplo de nuestro compañer Laureano a modo de ejemplo también:
En el caso que no queráis usar ARC porque vuestra máquina no lo soporte o simplemente porque no le veis beneficio aseguraos que las siguientes funciones están deshabilitadas:
- Arc fitting
- Z-hop type : Spiral lift


Los laminadores suelen contar con gcodes de inicio y de final que se encargan de realizar los procesos pre y postimpresión que pueden impactar en la calidad de nuestra impresión.
Dado que en Klipper podemos configurar nuestras propias macros, algo que suele ser muy útil es la creación de macros para el inicio de impresión (START_PRINT) y final de impresión (END_PRINT).
Os vamos a sugerir como poder personalizar vuestros gcodes pre y post usando las macros de Klipper que os van a permitir:
Si buscas un sistema más completo, avanzado y personalizable a los scripts básicos que te sugerimos a continuación te aconsejamos que revises nuestro bundle para Klipper modular aquí.
IMPORTANTE!!!
Configuración Linea Purga Inteligente.
- Puede ser necesario que vuestra sección [extruder] se indique el max_extrude_cross_section... un valor de 5 debería de ser suficiente generalmente:
printer.cfg
[extruder]
...
max_extrude_cross_section: 5
- Otro ajuste necesario para vuestra sección [extruder] se indique el max_extrude_only_distance... el valor aconsejable suele ser >101 (en caso de no estar definido usa 50) para por ejemplo permitir los tests típicos de calibración del extrusor. Deberías ajustar el valor en base a lo comentado anteriormente del test o la configuración de tu variable_line_length y/o variable_purge_amount.
Los siguientes ajustes se han de realizar en la macro START_PRINT en la sección inicial donde se encuentran las variables de configuración:
- Mediante variable_adaptive_enable , con valor True nuestra linea de purga va a ser dinámica en base al tamaño de nuestra pieza a imprimir
- En variable_flow_rate podemos ajustar el máximo flow rate de nuestro extrusor. El valor de 12mm3/s suele ser válido para sistemas de extrusión normales y 24 para alto flujo
- variable_line_length donde indicaremos el tamaño deseado en mm de nuestra linea de purga... un valor de 1/5 de nuestro eje X suele ser lo indicado
- variable_purge_amount la cantidad de filamento en mm que queremos purgar
- variable_x_default, y mismo parámetro para y, serán las coordenadas donde queremos que comience nuestra linea de purga. En el caso de tener activada la linea de purga automática no se tiene en cuenta
También contamos con la macro SETUP_START_PRINT que desde la UI podemos ajustar estos parámetros.
IMPORTANTE!!!
Configuración Nivelación.
En el ejemplo START_PRINT incluído en esta guía facilita el proceso de nivelación pudiendo adaptarse a diferentes usos:
Los siguientes ajustes se han de realizar en la macro START_PRINT en la sección inicial donde se encuentran las variables de configuración:
- variable_calibrate_z_tilt si contamos doble Z con z-tilt podremos hacer un nivelado Z-tilt (True) o no (False).
- variable_calibrate_bed_mesh para indicar si queremos hacer una malla al inicio de cada impresión (True) o si queremos aprovechar un mallado ya guardado (False).
También podemos añadir la siguiente macro para que haga el proceso de igual forma que se hacía antes del cambio en Klipper.
[delayed_gcode bed_mesh_init]
initial_duration: .01
gcode:
BED_MESH_PROFILE LOAD=default
En el ejemplo START_PRINT incluído en esta guía usaremos notificaciones para indicar en que paso estamos durante el proceso de inicio de impresión por lo que necesitamos que tu printer.cfg o includes del mismo tengan la sección [respond]
printer.cfg
[respond]
- Ejecutar una retracción del filamento
- Presentar la impresión para poder retirarla de forma sencilla
- Apagado de los motores
Para ejecutar estas macros en nuestro laminador:
Estas configuraciones suelen encontrarse dentro de las opciones dentro de la configuración de impresora. Revisa en el caso de tu laminador donde ajustar
- gcode de inicio START_PRINT, usando placeholders para pasar los valores de temperatura de filamento y cama de forma dinámica:
PrusaSlicer-SuperSlicer
Bambu Studio
Cura
IdeaMaker
Simplify3D
PrusaSlicer
M190 S0 ; Prevents prusaslicer from prepending m190 to the gcode ruining our macro
M109 S0 ; Prevents prusaslicer from prepending m109 to the gcode ruining our macro
SET_PRINT_STATS_INFO TOTAL_LAYER=[total_layer_count] ; Provide layer information
START_PRINT EXTRUDER_TEMP=[first_layer_temperature[initial_extruder]] BED_TEMP=[first_layer_bed_temperature] PRINT_MIN={first_layer_print_min[0]},{first_layer_print_min[1]} PRINT_MAX={first_layer_print_max[0]},{first_layer_print_max[1]}
SuperSlicer - contamos con la opción de poder ajustar la temperatura de cerramiento (CHAMBER)
M190 S0 ; Prevents prusaslicer from prepending m190 to the gcode ruining our macro
M109 S0 ; Prevents prusaslicer from prepending m109 to the gcode ruining our macro
SET_PRINT_STATS_INFO TOTAL_LAYER=[total_layer_count] ; Provide layer information
START_PRINT EXTRUDER_TEMP=[first_layer_temperature[initial_extruder]] BED_TEMP=[first_layer_bed_temperature] CHAMBER=[chamber_temperature] PRINT_MIN={first_layer_print_min[0]},{first_layer_print_min[1]} PRINT_MAX={first_layer_print_max[0]},{first_layer_print_max[1]}

Ejemplo para PrusaSlicer/SuperSlicer
M190 S0 ; Prevents prusaslicer engine from prepending m190 to the gcode ruining our macro
M109 S0 ; Prevents prusaslicer engine from prepending m109 to the gcode ruining our macro
SET_PRINT_STATS_INFO TOTAL_LAYER=[total_layer_count] ; Provide layer information
START_PRINT EXTRUDER_TEMP=[nozzle_temperature_initial_layer] BED_TEMP=[first_layer_bed_temperature] CHAMBER=[chamber_temperature] PRINT_MIN={first_layer_print_min[0]},{first_layer_print_min[1]} PRINT_MAX={first_layer_print_max[0]},{first_layer_print_max[1]}

START_PRINT EXTRUDER_TEMP={material_print_temperature_layer_0} BED_TEMP={material_bed_temperature_layer_0} PRINT_MIN=%MINX%,%MINY% PRINT_MAX=%MAXX%,%MAXY%
Deberemos de instalar el plugin Post Process Plugin (by frankbags) desde el menú Help/Show configuration Folder... copiaremos el script del link anterior dentro de la carpeta script.
Reiniciamos Cura e iremos a Extensions/Post processing/Modify G-Code y seleccionaremos Mesh Print Size.
START_PRINT EXTRUDER_TEMP={temperature_extruder1} BED_TEMP={temperature_heatbed}
START_PRINT EXTRUDER_TEMP=[extruder0_temperature] BED_TEMP=[bed0_temperature]
Los placeholders son unos "alias" o variables que usan los laminadores para que a la hora de generar el gcode sustituyen por los valores configurados en el perfil de impresión.
En los siguientes links podéis encontrar un listado de estos para: PrusaSlicer, SuperSlicer (además de los del anterior), Bambu Studio y Cura.
El uso de estos permiten que nuestras macros sean dinámicas.
- gcode de final END_PRINT, en este caso al no usar placeholders es común a todos los laminadores
END_PRINT
Podemos subir nuestros gcodes directamente desde el laminador, algo que es muy cómodo. Moonraker emula la API de Octoprint, algo muy útil para hacerlo compatible con cualquier herramienta que use Octoprint.
Para habilitar la emulación Octoprint tendremos que añadir al ficher de configuración de Moonraker lo siguiente:
[octoprint_compat]
PrusaSlicer/SuperSlicer (< v2.3.0)
Cura
Habilitaremos el modo experto y cambiaremos las opciones en Printer Settings / General como podemos ver en la siguiente captura.

Os recordamos que lo hemos de configurar desde una "Impresora Física"
Instalaremos la extensión OctoPrint-Connection desde el Marketplace. Iremos a Settings > Printer > Manage Printers y buscaremos el botón Connect OctoPrint y añadiremos nuestra impresora tal como vemos en la siguiente captura, podemos poner cualquier cosa en API Key.

Podemos generar previews de nuestras piezas que podemos visualizar en nuestra UI de Klipper para identificar mejor la pieza.

PrusaSlicer (< v2.3.0)
Superslicer (< v2.2.54.0)
Cura
IdeaMaker (< v4.2.1)
Cambiaremos al modo Experto y en General / Firmware pondremos 32x32,400x300 en G-code thumbnails:

Cambiaremos al modo Experto y en Printer Settings :


Para que podamos disponer del progreso de capas en nuestra UI es aconsejable configurar correctamente nuestro laminador:
Para habilitar la previsualización abriremos Advanced en Printer Settings, habilitaremos la opción Gcode Thumbnails for Pctoprint and Mainsail y en Resolution pondremos 400x400:

Para poder disponer del progreso de capas en nuestra UI de Klipper:
PrusaSlicer/SuperSlicer
Iremos a Slicer/SuperSlicer > Printer Settings > Custom Gcode > After layer change Gcode y añadiremos el siguiente gcode :
M117 Layer {layer_num+1}/[total_layer_count] : {filament_settings_id[0]} ;Update layer progress for LCD displays
SET_PRINT_STATS_INFO CURRENT_LAYER={layer_num + 1} ;Update layer progress 2nd screen like KlipperScreen

Captura de OrcaSlicer
Dado que Bambu Studio y OrcaSlicer se basan en PrusaSlicer estas configuraciones deberían de funcionar en ellos.
Nuestra UI de Klipper puede usar diferentes metodos para el cálculo del tiempo estimado de acabado (estimación y ETA). Normalmente podremos seleccionar el método que más nos guste o se ajuste a nuestra máquina en la configuración del UI y podremos, normalmente, seleccionar entre el fichero, filamento o el slicer:
En el caso de seleccionar varios hará una media de ellos.

En el caso que usemos KlipperScreen podemos mejorar la información mostrada sobre las capas ajustando:
Estas opciones habilitadas puede provocar calidad pobre de nuestras impresiones y lo aconsejable es la utilización de Pressure Advance.
Por otro lado, las funciones que suelen ir bien es emplear los valores de retracciones desde el laminador, las opciones de wipe o wipe on retract.
Última actualización 2mo ago