mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-24 17:21:11 -06:00 
			
		
		
		
	
		
			
				
	
	
		
			87 lines
		
	
	
	
		
			2.6 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			87 lines
		
	
	
	
		
			2.6 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| #ifndef SLABOILERPLATE_HPP
 | |
| #define SLABOILERPLATE_HPP
 | |
| 
 | |
| #include <iostream>
 | |
| #include <functional>
 | |
| #include <numeric>
 | |
| 
 | |
| #include "ExPolygon.hpp"
 | |
| #include "TriangleMesh.hpp"
 | |
| 
 | |
| namespace Slic3r {
 | |
| namespace sla {
 | |
| 
 | |
| using coord_t = Point::coord_type;
 | |
| 
 | |
| /// get the scaled clipper units for a millimeter value
 | |
| inline coord_t mm(double v) { return coord_t(v/SCALING_FACTOR); }
 | |
| 
 | |
| /// Get x and y coordinates (because we are eigenizing...)
 | |
| inline coord_t x(const Point& p) { return p(0); }
 | |
| inline coord_t y(const Point& p) { return p(1); }
 | |
| inline coord_t& x(Point& p) { return p(0); }
 | |
| inline coord_t& y(Point& p) { return p(1); }
 | |
| 
 | |
| inline coordf_t x(const Vec3d& p) { return p(0); }
 | |
| inline coordf_t y(const Vec3d& p) { return p(1); }
 | |
| inline coordf_t z(const Vec3d& p) { return p(2); }
 | |
| inline coordf_t& x(Vec3d& p) { return p(0); }
 | |
| inline coordf_t& y(Vec3d& p) { return p(1); }
 | |
| inline coordf_t& z(Vec3d& p) { return p(2); }
 | |
| 
 | |
| inline coord_t& x(Vec3crd& p) { return p(0); }
 | |
| inline coord_t& y(Vec3crd& p) { return p(1); }
 | |
| inline coord_t& z(Vec3crd& p) { return p(2); }
 | |
| inline coord_t x(const Vec3crd& p) { return p(0); }
 | |
| inline coord_t y(const Vec3crd& p) { return p(1); }
 | |
| inline coord_t z(const Vec3crd& p) { return p(2); }
 | |
| 
 | |
| inline void triangulate(const ExPolygon& expoly, Polygons& triangles) {
 | |
|     expoly.triangulate_p2t(&triangles);
 | |
| }
 | |
| 
 | |
| inline Polygons triangulate(const ExPolygon& expoly) {
 | |
|     Polygons tri; triangulate(expoly, tri); return tri;
 | |
| }
 | |
| 
 | |
| using Indices = std::vector<Vec3crd>;
 | |
| 
 | |
| /// Intermediate struct for a 3D mesh
 | |
| struct Contour3D {
 | |
|     Pointf3s points;
 | |
|     Indices indices;
 | |
| 
 | |
|     void merge(const Contour3D& ctr) {
 | |
|         auto s3 = coord_t(points.size());
 | |
|         auto s = coord_t(indices.size());
 | |
| 
 | |
|         points.insert(points.end(), ctr.points.begin(), ctr.points.end());
 | |
|         indices.insert(indices.end(), ctr.indices.begin(), ctr.indices.end());
 | |
| 
 | |
|         for(auto n = s; n < indices.size(); n++) {
 | |
|             auto& idx = indices[n]; x(idx) += s3; y(idx) += s3; z(idx) += s3;
 | |
|         }
 | |
|     }
 | |
| };
 | |
| 
 | |
| //using PointSet = Eigen::Matrix<double, Eigen::Dynamic, Eigen::Dynamic, Eigen::DontAlign>; //Eigen::MatrixXd;
 | |
| using ClusterEl = std::vector<unsigned>;
 | |
| using ClusteredPoints = std::vector<ClusterEl>;
 | |
| 
 | |
| /// Convert the triangulation output to an intermediate mesh.
 | |
| Contour3D convert(const Polygons& triangles, coord_t z, bool dir);
 | |
| 
 | |
| /// Mesh from an existing contour.
 | |
| inline TriangleMesh mesh(const Contour3D& ctour) {
 | |
|     return {ctour.points, ctour.indices};
 | |
| }
 | |
| 
 | |
| /// Mesh from an evaporating 3D contour
 | |
| inline TriangleMesh mesh(Contour3D&& ctour) {
 | |
|     return {std::move(ctour.points), std::move(ctour.indices)};
 | |
| }
 | |
| 
 | |
| }
 | |
| }
 | |
| 
 | |
| #endif // SLABOILERPLATE_HPP
 | 
