2013-07-15 12:14:22 +02:00
|
|
|
#ifndef slic3r_ExtrusionEntity_hpp_
|
|
|
|
#define slic3r_ExtrusionEntity_hpp_
|
|
|
|
|
2015-12-08 00:39:54 +01:00
|
|
|
#include "libslic3r.h"
|
2013-07-15 12:14:22 +02:00
|
|
|
#include "Polygon.hpp"
|
|
|
|
#include "Polyline.hpp"
|
|
|
|
|
|
|
|
namespace Slic3r {
|
|
|
|
|
2013-11-21 17:53:50 +01:00
|
|
|
class ExPolygonCollection;
|
|
|
|
class ExtrusionEntityCollection;
|
2014-04-08 02:43:02 +03:00
|
|
|
class Extruder;
|
2013-11-21 17:53:50 +01:00
|
|
|
|
2014-05-12 21:49:17 +02:00
|
|
|
/* Each ExtrusionRole value identifies a distinct set of { extruder, speed } */
|
2013-07-15 12:14:22 +02:00
|
|
|
enum ExtrusionRole {
|
2015-07-02 14:29:20 +02:00
|
|
|
erNone,
|
2013-07-15 12:14:22 +02:00
|
|
|
erPerimeter,
|
|
|
|
erExternalPerimeter,
|
|
|
|
erOverhangPerimeter,
|
2014-05-12 21:49:17 +02:00
|
|
|
erInternalInfill,
|
|
|
|
erSolidInfill,
|
|
|
|
erTopSolidInfill,
|
|
|
|
erBridgeInfill,
|
|
|
|
erGapFill,
|
2013-07-15 12:14:22 +02:00
|
|
|
erSkirt,
|
|
|
|
erSupportMaterial,
|
2014-05-12 22:59:49 +02:00
|
|
|
erSupportMaterialInterface,
|
2014-05-12 21:49:17 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
/* Special flags describing loop */
|
|
|
|
enum ExtrusionLoopRole {
|
|
|
|
elrDefault,
|
|
|
|
elrContourInternalPerimeter,
|
2015-12-21 15:02:39 +01:00
|
|
|
elrSkirt,
|
2013-07-15 12:14:22 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
class ExtrusionEntity
|
|
|
|
{
|
|
|
|
public:
|
2015-04-12 20:16:27 +02:00
|
|
|
virtual bool is_collection() const {
|
|
|
|
return false;
|
|
|
|
};
|
2015-01-08 15:19:56 +01:00
|
|
|
virtual bool is_loop() const {
|
|
|
|
return false;
|
|
|
|
};
|
2015-03-09 18:28:07 +01:00
|
|
|
virtual bool can_reverse() const {
|
|
|
|
return true;
|
|
|
|
};
|
2013-08-29 11:47:59 +02:00
|
|
|
virtual ExtrusionEntity* clone() const = 0;
|
2013-07-18 19:09:07 +02:00
|
|
|
virtual ~ExtrusionEntity() {};
|
2013-08-29 11:47:59 +02:00
|
|
|
virtual void reverse() = 0;
|
2014-04-24 16:40:10 +02:00
|
|
|
virtual Point first_point() const = 0;
|
|
|
|
virtual Point last_point() const = 0;
|
2015-01-15 20:06:30 +01:00
|
|
|
virtual Polygons grow() const = 0;
|
2015-05-31 22:04:32 +02:00
|
|
|
virtual double min_mm3_per_mm() const = 0;
|
2015-07-07 01:17:31 +02:00
|
|
|
virtual Polyline as_polyline() const = 0;
|
2016-03-19 19:40:11 +01:00
|
|
|
virtual double length() const { return 0; };
|
2013-07-15 12:14:22 +02:00
|
|
|
};
|
|
|
|
|
2013-07-18 19:09:07 +02:00
|
|
|
typedef std::vector<ExtrusionEntity*> ExtrusionEntitiesPtr;
|
|
|
|
|
2013-07-15 12:14:22 +02:00
|
|
|
class ExtrusionPath : public ExtrusionEntity
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
Polyline polyline;
|
2014-05-08 11:07:37 +02:00
|
|
|
ExtrusionRole role;
|
|
|
|
double mm3_per_mm; // mm^3 of plastic per mm of linear head motion
|
|
|
|
float width;
|
|
|
|
float height;
|
|
|
|
|
2014-05-12 21:49:17 +02:00
|
|
|
ExtrusionPath(ExtrusionRole role) : role(role), mm3_per_mm(-1), width(-1), height(-1) {};
|
2014-05-08 11:07:37 +02:00
|
|
|
ExtrusionPath* clone() const;
|
2013-07-15 12:14:22 +02:00
|
|
|
void reverse();
|
2014-04-24 16:40:10 +02:00
|
|
|
Point first_point() const;
|
|
|
|
Point last_point() const;
|
2014-03-09 20:19:30 +01:00
|
|
|
void intersect_expolygons(const ExPolygonCollection &collection, ExtrusionEntityCollection* retval) const;
|
|
|
|
void subtract_expolygons(const ExPolygonCollection &collection, ExtrusionEntityCollection* retval) const;
|
2013-11-21 18:03:40 +01:00
|
|
|
void clip_end(double distance);
|
2013-11-21 20:25:24 +01:00
|
|
|
void simplify(double tolerance);
|
2016-03-19 19:40:11 +01:00
|
|
|
virtual double length() const;
|
2014-05-08 11:07:37 +02:00
|
|
|
bool is_perimeter() const;
|
2014-12-17 00:34:00 +01:00
|
|
|
bool is_infill() const;
|
|
|
|
bool is_solid_infill() const;
|
2014-05-08 11:07:37 +02:00
|
|
|
bool is_bridge() const;
|
2015-01-15 20:06:30 +01:00
|
|
|
Polygons grow() const;
|
2015-05-31 22:04:32 +02:00
|
|
|
double min_mm3_per_mm() const {
|
|
|
|
return this->mm3_per_mm;
|
|
|
|
};
|
2015-07-07 01:17:31 +02:00
|
|
|
Polyline as_polyline() const {
|
|
|
|
return this->polyline;
|
|
|
|
};
|
2014-05-08 11:07:37 +02:00
|
|
|
|
2013-11-21 17:53:50 +01:00
|
|
|
private:
|
2014-03-09 20:19:30 +01:00
|
|
|
void _inflate_collection(const Polylines &polylines, ExtrusionEntityCollection* collection) const;
|
2013-07-15 12:14:22 +02:00
|
|
|
};
|
|
|
|
|
2014-05-08 11:07:37 +02:00
|
|
|
typedef std::vector<ExtrusionPath> ExtrusionPaths;
|
|
|
|
|
2013-07-15 12:14:22 +02:00
|
|
|
class ExtrusionLoop : public ExtrusionEntity
|
|
|
|
{
|
|
|
|
public:
|
2014-05-08 11:07:37 +02:00
|
|
|
ExtrusionPaths paths;
|
2014-05-12 21:49:17 +02:00
|
|
|
ExtrusionLoopRole role;
|
2014-05-07 12:02:09 +02:00
|
|
|
|
2014-05-12 21:49:17 +02:00
|
|
|
ExtrusionLoop(ExtrusionLoopRole role = elrDefault) : role(role) {};
|
2015-07-07 01:17:31 +02:00
|
|
|
ExtrusionLoop(const ExtrusionPaths &paths, ExtrusionLoopRole role = elrDefault)
|
|
|
|
: paths(paths), role(role) {};
|
2016-03-19 15:33:58 +01:00
|
|
|
ExtrusionLoop(const ExtrusionPath &path, ExtrusionLoopRole role = elrDefault)
|
|
|
|
: role(role) {
|
|
|
|
this->paths.push_back(path);
|
|
|
|
};
|
2015-01-08 15:19:56 +01:00
|
|
|
bool is_loop() const {
|
|
|
|
return true;
|
|
|
|
};
|
2015-03-09 18:28:07 +01:00
|
|
|
bool can_reverse() const {
|
|
|
|
return false;
|
|
|
|
};
|
2013-08-29 11:47:59 +02:00
|
|
|
ExtrusionLoop* clone() const;
|
2014-05-08 11:07:37 +02:00
|
|
|
bool make_clockwise();
|
2013-08-29 01:40:42 +02:00
|
|
|
bool make_counter_clockwise();
|
2013-08-29 11:47:59 +02:00
|
|
|
void reverse();
|
2014-04-24 16:40:10 +02:00
|
|
|
Point first_point() const;
|
|
|
|
Point last_point() const;
|
2015-01-25 15:21:45 +01:00
|
|
|
Polygon polygon() const;
|
2016-03-19 19:40:11 +01:00
|
|
|
virtual double length() const;
|
2014-11-08 12:56:14 +01:00
|
|
|
bool split_at_vertex(const Point &point);
|
2014-05-08 11:07:37 +02:00
|
|
|
void split_at(const Point &point);
|
|
|
|
void clip_end(double distance, ExtrusionPaths* paths) const;
|
|
|
|
bool has_overhang_point(const Point &point) const;
|
2014-12-17 01:15:47 +01:00
|
|
|
bool is_perimeter() const;
|
|
|
|
bool is_infill() const;
|
|
|
|
bool is_solid_infill() const;
|
2015-01-15 20:06:30 +01:00
|
|
|
Polygons grow() const;
|
2015-05-31 22:04:32 +02:00
|
|
|
double min_mm3_per_mm() const;
|
2015-07-07 01:17:31 +02:00
|
|
|
Polyline as_polyline() const {
|
2015-07-23 15:53:02 +02:00
|
|
|
return this->polygon().split_at_first_point();
|
2015-07-07 01:17:31 +02:00
|
|
|
};
|
2013-07-15 12:14:22 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|