2013-07-14 15:53:53 +02:00
|
|
|
#ifndef slic3r_Polygon_hpp_
|
|
|
|
#define slic3r_Polygon_hpp_
|
|
|
|
|
2013-07-16 21:04:14 +02:00
|
|
|
#include <myinit.h>
|
2013-07-15 20:31:43 +02:00
|
|
|
#include <vector>
|
2013-07-16 21:04:14 +02:00
|
|
|
#include "Line.hpp"
|
|
|
|
#include "MultiPoint.hpp"
|
2013-07-14 16:09:54 +02:00
|
|
|
#include "Polyline.hpp"
|
2013-07-14 15:53:53 +02:00
|
|
|
|
|
|
|
namespace Slic3r {
|
|
|
|
|
2013-11-22 02:16:10 +01:00
|
|
|
class Polygon;
|
|
|
|
typedef std::vector<Polygon> Polygons;
|
|
|
|
|
2013-07-15 23:28:23 +02:00
|
|
|
class Polygon : public MultiPoint {
|
|
|
|
public:
|
2014-01-07 15:40:38 +01:00
|
|
|
operator Polygons() const;
|
2013-09-02 22:33:03 +02:00
|
|
|
Point* last_point() const;
|
2013-09-03 19:26:58 +02:00
|
|
|
Lines lines() const;
|
2013-09-13 15:19:15 +02:00
|
|
|
Polyline* split_at(const Point* point) const;
|
|
|
|
Polyline* split_at_index(int index) const;
|
|
|
|
Polyline* split_at_first_point() const;
|
2013-11-11 20:59:58 +01:00
|
|
|
Points equally_spaced_points(double distance) const;
|
2013-08-26 22:50:26 +02:00
|
|
|
double area() const;
|
|
|
|
bool is_counter_clockwise() const;
|
2013-08-27 01:26:44 +02:00
|
|
|
bool is_clockwise() const;
|
2013-07-16 21:09:29 +02:00
|
|
|
bool make_counter_clockwise();
|
|
|
|
bool make_clockwise();
|
2013-08-26 23:27:51 +02:00
|
|
|
bool is_valid() const;
|
2013-11-21 16:21:42 +01:00
|
|
|
bool contains_point(const Point* point) const;
|
2013-11-21 20:25:24 +01:00
|
|
|
Polygons simplify(double tolerance) const;
|
|
|
|
void simplify(double tolerance, Polygons &polygons) const;
|
2013-09-13 14:48:40 +02:00
|
|
|
|
|
|
|
#ifdef SLIC3RXS
|
|
|
|
SV* to_SV_ref();
|
|
|
|
SV* to_SV_clone_ref() const;
|
|
|
|
#endif
|
2013-07-15 23:28:23 +02:00
|
|
|
};
|
2013-07-15 16:21:09 +02:00
|
|
|
|
2013-07-14 15:53:53 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|