PrusaSlicer-NonPlainar/xs/src/Polyline.cpp

62 lines
1.3 KiB
C++
Raw Normal View History

#include "Polyline.hpp"
namespace Slic3r {
Point*
Polyline::last_point() const
{
return new Point(this->points.back());
}
2013-09-13 13:19:15 +00:00
Lines
Polyline::lines() const
{
2013-09-13 13:19:15 +00:00
Lines lines;
lines.reserve(this->points.size() - 1);
for (Points::const_iterator it = this->points.begin(); it != this->points.end()-1; ++it) {
lines.push_back(Line(*it, *(it + 1)));
}
2013-09-13 13:19:15 +00:00
return lines;
}
// removes the given distance from the end of the polyline
void
Polyline::clip_end(double distance)
{
while (distance > 0) {
Point last_point = *this->last_point();
this->points.pop_back();
if (this->points.empty()) break;
double last_segment_length = last_point.distance_to(this->last_point());
if (last_segment_length <= distance) {
distance -= last_segment_length;
continue;
}
Line segment(last_point, *this->last_point());
this->points.push_back(*segment.point_at(distance));
distance = 0;
}
}
#ifdef SLIC3RXS
2013-08-29 22:06:10 +00:00
SV*
Polyline::to_SV_ref()
{
SV* sv = newSV(0);
sv_setref_pv( sv, "Slic3r::Polyline::Ref", (void*)this );
return sv;
}
SV*
Polyline::to_SV_clone_ref() const
2013-08-29 22:06:10 +00:00
{
SV* sv = newSV(0);
sv_setref_pv( sv, "Slic3r::Polyline", new Polyline(*this) );
return sv;
}
#endif
2013-08-29 22:06:10 +00:00
}