Feat: Replace custom KNCM with official Open-Elegoo-Community version
Replaced our custom nozzle cleaning macros with the official Klipper Nozzle Clean Macro (KNCM) from Open-Elegoo-Community. Changes: - Added KNCM/nozzle_clean.cfg (official macro code) - Updated KNCM_settings.cfg with official variable-based config - Updated KNCM/KNCM_settings.cfg (copy for include path) - Removed custom CLEAN_NOZZLE, SMART_PARK, LINE_PURGE macros Benefits of official KNCM: - Proper wiper position calculation (not hardcoded X0 Y0!) - Variable-based configuration (easy to customize) - Filament-specific cleaning temperatures - Sinusoidal wiping pattern for better cleaning - PurgeShake to remove strings before wiping - Actively maintained by Open-Elegoo-Community Neptune 4 Plus specific settings: - printer_bed_y_max: 330 - wiping_axis: Y (bed moves) - cleaning_height: 30 (CALIBRATE THIS!) - bed_corner_to_wiper_offset: 40.5 (MEASURE THIS!) Reference: https://github.com/Open-Elegoo-Community/klipper-nozzle-clean-macro
This commit is contained in:
parent
9624c1fb74
commit
e22df9b5ab
3 changed files with 673 additions and 112 deletions
473
KNCM/nozzle_clean.cfg
Normal file
473
KNCM/nozzle_clean.cfg
Normal file
|
|
@ -0,0 +1,473 @@
|
|||
#############################################################################
|
||||
# NOZZLE CLEAN CODE
|
||||
#############################################################################
|
||||
|
||||
# ------------------------------------------------------------------------
|
||||
# !!! DO NOT EDIT THIS FILE !!! - Changes below are unsupported
|
||||
# ------------------------------------------------------------------------
|
||||
|
||||
[gcode_macro CLEAN_NOZZLE]
|
||||
description: Nozzle cleaning using a brush
|
||||
gcode:
|
||||
# ------------------------------------------------------------------------
|
||||
# LOAD SETTINGS
|
||||
# ------------------------------------------------------------------------
|
||||
# Load variables from KNCM_settings.cfg
|
||||
{% set KNCM_SETTINGS = printer['gcode_macro _KNCM_SETTINGS'] %}
|
||||
# cleaningHeight
|
||||
{% set cleaningHeight = KNCM_SETTINGS.cleaning_height %}
|
||||
# wipingAxis
|
||||
{% set wipingAxis = KNCM_SETTINGS.wiping_axis %}
|
||||
# printerBedYMax
|
||||
{% set printerBedYMax = KNCM_SETTINGS.printer_bed_y_max %}
|
||||
# cleaningLoops
|
||||
{% set cleaningLoops = KNCM_SETTINGS.cleaning_loops %}
|
||||
# purgeSHake
|
||||
{% set purgeShake = KNCM_SETTINGS.purge_shake %}
|
||||
# waitNozzleTempRestore
|
||||
{% set waitNozzleTempRestore = KNCM_SETTINGS.wait_nozzle_temp_restore %}
|
||||
# debug
|
||||
{% set debug = KNCM_SETTINGS.debug %}
|
||||
# acceleration
|
||||
{% set acceleration = KNCM_SETTINGS.acceleration %}
|
||||
# speed
|
||||
{% set travelSpeed = KNCM_SETTINGS.travel_speed %}
|
||||
{% set slowSpeed = KNCM_SETTINGS.slow_speed %}
|
||||
{% set fastSpeed = KNCM_SETTINGS.fast_speed %}
|
||||
# cleaningTemperatures
|
||||
{% set cleaningTemperatures = KNCM_SETTINGS.cleaning_temperatures %}
|
||||
# wiperWidth
|
||||
{% set wiperWidth = KNCM_SETTINGS.wiper_width %}
|
||||
# wiperLength
|
||||
{% set wiperLength = KNCM_SETTINGS.wiper_length %}
|
||||
# wiperWallOffset
|
||||
{% set wiperWallOffset = KNCM_SETTINGS.wiper_walloffset %}
|
||||
# bedCornerToWiperOffset
|
||||
{% set bedCornerToWiperOffset = KNCM_SETTINGS.bed_corner_to_wiper_offset %}
|
||||
# waves
|
||||
{% set waves = KNCM_SETTINGS.waves %}
|
||||
|
||||
# ------------------------------------------------------------------------
|
||||
# DEBUG MESSAGE - LOADED VARIABLES
|
||||
# ------------------------------------------------------------------------
|
||||
{% if debug == 1 %}
|
||||
RESPOND MSG="INFO: loaded Variables"
|
||||
RESPOND MSG=" - cleaningHeight : { cleaningHeight }"
|
||||
RESPOND MSG=" - wipingAxis : { wipingAxis }"
|
||||
RESPOND MSG=" - printerBedYMax : { printerBedYMax }"
|
||||
RESPOND MSG=" - cleaningLoops : { cleaningLoops }"
|
||||
RESPOND MSG=" - purgeShake : { purgeShake }"
|
||||
RESPOND MSG=" - waitNozzleTempRestore : { waitNozzleTempRestore }"
|
||||
RESPOND MSG=" - debug : { debug }"
|
||||
RESPOND MSG=" - wiperWidth : { wiperWidth }"
|
||||
RESPOND MSG=" - wiperLength : { wiperLength }"
|
||||
RESPOND MSG=" - wiperWallOffset : { wiperWallOffset }"
|
||||
RESPOND MSG=" - bedCornerToWiperOffset : { bedCornerToWiperOffset }"
|
||||
RESPOND MSG=" - waves : { waves }"
|
||||
RESPOND MSG=" - acceleration : { acceleration }"
|
||||
RESPOND MSG=" - travelSpeed : { travelSpeed }"
|
||||
RESPOND MSG=" - slowSpeed : { slowSpeed }"
|
||||
RESPOND MSG=" - fastSpeed : { fastSpeed }"
|
||||
RESPOND MSG=" - cleaningTemperatures : { cleaningTemperatures }"
|
||||
{% endif %}
|
||||
|
||||
# ------------------------------------------------------------------------
|
||||
# INITIALIZE, CHECK AND PROCESS VARIABLES
|
||||
# ------------------------------------------------------------------------
|
||||
{% set filamentType = params.FILAMENT_TYPE|default("PLA")|string|upper %} # Set filamentType to the provided variable (fallback to PLA)
|
||||
{% set error = 0 %} # Initialize error variable
|
||||
|
||||
{% if wipingAxis not in ["x", "X", "y", "Y"] %} # Check for a valid wipingAxis
|
||||
RESPOND MSG="ERROR: Wiping axis configuration error. Please check your wipingAxis setting!"
|
||||
{% set error = 1 %}
|
||||
{% endif %}
|
||||
|
||||
{% if wipingAxis in ["x", "X"] %} # Check clearances for cleaning with head movements
|
||||
{% if ((printer.toolhead.axis_maximum.y - printerBedYMax) < 3.2) %}
|
||||
RESPOND MSG="ERROR: Insufficient vertical clearance between printerBedYMax ({printerBedYMax}) and nozzle max Y ({printer.toolhead.axis_maximum.y}). Minimum required: 3.2mm."
|
||||
{% set error = 1 %}
|
||||
{% endif %}
|
||||
{% if ((printerBedYMax < 1) or ((printerBedYMax > 1000))) %}
|
||||
RESPOND MSG="ERROR: Printer bed Y-axis size ({printerBedYMax}) out of expected range. Please verify configuration."
|
||||
{% set error = 1 %}
|
||||
{% endif %}
|
||||
{% elif ((printer.configfile.config.stepper_x.position_endstop|float + 3.2) > 0) %} # Check clearances for cleaning with bed movements
|
||||
RESPOND MSG="ERROR: X homing sensor position ({printer.configfile.config.stepper_x.position_endstop}) is too close to the bed. Required: ≤ -3.2mm."
|
||||
{% set error = 1 %}
|
||||
{% endif %}
|
||||
|
||||
{% if cleaningLoops < 1 %} # Check if cleaningLoops is set to a minimum of 1 loop
|
||||
RESPOND MSG="WARNING: cleaningLoops set to false value:{cleaningLoops} - changed to default 1 "
|
||||
{% set cleaningLoops = 1 %}
|
||||
{% endif %}
|
||||
|
||||
{% if wipingAxis in ["y", "Y"] %} # Cleaning using bed movement
|
||||
{% set wiperYmax = printerBedYMax %}
|
||||
{% if wiperWidth + wiperWallOffset + printer.configfile.config.stepper_x.position_endstop|float > 0 %} # limited clearance
|
||||
{% set wiperXmin = printer.configfile.config.stepper_x.position_endstop|float %}
|
||||
{% set wiperWidth = 0 - wiperWallOffset - printer.configfile.config.stepper_x.position_endstop|float %}
|
||||
{% else %}
|
||||
{% set wiperXmin = 0 - wiperWallOffset - wiperWidth %}
|
||||
{% endif %}
|
||||
{% else %} # Cleaning using head movement
|
||||
{% set wiperXmin = bedCornerToWiperOffset %}
|
||||
{% if printer.toolhead.axis_maximum.y - printerBedYMax - wiperWallOffset - wiperWidth < 0 %}
|
||||
{% set wiperYmax = printer.toolhead.axis_maximum.y %}
|
||||
{% set wiperWidth = printer.toolhead.axis_maximum.y - printerBedYMax - wiperWallOffset %}
|
||||
{% else %}
|
||||
{% set wiperYmax = printerBedYMax + wiperWallOffset + wiperWidth %}
|
||||
{% endif %}
|
||||
{% endif %}
|
||||
|
||||
{% if acceleration != 0 %}
|
||||
{% if acceleration > printer.configfile.config['printer']['max_accel']|float %}
|
||||
{% set accelerationValidated = printer.configfile.config['printer']['max_accel']|float %}
|
||||
{% else %}
|
||||
{% set accelerationValidated = acceleration %}
|
||||
{% endif %}
|
||||
{% endif %}
|
||||
|
||||
{% if travelSpeed > printer.configfile.config['printer']['max_velocity'] | float %}
|
||||
{% set travelSpeed = printer.configfile.config['printer']['max_velocity'] | float %}
|
||||
{% endif %}
|
||||
{% set travelFeedrate = travelSpeed * 60 %} # Convert travelSpeed to travelFeedrate
|
||||
{% if slowSpeed > printer.configfile.config['printer']['max_velocity'] | float %}
|
||||
{% set slowSpeed = printer.configfile.config['printer']['max_velocity'] | float / 2 %}
|
||||
{% endif %}
|
||||
{% set slowFeedrate = slowSpeed * 60 %} # Convert slowSpeed to slowFeedrate
|
||||
{% if fastSpeed > printer.configfile.config['printer']['max_velocity'] | float %}
|
||||
{% set fastSpeed = printer.configfile.config['printer']['max_velocity'] | float %}
|
||||
{% endif %}
|
||||
{% set fastFeedrate = fastSpeed * 60 %} # Convert fastSpeed to fastFeedrate
|
||||
|
||||
{% if debug == 1 %}
|
||||
RESPOND MSG="INFO: processed Variables"
|
||||
RESPOND MSG=" - wiperYmax : { wiperYmax }"
|
||||
RESPOND MSG=" - wiperXmin : { wiperXmin }"
|
||||
RESPOND MSG=" - wiperWidth : { wiperWidth }"
|
||||
RESPOND MSG=" - acceleration : { accelerationValidated }"
|
||||
RESPOND MSG=" - travelFeedrate : F{ travelFeedrate }"
|
||||
RESPOND MSG=" - slowFeedrate : F{ slowFeedrate }"
|
||||
RESPOND MSG=" - fastFeedrate : F{ fastFeedrate }"
|
||||
{% endif %}
|
||||
|
||||
# ------------------------------------------------------------------------
|
||||
# ERROR CHECK
|
||||
# ------------------------------------------------------------------------
|
||||
{% if error == 0 %} # Continue only if error is zero
|
||||
|
||||
# ------------------------------------------------------------------------
|
||||
# SET CLEANING ACCELERATION
|
||||
# ------------------------------------------------------------------------
|
||||
{% if acceleration != 0 %}
|
||||
SET_VELOCITY_LIMIT ACCEL={accelerationValidated}
|
||||
{% endif %}
|
||||
|
||||
# ------------------------------------------------------------------------
|
||||
# HOMING PROCESS
|
||||
# ------------------------------------------------------------------------
|
||||
{% if "x" not in printer.toolhead.homed_axes and "y" not in printer.toolhead.homed_axes and "z" not in printer.toolhead.homed_axes %}
|
||||
G28
|
||||
{% elif "x" not in printer.toolhead.homed_axes %}
|
||||
G28 X
|
||||
{% elif "y" not in printer.toolhead.homed_axes %}
|
||||
G28 Y
|
||||
{% elif "z" not in printer.toolhead.homed_axes %}
|
||||
G28 Z
|
||||
{% endif %}
|
||||
|
||||
# ------------------------------------------------------------------------
|
||||
# SAVE Z AXIS POSITION
|
||||
# ------------------------------------------------------------------------
|
||||
{% set zHeight = printer.toolhead.position.z %}
|
||||
{% if zHeight == 0 %}
|
||||
{% set zHeight = 10 %}
|
||||
{% set travelHeight = zHeight %}
|
||||
{% else %}
|
||||
{% set travelHeight = zHeight + 10 %}
|
||||
{% if travelHeight > printer.toolhead.axis_maximum.z|float %}
|
||||
{% set travelHeight = printer.toolhead.axis_maximum.z|float -10 %}
|
||||
{% endif %}
|
||||
{% endif %}
|
||||
{% if debug == 1 %}
|
||||
RESPOND MSG="INFO: travelHeight set to {travelHeight}"
|
||||
{% endif %}
|
||||
|
||||
# ------------------------------------------------------------------------
|
||||
# CHECK FOR BLENDED FILAMENTS
|
||||
# ------------------------------------------------------------------------
|
||||
{% if "-" in filamentType %}
|
||||
{% set baseFilament = filamentType.split("-")[0] %}
|
||||
{% set stringSplitted = 1 %}
|
||||
{% else %}
|
||||
{% set baseFilament = filamentType %}
|
||||
{% set stringSplitted = 0 %}
|
||||
{% endif %}
|
||||
|
||||
# ------------------------------------------------------------------------
|
||||
# EVALUATE CLEANING TEMPERATURE
|
||||
# ------------------------------------------------------------------------
|
||||
{% if baseFilament in cleaningTemperatures %}
|
||||
{% set cleaningTemperature = cleaningTemperatures[baseFilament] %}
|
||||
{% if debug == 1 %}
|
||||
{% if stringSplitted == 0 %}
|
||||
RESPOND MSG="INFO: Detected filament type {filamentType}. Cleaning temperature set to {cleaningTemperature}c."
|
||||
{% else %}
|
||||
RESPOND MSG="INFO: Detected filament type {filamentType} (base: {baseFilament}). Cleaning temperature set to {cleaningTemperature}c."
|
||||
{% endif %}
|
||||
{% endif %}
|
||||
{% else %}
|
||||
{% set cleaningTemperature = 140 %}
|
||||
RESPOND MSG="WARNING: Unknown filament type {filamentType}. Default cleaning temperature of {cleaningTemperature}c will be used."
|
||||
{% endif %}
|
||||
|
||||
# ------------------------------------------------------------------------
|
||||
# SAVE NOZZLE TARGET TEMPERATURE
|
||||
# ------------------------------------------------------------------------
|
||||
{% set nozzleTargetTemperature = printer['extruder'].target %}
|
||||
|
||||
# ------------------------------------------------------------------------
|
||||
# HEAT EXTRUDER
|
||||
# ------------------------------------------------------------------------
|
||||
{% if cleaningTemperature != nozzleTargetTemperature %}
|
||||
SET_HEATER_TEMPERATURE HEATER=extruder TARGET={cleaningTemperature}
|
||||
{% if debug == 1 %}
|
||||
RESPOND MSG="INFO: Heating extruder to {cleaningTemperature}c for cleaning..."
|
||||
{% endif %}
|
||||
TEMPERATURE_WAIT SENSOR=extruder MINIMUM={cleaningTemperature-4} MAXIMUM={cleaningTemperature+10}
|
||||
{% endif %}
|
||||
|
||||
# ------------------------------------------------------------------------
|
||||
# CLEANING SEQUENCE
|
||||
# ------------------------------------------------------------------------
|
||||
{% if debug == 1 %}
|
||||
RESPOND MSG="INFO: Initiating nozzle cleaning sequence..."
|
||||
{% endif %}
|
||||
|
||||
# ------------------------------------------------------------------------
|
||||
# Purge Shake
|
||||
# ------------------------------------------------------------------------
|
||||
{% if purgeShake == 1 %}
|
||||
# Travel to PurgeShake position
|
||||
G90
|
||||
G1 Z{travelHeight} F3000
|
||||
{% if wipingAxis in ["y", "Y"] %}
|
||||
{% if debug == 1 %}
|
||||
RESPOND MSG="INFO: Shaking movement starting at X=0, Y={printerBedYMax-1} (1mm safety margin)."
|
||||
{% endif %}
|
||||
G1 X0 Y{printerBedYMax-1} F{travelFeedrate}
|
||||
{% else %}
|
||||
{% if debug == 1 %}
|
||||
RESPOND MSG="INFO: Shaking movement starting at X={bedCornerToWiperOffset+wiperLength+1}, Y={printerBedYMax-1} (1mm safety margin)."
|
||||
{% endif %}
|
||||
G1 X{bedCornerToWiperOffset+wiperLength+1} Y{printerBedYMax-1} F{travelFeedrate}
|
||||
{% endif %}
|
||||
|
||||
# Quick left/right movements to clear filament strings
|
||||
G91
|
||||
G1 X20 F{fastFeedrate}
|
||||
G1 X-20
|
||||
G1 X20
|
||||
G1 X-20
|
||||
G1 X20
|
||||
G1 X-20
|
||||
{% endif %}
|
||||
|
||||
# ------------------------------------------------------------------------
|
||||
# Nozzle cleaning
|
||||
# ------------------------------------------------------------------------
|
||||
{% if wipingAxis in ["y", "Y"] %}
|
||||
# --- BED MOVEMENT CLEANING SEQUENCE ---
|
||||
{% if debug == 1 %}
|
||||
RESPOND MSG="INFO: Repeating cleaning motions for {cleaningLoops} times"
|
||||
{% if wiperXmin == printer.configfile.config.stepper_x.position_endstop|float %}
|
||||
RESPOND MSG="INFO: Starting first cleaning passes near X endstop at X={wiperXmin+0.2}, Y={wiperYmax} (limited X clearance)."
|
||||
{% else %}
|
||||
RESPOND MSG="INFO: Starting first cleaning passes at X={wiperXmin+(wiperWidth/4)}, Y={wiperYmax}."
|
||||
{% endif %}
|
||||
{% endif %}
|
||||
|
||||
{% for loops in range(0, cleaningLoops) %}
|
||||
G90
|
||||
{% if wiperXmin == printer.configfile.config.stepper_x.position_endstop|float %}
|
||||
G1 X{wiperXmin+0.2} Y{wiperYmax} F{travelFeedrate}
|
||||
{% else %}
|
||||
G1 X{wiperXmin+(wiperWidth/4)} Y{wiperYmax} F{travelFeedrate}
|
||||
{% endif %}
|
||||
|
||||
# Lower nozzle and start cleaning motion
|
||||
G1 Z{cleaningHeight} F1200
|
||||
|
||||
# Perform pseudosinusoidal cleaning motion
|
||||
G91
|
||||
{%set ymov=(wiperLength/(waves*4)) %}
|
||||
G1 F{slowFeedrate}
|
||||
{% for i in range(0,waves) %}
|
||||
G1 X{wiperWidth/2} Y-{ymov}
|
||||
G1 Y-{ymov}
|
||||
G1 X-{wiperWidth/2} Y-{ymov}
|
||||
G1 Y-{ymov}
|
||||
{% endfor %}
|
||||
G1 X{wiperWidth/2}
|
||||
{% for i in range(0,waves) %}
|
||||
G1 X-{wiperWidth/2} Y{ymov}
|
||||
G1 Y{ymov}
|
||||
G1 X{wiperWidth/2} Y{ymov}
|
||||
G1 Y{ymov}
|
||||
{% endfor %}
|
||||
|
||||
G1 F{fastFeedrate}
|
||||
G1 X-{wiperWidth/2}
|
||||
{% for i in range(0,waves) %}
|
||||
G1 Y-{ymov}
|
||||
G1 X{wiperWidth/2} Y-{ymov}
|
||||
G1 Y-{ymov}
|
||||
G1 X-{wiperWidth/2} Y-{ymov}
|
||||
{% endfor %}
|
||||
G1 X{wiperWidth/2}
|
||||
{% for i in range(0,waves) %}
|
||||
G1 Y{ymov}
|
||||
G1 X-{wiperWidth/2} Y{ymov}
|
||||
G1 Y{ymov}
|
||||
G1 X{wiperWidth/2} Y{ymov}
|
||||
{% endfor %}
|
||||
|
||||
G1 F{slowFeedrate}
|
||||
G1 X-{wiperWidth/2}
|
||||
{% for i in range(0,waves) %}
|
||||
G1 X{wiperWidth/2} Y-{2*ymov}
|
||||
G1 X-{wiperWidth/2} Y-{2*ymov}
|
||||
{% endfor %}
|
||||
G1 X{wiperWidth/2}
|
||||
{% for i in range(0,waves) %}
|
||||
G1 X-{wiperWidth/2} Y{2*ymov}
|
||||
G1 X{wiperWidth/2} Y{2*ymov}
|
||||
{% endfor %}
|
||||
{% endfor %}
|
||||
|
||||
{% else %}
|
||||
# --- HEAD MOVEMENT CLEANING SEQUENCE ---
|
||||
{% if debug == 1 %}
|
||||
RESPOND MSG="INFO: Repeating cleaning motions for {cleaningLoops} times"
|
||||
{% if wiperYmax == printer.toolhead.axis_maximum.y %}
|
||||
RESPOND MSG="INFO: Starting first cleaning passes near bed edge at X={wiperXmin+wiperLength}, Y={wiperYmax-0.1} (limited Y clearance)."
|
||||
{% else %}
|
||||
RESPOND MSG="INFO: Starting first cleaning passes at X={wiperXmin+wiperLength}, Y={wiperYmax-(wiperWidth/4)}."
|
||||
{% endif %}
|
||||
{% endif %}
|
||||
|
||||
{% for loops in range(0, cleaningLoops) %}
|
||||
G90
|
||||
{% if wiperYmax == printer.toolhead.axis_maximum.y %}
|
||||
G1 X{wiperXmin+wiperLength} Y{wiperYmax-0.1} F{travelFeedrate}
|
||||
{% else %}
|
||||
G1 X{wiperXmin+wiperLength} Y{wiperYmax-(wiperWidth/4)} F{travelFeedrate}
|
||||
{% endif %}
|
||||
|
||||
# Lower nozzle and start cleaning motion
|
||||
G1 Z{cleaningHeight} F1200
|
||||
|
||||
# Perform pseudosinusoidal cleaning motion
|
||||
G91
|
||||
{%set xmov=(wiperLength/(waves*4)) %}
|
||||
G1 F{slowFeedrate}
|
||||
{% for i in range(0,waves) %}
|
||||
G1 X-{xmov} Y-{wiperWidth}
|
||||
G1 X-{xmov}
|
||||
G1 X-{xmov} Y+{wiperWidth}
|
||||
G1 X-{xmov}
|
||||
{% endfor %}
|
||||
G1 Y-{wiperWidth}
|
||||
{% for i in range(0,waves) %}
|
||||
G1 X{xmov} Y+{wiperWidth}
|
||||
G1 X{xmov}
|
||||
G1 X{xmov} Y-{wiperWidth}
|
||||
G1 X{xmov}
|
||||
{% endfor %}
|
||||
|
||||
G1 F{fastFeedrate}
|
||||
G1 Y+{wiperWidth}
|
||||
{% for i in range(0,waves) %}
|
||||
G1 X-{xmov}
|
||||
G1 X-{xmov} Y-{wiperWidth}
|
||||
G1 X-{xmov}
|
||||
G1 X-{xmov} Y+{wiperWidth}
|
||||
{% endfor %}
|
||||
G1 Y-{wiperWidth}
|
||||
{% for i in range(0,waves) %}
|
||||
G1 X{xmov}
|
||||
G1 X{xmov} Y+{wiperWidth}
|
||||
G1 X{xmov}
|
||||
G1 X{xmov} Y-{wiperWidth}
|
||||
{% endfor %}
|
||||
|
||||
G1 F{slowFeedrate}
|
||||
G1 Y+{wiperWidth}
|
||||
{% for i in range(0,waves) %}
|
||||
G1 X-{xmov*2} Y-{wiperWidth}
|
||||
G1 X-{xmov*2} Y+{wiperWidth}
|
||||
{% endfor %}
|
||||
G1 Y-{wiperWidth}
|
||||
{% for i in range(0,waves) %}
|
||||
G1 X{xmov*2} Y+{wiperWidth}
|
||||
G1 X{xmov*2} Y-{wiperWidth}
|
||||
{% endfor %}
|
||||
{% endfor %}
|
||||
{% endif %}
|
||||
|
||||
# ------------------------------------------------------------------------
|
||||
# Restore saved nozze target temperature & move to middle of bed
|
||||
# ------------------------------------------------------------------------
|
||||
{% if waitNozzleTempRestore == 0 %}
|
||||
SET_HEATER_TEMPERATURE HEATER=extruder TARGET={nozzleTargetTemperature}
|
||||
G1 Z{travelHeight} F3000
|
||||
{% else %}
|
||||
G1 Z{travelHeight} F3000
|
||||
{% if nozzleTargetTemperature <= 60 %} # Nozzle is considered cold, use fans at 100% for faster cooldown
|
||||
SET_HEATER_TEMPERATURE HEATER=extruder TARGET={nozzleTargetTemperature}
|
||||
M106 S255
|
||||
{% if debug == 1 %}
|
||||
RESPOND MSG="INFO: Nozzle was cold. Waiting for temperature to rise into 50-60c range..."
|
||||
{% endif %}
|
||||
TEMPERATURE_WAIT SENSOR=extruder MINIMUM={50} MAXIMUM={60}
|
||||
M106 S0
|
||||
{% if debug == 1 %}
|
||||
RESPOND MSG="INFO: Nozzle temperature reached target range (50-60c)."
|
||||
{% endif %}
|
||||
{% elif nozzleTargetTemperature > 60 and nozzleTargetTemperature < cleaningTemperature %} # Nozzle is preheated, use fans at 50% for faster cooldown
|
||||
SET_HEATER_TEMPERATURE HEATER=extruder TARGET={nozzleTargetTemperature}
|
||||
M106 S128
|
||||
{% if debug == 1 %}
|
||||
RESPOND MSG="INFO: Restoring nozzle temperature to {nozzleTargetTemperature}c. Please wait for stabilization..."
|
||||
{% endif %}
|
||||
TEMPERATURE_WAIT SENSOR=extruder MINIMUM={nozzleTargetTemperature} MAXIMUM={nozzleTargetTemperature+10}
|
||||
M106 S0
|
||||
{% if debug == 1 %}
|
||||
RESPOND MSG="INFO: Nozzle temperature stabilized at ~{nozzleTargetTemperature}c."
|
||||
{% endif %}
|
||||
{% elif nozzleTargetTemperature >= cleaningTemperature %} # Nozzle is hot, use no fans for faster heating
|
||||
SET_HEATER_TEMPERATURE HEATER=extruder TARGET={nozzleTargetTemperature}
|
||||
{% if debug == 1 %}
|
||||
RESPOND MSG="INFO: Restoring nozzle temperature to {nozzleTargetTemperature}c. Please wait for stabilization..."
|
||||
{% endif %}
|
||||
TEMPERATURE_WAIT SENSOR=extruder MINIMUM={nozzleTargetTemperature} MAXIMUM={nozzleTargetTemperature+10}
|
||||
{% if debug == 1 %}
|
||||
RESPOND MSG="INFO: Nozzle temperature stabilized at ~{nozzleTargetTemperature}c."
|
||||
{% endif %}
|
||||
{% endif %}
|
||||
G90
|
||||
G1 X{printer.toolhead.axis_maximum.x/2} Y{printer.toolhead.axis_maximum.y/2} F{travelFeedrate}
|
||||
{% endif %}
|
||||
|
||||
# ------------------------------------------------------------------------
|
||||
# Reset Acceleration
|
||||
# ------------------------------------------------------------------------
|
||||
SET_VELOCITY_LIMIT ACCEL={printer.configfile.config['printer']['max_accel']|float}
|
||||
|
||||
# ------------------------------------------------------------------------
|
||||
# Print finish message
|
||||
# ------------------------------------------------------------------------
|
||||
{% if debug == 1 %}
|
||||
RESPOND MSG="INFO: Nozzle cleaning sequence complete."
|
||||
{% endif %}
|
||||
{% endif %}
|
||||
Loading…
Add table
Add a link
Reference in a new issue