mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-24 17:21:11 -06:00 
			
		
		
		
	Fix normal direction when exporting STL (#6406)
The export function does not depend on Model/ModelObject::mesh() family of functions, changing them might break the already too brittle code.
This commit is contained in:
		
							parent
							
								
									d1cfdcb49e
								
							
						
					
					
						commit
						978b359492
					
				
					 6 changed files with 42 additions and 26 deletions
				
			
		|  | @ -833,18 +833,6 @@ indexed_triangle_set ModelObject::raw_indexed_triangle_set() const | |||
|     return out; | ||||
| } | ||||
| 
 | ||||
| // Non-transformed (non-rotated, non-scaled, non-translated) sum of all object volumes.
 | ||||
| TriangleMesh ModelObject::full_raw_mesh() const | ||||
| { | ||||
|     TriangleMesh mesh; | ||||
|     for (const ModelVolume *v : this->volumes) | ||||
|     { | ||||
|         TriangleMesh vol_mesh(v->mesh()); | ||||
|         vol_mesh.transform(v->get_matrix()); | ||||
|         mesh.merge(vol_mesh); | ||||
|     } | ||||
|     return mesh; | ||||
| } | ||||
| 
 | ||||
| const BoundingBoxf3& ModelObject::raw_mesh_bounding_box() const | ||||
| { | ||||
|  |  | |||
|  | @ -289,8 +289,6 @@ public: | |||
|     TriangleMesh raw_mesh() const; | ||||
|     // The same as above, but producing a lightweight indexed_triangle_set.
 | ||||
|     indexed_triangle_set raw_indexed_triangle_set() const; | ||||
|     // Non-transformed (non-rotated, non-scaled, non-translated) sum of all object volumes.
 | ||||
|     TriangleMesh full_raw_mesh() const; | ||||
|     // A transformed snug bounding box around the non-modifier object volumes, without the translation applied.
 | ||||
|     // This bounding box is only used for the actual slicing.
 | ||||
|     const BoundingBoxf3& raw_bounding_box() const; | ||||
|  |  | |||
|  | @ -2207,6 +2207,7 @@ std::vector<ExPolygons> PrintObject::slice_volumes( | |||
|             TriangleMesh vol_mesh(model_volume.mesh()); | ||||
|             vol_mesh.transform(model_volume.get_matrix(), true); | ||||
|             mesh.merge(vol_mesh); | ||||
|             mesh.repair(false); | ||||
|         } | ||||
|         if (mesh.stl.stats.number_of_facets > 0) { | ||||
|             mesh.transform(m_trafo, true); | ||||
|  |  | |||
|  | @ -357,10 +357,14 @@ void TriangleMesh::transform(const Transform3d& t, bool fix_left_handed) | |||
|     its_transform(its, t); | ||||
| 	if (fix_left_handed && t.matrix().block(0, 0, 3, 3).determinant() < 0.) { | ||||
| 		// Left handed transformation is being applied. It is a good idea to flip the faces and their normals.
 | ||||
| 		this->repair(false); | ||||
| 		stl_reverse_all_facets(&stl); | ||||
| 		this->its.clear(); | ||||
| 		this->require_shared_vertices(); | ||||
|         // As for the assert: the repair function would fix the normals, reversing would
 | ||||
|         // break them again. The caller should provide a mesh that does not need repair.
 | ||||
|         // The repair call is left here so things don't break more than they were.
 | ||||
|         assert(this->repaired); | ||||
|         this->repair(false); | ||||
|         stl_reverse_all_facets(&stl); | ||||
|         this->its.clear(); | ||||
|         this->require_shared_vertices(); | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
|  | @ -369,11 +373,12 @@ void TriangleMesh::transform(const Matrix3d& m, bool fix_left_handed) | |||
|     stl_transform(&stl, m); | ||||
|     its_transform(its, m); | ||||
|     if (fix_left_handed && m.determinant() < 0.) { | ||||
|         // Left handed transformation is being applied. It is a good idea to flip the faces and their normals.
 | ||||
|         // See comments in function above.
 | ||||
|         assert(this->repaired); | ||||
|         this->repair(false); | ||||
|         stl_reverse_all_facets(&stl); | ||||
| 		this->its.clear(); | ||||
| 		this->require_shared_vertices(); | ||||
|         this->its.clear(); | ||||
|         this->require_shared_vertices(); | ||||
|     } | ||||
| } | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Lukas Matena
						Lukas Matena