mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-24 17:21:11 -06:00 
			
		
		
		
	Bugfix: external details were simplified too much when using default settings at low layer height, because the internal flow was erroneously taken into account. #2807
This commit is contained in:
		
							parent
							
								
									bab3404b2d
								
							
						
					
					
						commit
						795107dfa2
					
				
					 2 changed files with 14 additions and 5 deletions
				
			
		|  | @ -37,6 +37,9 @@ class Flow | ||||||
|     coord_t scaled_spacing() const { |     coord_t scaled_spacing() const { | ||||||
|         return scale_(this->spacing()); |         return scale_(this->spacing()); | ||||||
|     }; |     }; | ||||||
|  |     coord_t scaled_spacing(const Flow &other) const { | ||||||
|  |         return scale_(this->spacing(other)); | ||||||
|  |     }; | ||||||
|      |      | ||||||
|     static Flow new_from_config_width(FlowRole role, const ConfigOptionFloatOrPercent &width, float nozzle_diameter, float height, float bridge_flow_ratio); |     static Flow new_from_config_width(FlowRole role, const ConfigOptionFloatOrPercent &width, float nozzle_diameter, float height, float bridge_flow_ratio); | ||||||
|     static Flow new_from_spacing(float spacing, float nozzle_diameter, float height, bool bridge); |     static Flow new_from_spacing(float spacing, float nozzle_diameter, float height, bool bridge); | ||||||
|  |  | ||||||
|  | @ -14,8 +14,9 @@ PerimeterGenerator::process() | ||||||
|      |      | ||||||
|     // external perimeters
 |     // external perimeters
 | ||||||
|     this->_ext_mm3_per_mm       = this->ext_perimeter_flow.mm3_per_mm(); |     this->_ext_mm3_per_mm       = this->ext_perimeter_flow.mm3_per_mm(); | ||||||
|     coord_t ext_pwidth        = this->ext_perimeter_flow.scaled_width(); |     coord_t ext_pwidth          = this->ext_perimeter_flow.scaled_width(); | ||||||
|     coord_t ext_pspacing      = scale_(this->ext_perimeter_flow.spacing(this->perimeter_flow)); |     coord_t ext_pspacing        = this->ext_perimeter_flow.scaled_spacing(); | ||||||
|  |     coord_t ext_pspacing2       = this->ext_perimeter_flow.scaled_spacing(this->perimeter_flow); | ||||||
|      |      | ||||||
|     // overhang perimeters
 |     // overhang perimeters
 | ||||||
|     this->_mm3_per_mm_overhang  = this->overhang_flow.mm3_per_mm(); |     this->_mm3_per_mm_overhang  = this->overhang_flow.mm3_per_mm(); | ||||||
|  | @ -29,6 +30,11 @@ PerimeterGenerator::process() | ||||||
|     // with some tolerance in order to avoid triggering medial axis when
 |     // with some tolerance in order to avoid triggering medial axis when
 | ||||||
|     // some squishing might work. Loops are still spaced by the entire
 |     // some squishing might work. Loops are still spaced by the entire
 | ||||||
|     // flow spacing; this only applies to collapsing parts.
 |     // flow spacing; this only applies to collapsing parts.
 | ||||||
|  |     // For ext_min_spacing we use the ext_pspacing calculated for two adjacent
 | ||||||
|  |     // external loops (which is the correct way) instead of using ext_pspacing2
 | ||||||
|  |     // which is the spacing between external and internal, which is not correct
 | ||||||
|  |     // and would make the collapsing (thus the details resolution) dependent on 
 | ||||||
|  |     // internal flow which is unrelated.
 | ||||||
|     coord_t min_spacing         = pspacing      * (1 - INSET_OVERLAP_TOLERANCE); |     coord_t min_spacing         = pspacing      * (1 - INSET_OVERLAP_TOLERANCE); | ||||||
|     coord_t ext_min_spacing     = ext_pspacing  * (1 - INSET_OVERLAP_TOLERANCE); |     coord_t ext_min_spacing     = ext_pspacing  * (1 - INSET_OVERLAP_TOLERANCE); | ||||||
|      |      | ||||||
|  | @ -91,7 +97,7 @@ PerimeterGenerator::process() | ||||||
|                         // the maximum thickness of our thin wall area is equal to the minimum thickness of a single loop
 |                         // the maximum thickness of our thin wall area is equal to the minimum thickness of a single loop
 | ||||||
|                         Polylines pp; |                         Polylines pp; | ||||||
|                         for (ExPolygons::const_iterator ex = expp.begin(); ex != expp.end(); ++ex) |                         for (ExPolygons::const_iterator ex = expp.begin(); ex != expp.end(); ++ex) | ||||||
|                             ex->medial_axis(ext_pwidth + ext_pspacing, min_width, &pp); |                             ex->medial_axis(ext_pwidth + ext_pspacing2, min_width, &pp); | ||||||
|                          |                          | ||||||
|                         double threshold = ext_pwidth * 2; |                         double threshold = ext_pwidth * 2; | ||||||
|                         for (Polylines::const_iterator p = pp.begin(); p != pp.end(); ++p) { |                         for (Polylines::const_iterator p = pp.begin(); p != pp.end(); ++p) { | ||||||
|  | @ -117,7 +123,7 @@ PerimeterGenerator::process() | ||||||
|                         */ |                         */ | ||||||
|                     } |                     } | ||||||
|                 } else { |                 } else { | ||||||
|                     coord_t distance = (i == 1) ? ext_pspacing : pspacing; |                     coord_t distance = (i == 1) ? ext_pspacing2 : pspacing; | ||||||
|                      |                      | ||||||
|                     if (this->config->thin_walls) { |                     if (this->config->thin_walls) { | ||||||
|                         offsets = offset2( |                         offsets = offset2( | ||||||
|  | @ -291,7 +297,7 @@ PerimeterGenerator::process() | ||||||
|         coord_t inset = 0; |         coord_t inset = 0; | ||||||
|         if (loop_number == 0) { |         if (loop_number == 0) { | ||||||
|             // one loop
 |             // one loop
 | ||||||
|             inset += ext_pspacing/2; |             inset += ext_pspacing2/2; | ||||||
|         } else if (loop_number > 0) { |         } else if (loop_number > 0) { | ||||||
|             // two or more loops
 |             // two or more loops
 | ||||||
|             inset += pspacing/2; |             inset += pspacing/2; | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Alessandro Ranellucci
						Alessandro Ranellucci