#ifndef slic3r_Polygon_hpp_ #define slic3r_Polygon_hpp_ #include #include #include "Line.hpp" #include "MultiPoint.hpp" #include "Polyline.hpp" namespace Slic3r { class Polygon : public MultiPoint { public: Point* last_point() const; Lines lines() const; Polyline* split_at(const Point* point) const; Polyline* split_at_index(int index) const; Polyline* split_at_first_point() const; Points equally_spaced_points(double distance) const; double area() const; bool is_counter_clockwise() const; bool is_clockwise() const; bool make_counter_clockwise(); bool make_clockwise(); bool is_valid() const; #ifdef SLIC3RXS SV* to_SV_ref(); SV* to_SV_clone_ref() const; #endif }; typedef std::vector Polygons; } #endif