mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-25 09:41:11 -06:00 
			
		
		
		
	Fix of 8f293f0cb5
				
					
				
			When was set use_external_mp_once to true then after first calling the avoid crossing perimeters this flag was reset which cases that on the second call of the avoid crossing perimeters the travel move didn't process as external.
This commit is contained in:
		
							parent
							
								
									0593a41350
								
							
						
					
					
						commit
						a53de51b22
					
				
					 2 changed files with 12 additions and 4 deletions
				
			
		|  | @ -2841,6 +2841,8 @@ std::string GCode::travel_to(const Point &point, ExtrusionRole role, std::string | ||||||
|     bool needs_retraction             = this->needs_retraction(travel, role); |     bool needs_retraction             = this->needs_retraction(travel, role); | ||||||
|     // check whether wipe could be disabled without causing visible stringing
 |     // check whether wipe could be disabled without causing visible stringing
 | ||||||
|     bool could_be_wipe_disabled       = false; |     bool could_be_wipe_disabled       = false; | ||||||
|  |     // Save state of use_external_mp_once for the case that will be needed to call twice m_avoid_crossing_perimeters.travel_to.
 | ||||||
|  |     const bool used_external_mp_once  = m_avoid_crossing_perimeters.used_external_mp_once(); | ||||||
| 
 | 
 | ||||||
|     // if a retraction would be needed, try to use avoid_crossing_perimeters to plan a
 |     // if a retraction would be needed, try to use avoid_crossing_perimeters to plan a
 | ||||||
|     // multi-hop travel path inside the configuration space
 |     // multi-hop travel path inside the configuration space
 | ||||||
|  | @ -2868,8 +2870,13 @@ std::string GCode::travel_to(const Point &point, ExtrusionRole role, std::string | ||||||
|         // Because of it, it is necessary to call avoid crossing perimeters again with new starting point 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.
 |         // 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, point); |             // If in the previous call of m_avoid_crossing_perimeters.travel_to was use_external_mp_once set to true restore this value for next call.
 | ||||||
|             travel = std::move(retract_travel); |             if (used_external_mp_once) | ||||||
|  |                 m_avoid_crossing_perimeters.use_external_mp_once(); | ||||||
|  |             travel = m_avoid_crossing_perimeters.travel_to(*this, point); | ||||||
|  |             // If state of use_external_mp_once was changed reset it to right value.
 | ||||||
|  |             if (used_external_mp_once) | ||||||
|  |                 m_avoid_crossing_perimeters.reset_once_modifiers(); | ||||||
|         } |         } | ||||||
|     } else |     } else | ||||||
|         // Reset the wipe path when traveling, so one would not wipe along an old path.
 |         // Reset the wipe path when traveling, so one would not wipe along an old path.
 | ||||||
|  |  | ||||||
|  | @ -18,6 +18,7 @@ public: | ||||||
|     // Routing around the objects vs. inside a single object.
 |     // Routing around the objects vs. inside a single object.
 | ||||||
|     void        use_external_mp(bool use = true) { m_use_external_mp = use; }; |     void        use_external_mp(bool use = true) { m_use_external_mp = use; }; | ||||||
|     void        use_external_mp_once()  { m_use_external_mp_once = true; } |     void        use_external_mp_once()  { m_use_external_mp_once = true; } | ||||||
|  |     bool        used_external_mp_once() { return m_use_external_mp_once; } | ||||||
|     void        disable_once()          { m_disabled_once = true; } |     void        disable_once()          { m_disabled_once = true; } | ||||||
|     bool        disabled_once() const   { return m_disabled_once; } |     bool        disabled_once() const   { return m_disabled_once; } | ||||||
|     void        reset_once_modifiers()  { m_use_external_mp_once = false; m_disabled_once = false; } |     void        reset_once_modifiers()  { m_use_external_mp_once = false; m_disabled_once = false; } | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Lukáš Hejl
						Lukáš Hejl