mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-22 16:21:24 -06:00 
			
		
		
		
	Refactor loop building code to make_loops()
This commit is contained in:
		
							parent
							
								
									86f91bb3c4
								
							
						
					
					
						commit
						a831f5b176
					
				
					 2 changed files with 71 additions and 54 deletions
				
			
		|  | @ -411,6 +411,22 @@ TriangleMeshSlicer::slice(const std::vector<float> &z, std::vector<Polygons>* la | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | void | ||||||
|  | TriangleMeshSlicer::slice(const std::vector<float> &z, std::vector<ExPolygons>* layers) | ||||||
|  | { | ||||||
|  |     std::vector<Polygons> layers_p; | ||||||
|  |     this->slice(z, &layers_p); | ||||||
|  |      | ||||||
|  |     layers->resize(z.size()); | ||||||
|  |     for (std::vector<Polygons>::const_iterator loops = layers_p.begin(); loops != layers_p.end(); ++loops) { | ||||||
|  |         #ifdef SLIC3R_DEBUG | ||||||
|  |         printf("Layer %zu (slice_z = %.2f): ", layer_id, z[layer_id]); | ||||||
|  |         #endif | ||||||
|  |          | ||||||
|  |         this->make_expolygons(*loops, &(*layers)[ loops - layers_p.begin() ]); | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | 
 | ||||||
| void | void | ||||||
| TriangleMeshSlicer::slice_facet(float slice_z, const stl_facet &facet, const int &facet_idx, const float &min_z, const float &max_z, std::vector<IntersectionLine>* lines) const | TriangleMeshSlicer::slice_facet(float slice_z, const stl_facet &facet, const int &facet_idx, const float &min_z, const float &max_z, std::vector<IntersectionLine>* lines) const | ||||||
| { | { | ||||||
|  | @ -664,11 +680,8 @@ class _area_comp { | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| void | void | ||||||
| TriangleMeshSlicer::slice(const std::vector<float> &z, std::vector<ExPolygons>* layers) | TriangleMeshSlicer::make_expolygons(const Polygons &loops, ExPolygons* slices) | ||||||
| { | { | ||||||
|     std::vector<Polygons> layers_p; |  | ||||||
|     this->slice(z, &layers_p); |  | ||||||
|      |  | ||||||
|     /*
 |     /*
 | ||||||
|         Input loops are not suitable for evenodd nor nonzero fill types, as we might get |         Input loops are not suitable for evenodd nor nonzero fill types, as we might get | ||||||
|         two consecutive concentric loops having the same winding order - and we have to  |         two consecutive concentric loops having the same winding order - and we have to  | ||||||
|  | @ -686,54 +699,56 @@ TriangleMeshSlicer::slice(const std::vector<float> &z, std::vector<ExPolygons>* | ||||||
|         loops correctly in some edge cases when original model had overlapping facets |         loops correctly in some edge cases when original model had overlapping facets | ||||||
|     */ |     */ | ||||||
| 
 | 
 | ||||||
|     layers->resize(z.size()); |  | ||||||
|      |  | ||||||
|     for (std::vector<Polygons>::const_iterator loops = layers_p.begin(); loops != layers_p.end(); ++loops) { |  | ||||||
|         size_t layer_id = loops - layers_p.begin(); |  | ||||||
|          |  | ||||||
|     std::vector<double> area; |     std::vector<double> area; | ||||||
|     std::vector<double> abs_area; |     std::vector<double> abs_area; | ||||||
|     std::vector<size_t> sorted_area;  // vector of indices
 |     std::vector<size_t> sorted_area;  // vector of indices
 | ||||||
|         for (Polygons::const_iterator loop = loops->begin(); loop != loops->end(); ++loop) { |     for (Polygons::const_iterator loop = loops.begin(); loop != loops.end(); ++loop) { | ||||||
|         double a = loop->area(); |         double a = loop->area(); | ||||||
|         area.push_back(a); |         area.push_back(a); | ||||||
|         abs_area.push_back(std::fabs(a)); |         abs_area.push_back(std::fabs(a)); | ||||||
|             sorted_area.push_back(loop - loops->begin()); |         sorted_area.push_back(loop - loops.begin()); | ||||||
|     } |     } | ||||||
|      |      | ||||||
|     std::sort(sorted_area.begin(), sorted_area.end(), _area_comp(&abs_area));  // outer first
 |     std::sort(sorted_area.begin(), sorted_area.end(), _area_comp(&abs_area));  // outer first
 | ||||||
| 
 | 
 | ||||||
|     // we don't perform a safety offset now because it might reverse cw loops
 |     // we don't perform a safety offset now because it might reverse cw loops
 | ||||||
|         Polygons slices; |     Polygons p_slices; | ||||||
|     for (std::vector<size_t>::const_iterator loop_idx = sorted_area.begin(); loop_idx != sorted_area.end(); ++loop_idx) { |     for (std::vector<size_t>::const_iterator loop_idx = sorted_area.begin(); loop_idx != sorted_area.end(); ++loop_idx) { | ||||||
|         /* we rely on the already computed area to determine the winding order
 |         /* we rely on the already computed area to determine the winding order
 | ||||||
|            of the loops, since the Orientation() function provided by Clipper |            of the loops, since the Orientation() function provided by Clipper | ||||||
|            would do the same, thus repeating the calculation */ |            would do the same, thus repeating the calculation */ | ||||||
|             Polygons::const_iterator loop = loops->begin() + *loop_idx; |         Polygons::const_iterator loop = loops.begin() + *loop_idx; | ||||||
|         if (area[*loop_idx] >= 0) { |         if (area[*loop_idx] >= 0) { | ||||||
|                 slices.push_back(*loop); |             p_slices.push_back(*loop); | ||||||
|         } else { |         } else { | ||||||
|                 diff(slices, *loop, slices); |             diff(p_slices, *loop, p_slices); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     // perform a safety offset to merge very close facets (TODO: find test case for this)
 |     // perform a safety offset to merge very close facets (TODO: find test case for this)
 | ||||||
|     double safety_offset = scale_(0.0499); |     double safety_offset = scale_(0.0499); | ||||||
|     ExPolygons ex_slices; |     ExPolygons ex_slices; | ||||||
|         offset2_ex(slices, ex_slices, +safety_offset, -safety_offset); |     offset2_ex(p_slices, ex_slices, +safety_offset, -safety_offset); | ||||||
|      |      | ||||||
|     #ifdef SLIC3R_DEBUG |     #ifdef SLIC3R_DEBUG | ||||||
|     size_t holes_count = 0; |     size_t holes_count = 0; | ||||||
|     for (ExPolygons::const_iterator e = ex_slices.begin(); e != ex_slices.end(); ++e) { |     for (ExPolygons::const_iterator e = ex_slices.begin(); e != ex_slices.end(); ++e) { | ||||||
|         holes_count += e->holes.size(); |         holes_count += e->holes.size(); | ||||||
|     } |     } | ||||||
|         printf("Layer %zu (slice_z = %.2f): %zu surface(s) having %zu holes detected from %zu polylines\n", |     printf("%zu surface(s) having %zu holes detected from %zu polylines\n", | ||||||
|             layer_id, z[layer_id], ex_slices.size(), holes_count, loops->size()); |         ex_slices.size(), holes_count, loops.size()); | ||||||
|     #endif |     #endif | ||||||
|      |      | ||||||
|         ExPolygons* layer = &(*layers)[layer_id]; |     // append to the supplied collection
 | ||||||
|         layer->insert(layer->end(), ex_slices.begin(), ex_slices.end()); |     slices->insert(slices->end(), ex_slices.begin(), ex_slices.end()); | ||||||
|     } | } | ||||||
|  | 
 | ||||||
|  | void | ||||||
|  | TriangleMeshSlicer::make_expolygons(std::vector<IntersectionLine> &lines, ExPolygons* slices) | ||||||
|  | { | ||||||
|  |     Polygons pp; | ||||||
|  |     this->make_loops(lines, &pp); | ||||||
|  |     this->make_expolygons(pp, slices); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void | void | ||||||
|  | @ -817,8 +832,8 @@ TriangleMeshSlicer::cut(float z, TriangleMesh* upper, TriangleMesh* lower) | ||||||
|     } |     } | ||||||
|      |      | ||||||
|     // compute shape of section
 |     // compute shape of section
 | ||||||
|     Polygons section; |     ExPolygons section; | ||||||
|     this->make_loops(lines, §ion); |     this->make_expolygons(lines, §ion); | ||||||
|      |      | ||||||
|     /*
 |     /*
 | ||||||
|     stl_get_size(&(upper->stl)); |     stl_get_size(&(upper->stl)); | ||||||
|  |  | ||||||
|  | @ -91,6 +91,8 @@ class TriangleMeshSlicer | ||||||
|     t_facets_edges facets_edges; |     t_facets_edges facets_edges; | ||||||
|     stl_vertex* v_scaled_shared; |     stl_vertex* v_scaled_shared; | ||||||
|     void make_loops(std::vector<IntersectionLine> &lines, Polygons* loops); |     void make_loops(std::vector<IntersectionLine> &lines, Polygons* loops); | ||||||
|  |     void make_expolygons(const Polygons &loops, ExPolygons* slices); | ||||||
|  |     void make_expolygons(std::vector<IntersectionLine> &lines, ExPolygons* slices); | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| } | } | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Alessandro Ranellucci
						Alessandro Ranellucci