PrusaSlicer-NonPlainar/xs/src/libslic3r/Geometry.hpp

47 lines
1.6 KiB
C++
Raw Normal View History

2013-11-22 21:38:30 +00:00
#ifndef slic3r_Geometry_hpp_
#define slic3r_Geometry_hpp_
#include "BoundingBox.hpp"
2013-11-22 21:38:30 +00:00
#include "Polygon.hpp"
#include "Polyline.hpp"
2013-11-22 21:38:30 +00:00
#include "boost/polygon/voronoi.hpp"
using boost::polygon::voronoi_builder;
using boost::polygon::voronoi_diagram;
namespace Slic3r { namespace Geometry {
2013-11-22 21:38:30 +00:00
void convex_hull(Points points, Polygon* hull);
2014-11-09 14:27:34 +00:00
void convex_hull(const Polygons &polygons, Polygon* hull);
void chained_path(const Points &points, std::vector<Points::size_type> &retval, Point start_near);
void chained_path(const Points &points, std::vector<Points::size_type> &retval);
2013-11-23 22:21:59 +00:00
template<class T> void chained_path_items(Points &points, T &items, T &retval);
bool directions_parallel(double angle1, double angle2, double max_diff = 0);
2014-11-15 21:41:22 +00:00
template<class T> bool contains_point(const std::vector<T> &vector, const Point &point);
double rad2deg(double angle);
double rad2deg_dir(double angle);
double deg2rad(double angle);
2013-11-22 21:38:30 +00:00
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;
};
} }
2013-11-22 21:38:30 +00:00
#endif