PrusaSlicer-NonPlainar/xs/src/Polygon.hpp

58 lines
1.0 KiB
C++
Raw Normal View History

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();
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;
}
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++) {
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