diff options
Diffstat (limited to 'xs/src/libslic3r/Geometry.hpp')
-rw-r--r-- | xs/src/libslic3r/Geometry.hpp | 41 |
1 files changed, 41 insertions, 0 deletions
diff --git a/xs/src/libslic3r/Geometry.hpp b/xs/src/libslic3r/Geometry.hpp new file mode 100644 index 000000000..2dc183f82 --- /dev/null +++ b/xs/src/libslic3r/Geometry.hpp @@ -0,0 +1,41 @@ +#ifndef slic3r_Geometry_hpp_ +#define slic3r_Geometry_hpp_ + +#include "BoundingBox.hpp" +#include "Polygon.hpp" +#include "Polyline.hpp" + +#include "boost/polygon/voronoi.hpp" +using boost::polygon::voronoi_builder; +using boost::polygon::voronoi_diagram; + +namespace Slic3r { namespace Geometry { + +void convex_hull(Points &points, Polygon* hull); +void chained_path(Points &points, std::vector<Points::size_type> &retval, Point start_near); +void chained_path(Points &points, std::vector<Points::size_type> &retval); +template<class T> void chained_path_items(Points &points, T &items, T &retval); +bool directions_parallel(double angle1, double angle2, double max_diff = 0); + +class MedialAxis { + public: + Points points; + Lines lines; + double max_width; + double min_width; + MedialAxis(double _max_width, double _min_width) : max_width(_max_width), min_width(_min_width) {}; + void build(Polylines* polylines); + + private: + typedef voronoi_diagram<double> VD; + VD vd; + std::set<const VD::edge_type*> edges; + Line edge_to_line(const VD::edge_type &edge) const; + void process_edge_neighbors(const voronoi_diagram<double>::edge_type& edge, Points* points); + bool is_valid_edge(const voronoi_diagram<double>::edge_type& edge) const; + Line retrieve_segment(const voronoi_diagram<double>::cell_type& cell) const; +}; + +} } + +#endif |