mirror of
				https://git.mirrors.martin98.com/https://github.com/prusa3d/PrusaSlicer.git
				synced 2025-10-22 06:31:05 +08:00 
			
		
		
		
	 8a2a9dba2f
			
		
	
	
		8a2a9dba2f
		
	
	
	
	
		
			
			TriangleMesh newly only holds indexed_triangle_set and
TriangleMeshStats. TriangleMeshStats contains an excerpt of stl_stats.
TriangleMeshStats are updated when initializing with indexed_triangle_set.
Admesh triangle mesh fixing is newly only used when loading an STL.
AMF / 3MF / OBJ file formats are already indexed triangle sets, thus
they are no more converted to admesh stl_file format, nor fixed
through admesh repair machinery. When importing AMF / 3MF / OBJ files,
volume is calculated and if negative, all faces are flipped. Also
a bounding box and number of open edges is calculated.
Implemented its_number_of_patches(), its_num_open_edges()
Optimized its_split(), its_is_splittable() using a visitor pattern.
Reworked QHull integration into TriangleMesh:
    1) Face normals were not right.
    2) Indexed triangle set is newly emitted instead of duplicating
       vertices for each face.
Fixed cut_mesh(): Orient the triangulated faces correctly.
		
	
			
		
			
				
	
	
		
			44 lines
		
	
	
		
			999 B
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			44 lines
		
	
	
		
			999 B
		
	
	
	
		
			C++
		
	
	
	
	
	
| #include <iostream>
 | |
| #include <vector>
 | |
| 
 | |
| #include <libslic3r/TriangleMesh.hpp>
 | |
| #include <libslic3r/Model.hpp>
 | |
| #include <libslic3r/SLAPrint.hpp>
 | |
| #include <libslic3r/SLAPrintSteps.hpp>
 | |
| #include <libslic3r/MeshBoolean.hpp>
 | |
| 
 | |
| #include <libnest2d/tools/benchmark.h>
 | |
| 
 | |
| #include <boost/log/trivial.hpp>
 | |
| 
 | |
| int main(const int argc, const char * argv[])
 | |
| {
 | |
|     using namespace Slic3r;
 | |
|     
 | |
|     if (argc <= 1) {
 | |
|         std::cout << "Usage: meshboolean <input_file.3mf>" << std::endl;
 | |
|         return EXIT_FAILURE;
 | |
|     }
 | |
|     
 | |
|     
 | |
|     TriangleMesh input;
 | |
|     
 | |
|     input.ReadSTLFile(argv[1]);
 | |
|     
 | |
|     Benchmark bench;
 | |
|     
 | |
|     bench.start();
 | |
|     bool fckd = MeshBoolean::cgal::does_self_intersect(input);
 | |
|     bench.stop();
 | |
|     
 | |
|     std::cout << "Self intersect test: " << fckd << " duration: " << bench.getElapsedSec() << std::endl;
 | |
|     
 | |
|     bench.start();
 | |
|     MeshBoolean::self_union(input);
 | |
|     bench.stop();
 | |
|     
 | |
|     std::cout << "Self union duration: " << bench.getElapsedSec() << std::endl;
 | |
|     
 | |
|     return 0;
 | |
| }
 |