2016-04-11 15:08:30 +00:00
|
|
|
#ifndef slic3r_FillHoneycomb_hpp_
|
|
|
|
#define slic3r_FillHoneycomb_hpp_
|
|
|
|
|
|
|
|
#include <map>
|
|
|
|
|
|
|
|
#include "../libslic3r.h"
|
|
|
|
|
|
|
|
#include "FillBase.hpp"
|
|
|
|
|
|
|
|
namespace Slic3r {
|
|
|
|
|
2016-09-13 09:26:38 +00:00
|
|
|
class FillHoneycomb : public Fill
|
2016-04-11 15:08:30 +00:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
virtual ~FillHoneycomb() {}
|
|
|
|
|
|
|
|
protected:
|
2016-11-30 18:47:45 +00:00
|
|
|
virtual Fill* clone() const { return new FillHoneycomb(*this); };
|
2016-09-13 09:26:38 +00:00
|
|
|
virtual void _fill_surface_single(
|
|
|
|
const FillParams ¶ms,
|
|
|
|
unsigned int thickness_layers,
|
|
|
|
const std::pair<float, Point> &direction,
|
|
|
|
ExPolygon &expolygon,
|
|
|
|
Polylines &polylines_out);
|
|
|
|
|
2016-04-11 15:08:30 +00:00
|
|
|
// Caching the
|
|
|
|
struct CacheID
|
|
|
|
{
|
|
|
|
CacheID(float adensity, coordf_t aspacing) :
|
|
|
|
density(adensity), spacing(aspacing) {}
|
|
|
|
float density;
|
|
|
|
coordf_t spacing;
|
|
|
|
bool operator<(const CacheID &other) const
|
|
|
|
{ return (density < other.density) || (density == other.density && spacing < other.spacing); }
|
|
|
|
bool operator==(const CacheID &other) const
|
|
|
|
{ return density == other.density && spacing == other.spacing; }
|
|
|
|
};
|
|
|
|
struct CacheData
|
|
|
|
{
|
|
|
|
coord_t distance;
|
|
|
|
coord_t hex_side;
|
|
|
|
coord_t hex_width;
|
|
|
|
coord_t pattern_height;
|
|
|
|
coord_t y_short;
|
|
|
|
coord_t x_offset;
|
|
|
|
coord_t y_offset;
|
|
|
|
Point hex_center;
|
|
|
|
};
|
|
|
|
typedef std::map<CacheID, CacheData> Cache;
|
|
|
|
Cache cache;
|
|
|
|
|
2016-09-13 09:26:38 +00:00
|
|
|
virtual float _layer_angle(size_t idx) const { return float(M_PI/3.) * (idx % 3); }
|
2016-04-11 15:08:30 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace Slic3r
|
|
|
|
|
|
|
|
#endif // slic3r_FillHoneycomb_hpp_
|