Improve FWRETRACT logic, add common sense
This commit is contained in:
		
				
					committed by
					
						 Scott Lahteine
						Scott Lahteine
					
				
			
			
				
	
			
			
			
						parent
						
							3f827758d7
						
					
				
				
					commit
					eb02f8c719
				
			| @@ -94,13 +94,16 @@ void FWRetract::retract(const bool retracting | |||||||
|   #endif |   #endif | ||||||
| ) { | ) { | ||||||
|  |  | ||||||
|   static float hop_height,        // Remember where the Z height started |   static float hop_amount = 0.0;  // Total amount lifted, for use in recover | ||||||
|                hop_amount = 0.0;  // Total amount lifted, for use in recover |  | ||||||
|  |  | ||||||
|   // Simply never allow two retracts or recovers in a row |   // Prevent two retracts or recovers in a row | ||||||
|   if (retracted[active_extruder] == retracting) return; |   if (retracted[active_extruder] == retracting) return; | ||||||
|  |  | ||||||
|  |   // Prevent two swap-retract or recovers in a row | ||||||
|   #if EXTRUDERS > 1 |   #if EXTRUDERS > 1 | ||||||
|  |     // Allow G10 S1 only after G10 | ||||||
|  |     if (swapping && retracted_swap[active_extruder] == retracting) return; | ||||||
|  |     // G11 priority to recover the long retract if activated | ||||||
|     if (!retracting) swapping = retracted_swap[active_extruder]; |     if (!retracting) swapping = retracted_swap[active_extruder]; | ||||||
|   #else |   #else | ||||||
|     const bool swapping = false; |     const bool swapping = false; | ||||||
| @@ -121,64 +124,56 @@ void FWRetract::retract(const bool retracting | |||||||
|   //*/ |   //*/ | ||||||
|  |  | ||||||
|   const bool has_zhop = retract_zlift > 0.01;     // Is there a hop set? |   const bool has_zhop = retract_zlift > 0.01;     // Is there a hop set? | ||||||
|  |  | ||||||
|   const float old_feedrate_mm_s = feedrate_mm_s; |   const float old_feedrate_mm_s = feedrate_mm_s; | ||||||
|   const int16_t old_flow = planner.flow_percentage[active_extruder]; |  | ||||||
|  |  | ||||||
|   // Don't apply flow multiplication to retract/recover |  | ||||||
|   planner.flow_percentage[active_extruder] = 100; |  | ||||||
|  |  | ||||||
|   // The current position will be the destination for E and Z moves |   // The current position will be the destination for E and Z moves | ||||||
|   set_destination_from_current(); |   set_destination_from_current(); | ||||||
|  |  | ||||||
|   stepper.synchronize();  // Wait for buffered moves to complete |   stepper.synchronize();  // Wait for buffered moves to complete | ||||||
|  |  | ||||||
|   if (retracting) { |   const float renormalize = 100.0 / planner.flow_percentage[active_extruder] / planner.volumetric_multiplier[active_extruder]; | ||||||
|     // Remember the Z height since G-code may include its own Z-hop |  | ||||||
|     // For best results turn off Z hop if G-code already includes it |  | ||||||
|     hop_height = destination[Z_AXIS]; |  | ||||||
|  |  | ||||||
|  |   if (retracting) { | ||||||
|     // Retract by moving from a faux E position back to the current E position |     // Retract by moving from a faux E position back to the current E position | ||||||
|     feedrate_mm_s = retract_feedrate_mm_s; |     feedrate_mm_s = retract_feedrate_mm_s; | ||||||
|     current_position[E_AXIS] += (swapping ? swap_retract_length : retract_length) / planner.volumetric_multiplier[active_extruder]; |     current_position[E_AXIS] += (swapping ? swap_retract_length : retract_length) * renormalize; | ||||||
|     sync_plan_position_e(); |     sync_plan_position_e(); | ||||||
|     prepare_move_to_destination(); |     prepare_move_to_destination(); | ||||||
|  |  | ||||||
|     // Is a Z hop set, and has the hop not yet been done? |     // Is a Z hop set, and has the hop not yet been done? | ||||||
|     if (has_zhop) { |     // No double zlifting | ||||||
|       hop_amount += retract_zlift;                // Carriage is raised for retraction hop |     // Feedrate to the max | ||||||
|       current_position[Z_AXIS] -= retract_zlift;  // Pretend current pos is lower. Next move raises Z. |     if (has_zhop && !hop_amount) { | ||||||
|       SYNC_PLAN_POSITION_KINEMATIC();             // Set the planner to the new position |       hop_amount += retract_zlift;                        // Carriage is raised for retraction hop | ||||||
|       prepare_move_to_destination();              // Raise up to the old current pos |       feedrate_mm_s = planner.max_feedrate_mm_s[Z_AXIS];  // Z feedrate to max | ||||||
|  |       current_position[Z_AXIS] -= retract_zlift;          // Pretend current pos is lower. Next move raises Z. | ||||||
|  |       SYNC_PLAN_POSITION_KINEMATIC();                     // Set the planner to the new position | ||||||
|  |       prepare_move_to_destination();                      // Raise up to the old current pos | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
|   else { |   else { | ||||||
|     // If a hop was done and Z hasn't changed, undo the Z hop |     // If a hop was done and Z hasn't changed, undo the Z hop | ||||||
|     if (hop_amount && NEAR(hop_height, destination[Z_AXIS])) { |     if (hop_amount) { | ||||||
|       current_position[Z_AXIS] += hop_amount;     // Pretend current pos is higher. Next move lowers Z. |       current_position[Z_AXIS] -= retract_zlift;          // Pretend current pos is lower. Next move raises Z. | ||||||
|       SYNC_PLAN_POSITION_KINEMATIC();             // Set the planner to the new position |       SYNC_PLAN_POSITION_KINEMATIC();                     // Set the planner to the new position | ||||||
|       prepare_move_to_destination();              // Lower to the old current pos |       feedrate_mm_s = planner.max_feedrate_mm_s[Z_AXIS];  // Z feedrate to max | ||||||
|       hop_amount = 0.0; |       prepare_move_to_destination();                      // Raise up to the old current pos | ||||||
|  |       hop_amount = 0.0;                                   // Clear hop | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     // A retract multiplier has been added here to get faster swap recovery |     // A retract multiplier has been added here to get faster swap recovery | ||||||
|     feedrate_mm_s = swapping ? swap_retract_recover_feedrate_mm_s : retract_recover_feedrate_mm_s; |     feedrate_mm_s = swapping ? swap_retract_recover_feedrate_mm_s : retract_recover_feedrate_mm_s; | ||||||
|  |  | ||||||
|     const float move_e = swapping ? swap_retract_length + swap_retract_recover_length : retract_length + retract_recover_length; |     const float move_e = swapping ? swap_retract_length + swap_retract_recover_length : retract_length + retract_recover_length; | ||||||
|     current_position[E_AXIS] -= move_e / planner.volumetric_multiplier[active_extruder]; |     current_position[E_AXIS] -= move_e * renormalize; | ||||||
|     sync_plan_position_e(); |     sync_plan_position_e(); | ||||||
|  |  | ||||||
|     prepare_move_to_destination();  // Recover E |     prepare_move_to_destination();  // Recover E | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   // Restore flow and feedrate |   feedrate_mm_s = old_feedrate_mm_s;                      // Restore original feedrate | ||||||
|   planner.flow_percentage[active_extruder] = old_flow; |  | ||||||
|   feedrate_mm_s = old_feedrate_mm_s; |  | ||||||
|  |  | ||||||
|   // The active extruder is now retracted or recovered |   retracted[active_extruder] = retracting;                // Active extruder now retracted / recovered | ||||||
|   retracted[active_extruder] = retracting; |  | ||||||
|  |  | ||||||
|   // If swap retract/recover then update the retracted_swap flag too |   // If swap retract/recover update the retracted_swap flag too | ||||||
|   #if EXTRUDERS > 1 |   #if EXTRUDERS > 1 | ||||||
|     if (swapping) retracted_swap[active_extruder] = retracting; |     if (swapping) retracted_swap[active_extruder] = retracting; | ||||||
|   #endif |   #endif | ||||||
| @@ -197,6 +192,6 @@ void FWRetract::retract(const bool retracting | |||||||
|     SERIAL_ECHOLNPAIR("hop_amount ", hop_amount); |     SERIAL_ECHOLNPAIR("hop_amount ", hop_amount); | ||||||
|   //*/ |   //*/ | ||||||
|  |  | ||||||
| } // retract() | } | ||||||
|  |  | ||||||
| #endif // FWRETRACT | #endif // FWRETRACT | ||||||
|   | |||||||
| @@ -615,7 +615,10 @@ | |||||||
|   #define MSG_CONTROL_RETRACT_RECOVER_SWAP    _UxGT("S UnRet mm") |   #define MSG_CONTROL_RETRACT_RECOVER_SWAP    _UxGT("S UnRet mm") | ||||||
| #endif | #endif | ||||||
| #ifndef MSG_CONTROL_RETRACT_RECOVERF | #ifndef MSG_CONTROL_RETRACT_RECOVERF | ||||||
|   #define MSG_CONTROL_RETRACT_RECOVERF        _UxGT("UnRet  V") |   #define MSG_CONTROL_RETRACT_RECOVERF        _UxGT("UnRet V") | ||||||
|  | #endif | ||||||
|  | #ifndef MSG_CONTROL_RETRACT_RECOVER_SWAPF | ||||||
|  |   #define MSG_CONTROL_RETRACT_RECOVER_SWAPF   _UxGT("S UnRet V") | ||||||
| #endif | #endif | ||||||
| #ifndef MSG_AUTORETRACT | #ifndef MSG_AUTORETRACT | ||||||
|   #define MSG_AUTORETRACT                     _UxGT("AutoRetr.") |   #define MSG_AUTORETRACT                     _UxGT("AutoRetr.") | ||||||
|   | |||||||
| @@ -222,6 +222,7 @@ | |||||||
| #define MSG_CONTROL_RETRACT_RECOVER         _UxGT("UnRet mm") | #define MSG_CONTROL_RETRACT_RECOVER         _UxGT("UnRet mm") | ||||||
| #define MSG_CONTROL_RETRACT_RECOVER_SWAP    _UxGT("Ech. UnRet mm") | #define MSG_CONTROL_RETRACT_RECOVER_SWAP    _UxGT("Ech. UnRet mm") | ||||||
| #define MSG_CONTROL_RETRACT_RECOVERF        _UxGT("UnRet V") | #define MSG_CONTROL_RETRACT_RECOVERF        _UxGT("UnRet V") | ||||||
|  | #define MSG_CONTROL_RETRACT_RECOVER_SWAPF   _UxGT("Ech. Retr. V") | ||||||
| #define MSG_AUTORETRACT                     _UxGT("Retract. Auto.") | #define MSG_AUTORETRACT                     _UxGT("Retract. Auto.") | ||||||
| #define MSG_FILAMENTCHANGE                  _UxGT("Changer filament") | #define MSG_FILAMENTCHANGE                  _UxGT("Changer filament") | ||||||
| #define MSG_INIT_SDCARD                     _UxGT("Init. la carte SD") | #define MSG_INIT_SDCARD                     _UxGT("Init. la carte SD") | ||||||
|   | |||||||
| @@ -3716,6 +3716,9 @@ void kill_screen(const char* lcd_msg) { | |||||||
|         MENU_ITEM_EDIT(float52, MSG_CONTROL_RETRACT_RECOVER_SWAP, &fwretract.swap_retract_recover_length, -100, 100); |         MENU_ITEM_EDIT(float52, MSG_CONTROL_RETRACT_RECOVER_SWAP, &fwretract.swap_retract_recover_length, -100, 100); | ||||||
|       #endif |       #endif | ||||||
|       MENU_ITEM_EDIT(float3, MSG_CONTROL_RETRACT_RECOVERF, &fwretract.retract_recover_feedrate_mm_s, 1, 999); |       MENU_ITEM_EDIT(float3, MSG_CONTROL_RETRACT_RECOVERF, &fwretract.retract_recover_feedrate_mm_s, 1, 999); | ||||||
|  |       #if EXTRUDERS > 1 | ||||||
|  |         MENU_ITEM_EDIT(float3, MSG_CONTROL_RETRACT_RECOVER_SWAPF, &fwretract.swap_retract_recover_feedrate_mm_s, 1, 999); | ||||||
|  |       #endif | ||||||
|       END_MENU(); |       END_MENU(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user