mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-25 17:51:10 -06:00 
			
		
		
		
	Fixed unnecessary travels after calling the avoid crossing perimeters when the wipe is enabled.
When the avoid crossing perimeters was enabled, and the wipe was enabled, there were unnecessary travels in the opposite direction than the wipe travel.
This commit is contained in:
		
							parent
							
								
									86d7e1fb90
								
							
						
					
					
						commit
						8f293f0cb5
					
				
					 1 changed files with 3 additions and 3 deletions
				
			
		|  | @ -2853,10 +2853,10 @@ std::string GCode::travel_to(const Point &point, ExtrusionRole role, std::string | ||||||
|         Point last_post_before_retract = this->last_pos(); |         Point last_post_before_retract = this->last_pos(); | ||||||
|         gcode += this->retract(); |         gcode += this->retract(); | ||||||
|         // When "Wipe while retracting" is enabled, then extruder moves to another position, and travel from this position can cross perimeters.
 |         // When "Wipe while retracting" is enabled, then extruder moves to another position, and travel from this position can cross perimeters.
 | ||||||
|         // Because of it, it is necessary to call avoid crossing perimeters for the path between previous last_post and last_post after calling retraction()
 |         // Because of it, it is necessary to call avoid crossing perimeters again with new starting point after calling retraction()
 | ||||||
|  |         // FIXME Lukas H.: Try to predict if this second calling of avoid crossing perimeters will be needed or not. It could save computations.
 | ||||||
|         if (last_post_before_retract != this->last_pos() && m_config.avoid_crossing_perimeters) { |         if (last_post_before_retract != this->last_pos() && m_config.avoid_crossing_perimeters) { | ||||||
|             Polyline retract_travel = m_avoid_crossing_perimeters.travel_to(*this, last_post_before_retract); |             Polyline retract_travel = m_avoid_crossing_perimeters.travel_to(*this, point); | ||||||
|             append(retract_travel.points, travel.points); |  | ||||||
|             travel = std::move(retract_travel); |             travel = std::move(retract_travel); | ||||||
|         } |         } | ||||||
|     } else |     } else | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Lukáš Hejl
						Lukáš Hejl