mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-25 17:51:10 -06:00 
			
		
		
		
	Fixing model import of models with nearly degenerate triangles, which degenerate after transformation (translation or rotation). There was certainly a bug in PrusaSlicer, however this bug was triggered mostly by the ASCII STL files generated by OpenSCAD, likely due to insufficient number of decimal digits when saving an ASCII STL, see [openscad/openscad] STL export should contain single precision floats (#2651)
This commit is contained in:
		
							parent
							
								
									ba9025491b
								
							
						
					
					
						commit
						9c5dd358ab
					
				
					 1 changed files with 14 additions and 8 deletions
				
			
		|  | @ -2143,6 +2143,16 @@ std::vector<ExPolygons> PrintObject::slice_support_volumes(const ModelVolumeType | ||||||
|     return this->slice_volumes(zs, SlicingMode::Regular, volumes); |     return this->slice_volumes(zs, SlicingMode::Regular, volumes); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | //FIXME The admesh repair function may break the face connectivity, rather refresh it here as the slicing code relies on it.
 | ||||||
|  | static void fix_mesh_connectivity(TriangleMesh &mesh) | ||||||
|  | { | ||||||
|  |     auto nr_degenerated = mesh.stl.stats.degenerate_facets; | ||||||
|  |     stl_check_facets_exact(&mesh.stl); | ||||||
|  |     if (nr_degenerated != mesh.stl.stats.degenerate_facets) | ||||||
|  |         // stl_check_facets_exact() removed some newly degenerated faces. Some faces could become degenerate after some mesh transformation.
 | ||||||
|  |         stl_generate_shared_vertices(&mesh.stl, mesh.its); | ||||||
|  | } | ||||||
|  | 
 | ||||||
| std::vector<ExPolygons> PrintObject::slice_volumes( | std::vector<ExPolygons> PrintObject::slice_volumes( | ||||||
|     const std::vector<float> &z,  |     const std::vector<float> &z,  | ||||||
|     SlicingMode mode, size_t slicing_mode_normal_below_layer, SlicingMode mode_below,  |     SlicingMode mode, size_t slicing_mode_normal_below_layer, SlicingMode mode_below,  | ||||||
|  | @ -2155,10 +2165,8 @@ std::vector<ExPolygons> PrintObject::slice_volumes( | ||||||
| 		TriangleMesh mesh(volumes.front()->mesh()); | 		TriangleMesh mesh(volumes.front()->mesh()); | ||||||
|         mesh.transform(volumes.front()->get_matrix(), true); |         mesh.transform(volumes.front()->get_matrix(), true); | ||||||
| 		assert(mesh.repaired); | 		assert(mesh.repaired); | ||||||
| 		if (volumes.size() == 1 && mesh.repaired) { | 		if (volumes.size() == 1 && mesh.repaired) | ||||||
| 			//FIXME The admesh repair function may break the face connectivity, rather refresh it here as the slicing code relies on it.
 |             fix_mesh_connectivity(mesh); | ||||||
| 			stl_check_facets_exact(&mesh.stl); |  | ||||||
| 		} |  | ||||||
|         for (size_t idx_volume = 1; idx_volume < volumes.size(); ++ idx_volume) { |         for (size_t idx_volume = 1; idx_volume < volumes.size(); ++ idx_volume) { | ||||||
|             const ModelVolume &model_volume = *volumes[idx_volume]; |             const ModelVolume &model_volume = *volumes[idx_volume]; | ||||||
|             TriangleMesh vol_mesh(model_volume.mesh()); |             TriangleMesh vol_mesh(model_volume.mesh()); | ||||||
|  | @ -2191,10 +2199,8 @@ std::vector<ExPolygons> PrintObject::slice_volume(const std::vector<float> &z, S | ||||||
| 	    //FIXME better to split the mesh into separate shells, perform slicing over each shell separately and then to use a Boolean operation to merge them.
 | 	    //FIXME better to split the mesh into separate shells, perform slicing over each shell separately and then to use a Boolean operation to merge them.
 | ||||||
| 	    TriangleMesh mesh(volume.mesh()); | 	    TriangleMesh mesh(volume.mesh()); | ||||||
| 	    mesh.transform(volume.get_matrix(), true); | 	    mesh.transform(volume.get_matrix(), true); | ||||||
| 		if (mesh.repaired) { | 		if (mesh.repaired) | ||||||
| 			//FIXME The admesh repair function may break the face connectivity, rather refresh it here as the slicing code relies on it.
 |             fix_mesh_connectivity(mesh); | ||||||
| 			stl_check_facets_exact(&mesh.stl); |  | ||||||
| 		} |  | ||||||
| 	    if (mesh.stl.stats.number_of_facets > 0) { | 	    if (mesh.stl.stats.number_of_facets > 0) { | ||||||
| 	        mesh.transform(m_trafo, true); | 	        mesh.transform(m_trafo, true); | ||||||
| 	        // apply XY shift
 | 	        // apply XY shift
 | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Vojtech Bubnik
						Vojtech Bubnik