Variable tool change purge (#14618)
This commit is contained in:
		
				
					committed by
					
						 Scott Lahteine
						Scott Lahteine
					
				
			
			
				
	
			
			
			
						parent
						
							cbe4bf2ba8
						
					
				
				
					commit
					ce02c6cee2
				
			| @@ -32,6 +32,7 @@ void M217_report(const bool eeprom=false) { | ||||
|   #if ENABLED(TOOLCHANGE_FILAMENT_SWAP) | ||||
|     serialprintPGM(eeprom ? PSTR("  M217") : PSTR("Toolchange:")); | ||||
|     SERIAL_ECHOPAIR(" S", LINEAR_UNIT(toolchange_settings.swap_length)); | ||||
|     SERIAL_ECHOPAIR(" E", LINEAR_UNIT(toolchange_settings.extra_prime)); | ||||
|     SERIAL_ECHOPAIR(" P", LINEAR_UNIT(toolchange_settings.prime_speed)); | ||||
|     SERIAL_ECHOPAIR(" R", LINEAR_UNIT(toolchange_settings.retract_speed)); | ||||
|  | ||||
| @@ -54,6 +55,7 @@ void M217_report(const bool eeprom=false) { | ||||
|  * M217 - Set SINGLENOZZLE toolchange parameters | ||||
|  * | ||||
|  *  S[linear]   Swap length | ||||
|  *  E[linear]   Purge length | ||||
|  *  P[linear/m] Prime speed | ||||
|  *  R[linear/m] Retract speed | ||||
|  *  X[linear]   Park X (Requires TOOLCHANGE_PARK) | ||||
| @@ -68,18 +70,29 @@ void GcodeSuite::M217() { | ||||
|   #if ENABLED(TOOLCHANGE_FILAMENT_SWAP) | ||||
|  | ||||
|     #undef SPR_PARAM | ||||
|     #define SPR_PARAM "SPR" | ||||
|     #define SPR_PARAM "SPRE" | ||||
|  | ||||
|     if (parser.seenval('S')) { const float v = parser.value_linear_units(); toolchange_settings.swap_length = constrain(v, 0, 500); } | ||||
|     static constexpr float max_extrude = | ||||
|       #if ENABLED(PREVENT_LENGTHY_EXTRUDE) | ||||
|         EXTRUDE_MAXLENGTH | ||||
|       #else | ||||
|         500 | ||||
|       #endif | ||||
|     ; | ||||
|  | ||||
|     if (parser.seenval('S')) { const float v = parser.value_linear_units(); toolchange_settings.swap_length = constrain(v, 0, max_extrude); } | ||||
|     if (parser.seenval('E')) { const float v = parser.value_linear_units(); toolchange_settings.extra_prime = constrain(v, 0, max_extrude); } | ||||
|     if (parser.seenval('P')) { const int16_t v = parser.value_linear_units(); toolchange_settings.prime_speed = constrain(v, 10, 5400); } | ||||
|     if (parser.seenval('R')) { const int16_t v = parser.value_linear_units(); toolchange_settings.retract_speed = constrain(v, 10, 5400); } | ||||
|   #endif | ||||
|  | ||||
|   #if ENABLED(TOOLCHANGE_PARK) | ||||
|     #undef XY_PARAM | ||||
|     #define XY_PARAM "XY" | ||||
|     if (parser.seenval('X')) { toolchange_settings.change_point.x = parser.value_linear_units(); } | ||||
|     if (parser.seenval('Y')) { toolchange_settings.change_point.y = parser.value_linear_units(); } | ||||
|   #endif | ||||
|  | ||||
|   if (parser.seenval('Z')) { toolchange_settings.z_raise = parser.value_linear_units(); } | ||||
|  | ||||
|   if (!parser.seen(SPR_PARAM XY_PARAM "Z")) M217_report(); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user