mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-31 12:41:20 -06:00 
			
		
		
		
	
		
			
				
	
	
		
			201 lines
		
	
	
	
		
			6.4 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			201 lines
		
	
	
	
		
			6.4 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| #ifndef SLASUPPORTTREE_HPP
 | |
| #define SLASUPPORTTREE_HPP
 | |
| 
 | |
| #include <vector>
 | |
| #include <array>
 | |
| #include <cstdint>
 | |
| #include <memory>
 | |
| #include <Eigen/Geometry>
 | |
| 
 | |
| #include "SLACommon.hpp"
 | |
| 
 | |
| 
 | |
| namespace Slic3r {
 | |
| 
 | |
| // Needed types from Point.hpp
 | |
| typedef int32_t coord_t;
 | |
| typedef Eigen::Matrix<double,   3, 1, Eigen::DontAlign> Vec3d;
 | |
| typedef Eigen::Matrix<float,    3, 1, Eigen::DontAlign> Vec3f;
 | |
| typedef Eigen::Matrix<coord_t,  3, 1, Eigen::DontAlign> Vec3crd;
 | |
| typedef std::vector<Vec3d>                              Pointf3s;
 | |
| typedef std::vector<Vec3crd>                            Points3;
 | |
| 
 | |
| class TriangleMesh;
 | |
| class Model;
 | |
| class ModelInstance;
 | |
| class ModelObject;
 | |
| class ExPolygon;
 | |
| 
 | |
| using SliceLayer = std::vector<ExPolygon>;
 | |
| using SlicedSupports = std::vector<SliceLayer>;
 | |
| 
 | |
| namespace sla {
 | |
| 
 | |
| enum class PillarConnectionMode {
 | |
|     zigzag,
 | |
|     cross,
 | |
|     dynamic
 | |
| };
 | |
| 
 | |
| struct SupportConfig {
 | |
|     // Radius in mm of the pointing side of the head.
 | |
|     double head_front_radius_mm = 0.2;
 | |
| 
 | |
|     // How much the pinhead has to penetrate the model surface
 | |
|     double head_penetration_mm = 0.5;
 | |
| 
 | |
|     // Radius of the back side of the 3d arrow.
 | |
|     double head_back_radius_mm = 0.5;
 | |
| 
 | |
|     // Width in mm from the back sphere center to the front sphere center.
 | |
|     double head_width_mm = 1.0;
 | |
| 
 | |
|     // How to connect pillars
 | |
|     PillarConnectionMode pillar_connection_mode = PillarConnectionMode::dynamic;
 | |
| 
 | |
|     // Only generate pillars that can be routed to ground
 | |
|     bool ground_facing_only = false;
 | |
| 
 | |
|     // TODO: unimplemented at the moment. This coefficient will have an impact
 | |
|     // when bridges and pillars are merged. The resulting pillar should be a bit
 | |
|     // thicker than the ones merging into it. How much thicker? I don't know
 | |
|     // but it will be derived from this value.
 | |
|     double pillar_widening_factor = 0.5;
 | |
| 
 | |
|     // Radius in mm of the pillar base.
 | |
|     double base_radius_mm = 2.0;
 | |
| 
 | |
|     // The height of the pillar base cone in mm.
 | |
|     double base_height_mm = 1.0;
 | |
| 
 | |
|     // The default angle for connecting support sticks and junctions.
 | |
|     double bridge_slope = M_PI/4;
 | |
| 
 | |
|     // The max length of a bridge in mm
 | |
|     double max_bridge_length_mm = 10.0;
 | |
| 
 | |
|     // The max distance of a pillar to pillar link.
 | |
|     double max_pillar_link_distance_mm = 10.0;
 | |
| 
 | |
|     // The elevation in Z direction upwards. This is the space between the pad
 | |
|     // and the model object's bounding box bottom.
 | |
|     double object_elevation_mm = 10;
 | |
| 
 | |
|     // /////////////////////////////////////////////////////////////////////////
 | |
|     // Compile time configuration values (candidates for runtime)
 | |
|     // /////////////////////////////////////////////////////////////////////////
 | |
| 
 | |
|     // The max Z angle for a normal at which it will get completely ignored.
 | |
|     static const double normal_cutoff_angle;
 | |
| 
 | |
|     // The shortest distance of any support structure from the model surface
 | |
|     static const double safety_distance_mm;
 | |
| 
 | |
|     static const double max_solo_pillar_height_mm;
 | |
|     static const double max_dual_pillar_height_mm;
 | |
|     static const double   optimizer_rel_score_diff;
 | |
|     static const unsigned optimizer_max_iterations;
 | |
|     static const unsigned pillar_cascade_neighbors;
 | |
|     static const unsigned max_bridges_on_pillar;
 | |
| };
 | |
| 
 | |
| struct PoolConfig;
 | |
| 
 | |
| /// A Control structure for the support calculation. Consists of the status
 | |
| /// indicator callback and the stop condition predicate.
 | |
| struct Controller {
 | |
| 
 | |
|     // This will signal the status of the calculation to the front-end
 | |
|     std::function<void(unsigned, const std::string&)> statuscb =
 | |
|             [](unsigned, const std::string&){};
 | |
| 
 | |
|     // Returns true if the calculation should be aborted.
 | |
|     std::function<bool(void)> stopcondition = [](){ return false; };
 | |
| 
 | |
|     // Similar to cancel callback. This should check the stop condition and
 | |
|     // if true, throw an appropriate exception. (TriangleMeshSlicer needs this)
 | |
|     // consider it a hard abort. stopcondition is permits the algorithm to
 | |
|     // terminate itself
 | |
|     std::function<void(void)> cancelfn = [](){};
 | |
| };
 | |
| 
 | |
| using PointSet = Eigen::MatrixXd;
 | |
| 
 | |
| //EigenMesh3D to_eigenmesh(const TriangleMesh& m);
 | |
| 
 | |
| // needed for find best rotation
 | |
| //EigenMesh3D to_eigenmesh(const ModelObject& model);
 | |
| 
 | |
| // Simple conversion of 'vector of points' to an Eigen matrix
 | |
| //PointSet    to_point_set(const std::vector<sla::SupportPoint>&);
 | |
| 
 | |
| 
 | |
| /* ************************************************************************** */
 | |
| 
 | |
| /// The class containing mesh data for the generated supports.
 | |
| class SLASupportTree {
 | |
|     class Impl;     // persistent support data
 | |
|     std::unique_ptr<Impl> m_impl;
 | |
| 
 | |
|     Impl& get() { return *m_impl; }
 | |
|     const Impl& get() const { return *m_impl; }
 | |
| 
 | |
|     friend void add_sla_supports(Model&,
 | |
|                                  const SupportConfig&,
 | |
|                                  const Controller&);
 | |
| 
 | |
|     // The generation algorithm is quite long and will be captured in a separate
 | |
|     // class with private data, helper methods, etc... This data is only needed
 | |
|     // during the calculation whereas the Impl class contains the persistent
 | |
|     // data, mostly the meshes.
 | |
|     class Algorithm;
 | |
| 
 | |
|     // Generate the 3D supports for a model intended for SLA print. This
 | |
|     // will instantiate the Algorithm class and call its appropriate methods
 | |
|     // with status indication.
 | |
|     bool generate(const std::vector<SupportPoint>& pts,
 | |
|                   const EigenMesh3D& mesh,
 | |
|                   const SupportConfig& cfg = {},
 | |
|                   const Controller& ctl = {});
 | |
| 
 | |
| public:
 | |
| 
 | |
|     SLASupportTree();
 | |
| 
 | |
|     SLASupportTree(const std::vector<SupportPoint>& pts,
 | |
|                    const EigenMesh3D& em,
 | |
|                    const SupportConfig& cfg = {},
 | |
|                    const Controller& ctl = {});
 | |
| 
 | |
|     SLASupportTree(const SLASupportTree&);
 | |
|     SLASupportTree& operator=(const SLASupportTree&);
 | |
| 
 | |
|     ~SLASupportTree();
 | |
| 
 | |
|     /// Get the whole mesh united into the output TriangleMesh
 | |
|     /// WITHOUT THE PAD
 | |
|     const TriangleMesh& merged_mesh() const;
 | |
| 
 | |
|     void merged_mesh_with_pad(TriangleMesh&) const;
 | |
| 
 | |
|     /// Get the sliced 2d layers of the support geometry.
 | |
|     SlicedSupports slice(float layerh, float init_layerh = -1.0) const;
 | |
| 
 | |
|     SlicedSupports slice(const std::vector<float>&, float closing_radius) const;
 | |
| 
 | |
|     /// Adding the "pad" (base pool) under the supports
 | |
|     const TriangleMesh& add_pad(const SliceLayer& baseplate,
 | |
|                                 const PoolConfig& pcfg) const;
 | |
| 
 | |
|     /// Get the pad geometry
 | |
|     const TriangleMesh& get_pad() const;
 | |
| 
 | |
|     void remove_pad();
 | |
| 
 | |
| };
 | |
| 
 | |
| }
 | |
| 
 | |
| }
 | |
| 
 | |
| #endif // SLASUPPORTTREE_HPP
 | 
