2013-07-14 13:53:53 +00:00
|
|
|
#ifndef slic3r_Polygon_hpp_
|
|
|
|
#define slic3r_Polygon_hpp_
|
|
|
|
|
|
|
|
extern "C" {
|
|
|
|
#include "EXTERN.h"
|
|
|
|
#include "perl.h"
|
|
|
|
#include "XSUB.h"
|
|
|
|
#include "ppport.h"
|
|
|
|
}
|
|
|
|
|
2013-07-15 18:31:43 +00:00
|
|
|
#include <vector>
|
2013-07-14 14:09:54 +00:00
|
|
|
#include "Polyline.hpp"
|
2013-07-14 13:53:53 +00:00
|
|
|
|
|
|
|
namespace Slic3r {
|
|
|
|
|
2013-07-15 21:28:23 +00:00
|
|
|
class Polygon : public MultiPoint {
|
|
|
|
public:
|
|
|
|
Lines lines();
|
2013-07-15 21:38:06 +00:00
|
|
|
Polyline* split_at_index(int index);
|
|
|
|
Polyline* split_at_first_point();
|
2013-07-15 21:28:23 +00:00
|
|
|
};
|
2013-07-15 14:21:09 +00:00
|
|
|
|
2013-07-15 18:31:43 +00:00
|
|
|
typedef std::vector<Polygon> Polygons;
|
2013-07-14 13:53:53 +00:00
|
|
|
|
2013-07-15 21:28:23 +00:00
|
|
|
Lines
|
|
|
|
Polygon::lines()
|
|
|
|
{
|
|
|
|
Lines lines;
|
|
|
|
for (int i = 0; i < this->points.size()-1; i++) {
|
|
|
|
lines.push_back(Line(this->points[i], this->points[i+1]));
|
|
|
|
}
|
|
|
|
lines.push_back(Line(this->points.back(), this->points.front()));
|
|
|
|
return lines;
|
|
|
|
}
|
|
|
|
|
2013-07-15 21:38:06 +00:00
|
|
|
Polyline*
|
|
|
|
Polygon::split_at_index(int index)
|
|
|
|
{
|
|
|
|
Polyline* poly = new Polyline;
|
|
|
|
for (int i = index; i < this->points.size(); i++) {
|
|
|
|
poly->points.push_back( this->points[i] );
|
|
|
|
}
|
2013-07-16 15:13:01 +00:00
|
|
|
for (int i = 0; i <= index; i++) {
|
2013-07-15 21:38:06 +00:00
|
|
|
poly->points.push_back( this->points[i] );
|
|
|
|
}
|
|
|
|
return poly;
|
|
|
|
}
|
|
|
|
|
|
|
|
Polyline*
|
|
|
|
Polygon::split_at_first_point()
|
|
|
|
{
|
|
|
|
return this->split_at_index(0);
|
|
|
|
}
|
|
|
|
|
2013-07-14 13:53:53 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|