22#include "manifold/common.h"
23#include "manifold/vec_view.h"
98 std::vector<CrossSection>
Decompose()
const;
127 double miter_limit = 2.0,
int circularSegments = 0)
const;
136 const std::vector<CrossSection>& crossSections,
OpType op);
155 mutable std::mutex pathsMutex_;
156 mutable std::shared_ptr<const PathImpl> paths_;
157 mutable mat2x3 transform_ = la::identity;
159 mutable double tolerance_ = 0.0;
161 std::shared_ptr<const PathImpl> GetPaths()
const;
CrossSection Boolean(const CrossSection &second, OpType op) const
Definition cross_section.cpp:347
CrossSection & operator+=(const CrossSection &)
Definition cross_section.cpp:412
Polygons ToPolygons() const
Definition cross_section.cpp:763
CrossSection WarpBatch(std::function< void(VecView< vec2 >)> warpFunc) const
Definition cross_section.cpp:569
CrossSection operator+(const CrossSection &) const
Definition cross_section.cpp:404
CrossSection operator^(const CrossSection &) const
Definition cross_section.cpp:437
CrossSection Translate(const vec2 v) const
Definition cross_section.cpp:484
CrossSection Mirror(const vec2 ax) const
Definition cross_section.cpp:521
::manifold::JoinType JoinType
Definition cross_section.h:81
CrossSection & operator-=(const CrossSection &)
Definition cross_section.cpp:429
static CrossSection Square(const vec2 dims, bool center=false)
Definition cross_section.cpp:317
std::vector< CrossSection > Decompose() const
Definition cross_section.cpp:464
CrossSection Transform(const mat2x3 &m) const
Definition cross_section.cpp:535
CrossSection Offset(double delta, JoinType jt=JoinType::Round, double miter_limit=2.0, int circularSegments=0) const
Definition cross_section.cpp:640
CrossSection Rotate(double degrees) const
Definition cross_section.cpp:495
static CrossSection BatchBoolean(const std::vector< CrossSection > &crossSections, OpType op)
Definition cross_section.cpp:364
size_t NumContour() const
Definition cross_section.cpp:741
bool IsEmpty() const
Definition cross_section.cpp:746
FillRule
Definition cross_section.h:69
@ Positive
Only sub-regions with winding counts > 0 are filled.
Definition cross_section.h:72
@ NonZero
Only non-zero sub-regions are filled.
Definition cross_section.h:71
@ EvenOdd
Only odd numbered sub-regions are filled.
Definition cross_section.h:70
@ Negative
Only sub-regions with winding counts < 0 are filled.
Definition cross_section.h:73
CrossSection & operator^=(const CrossSection &)
Definition cross_section.cpp:445
CrossSection Simplify(double epsilon=1e-6) const
Definition cross_section.cpp:601
CrossSection Hull() const
Definition cross_section.cpp:688
CrossSection Warp(std::function< void(vec2 &)> warpFunc) const
Definition cross_section.cpp:556
double Area() const
Definition cross_section.cpp:724
size_t NumVert() const
Definition cross_section.cpp:731
CrossSection()
Definition cross_section.cpp:197
CrossSection Scale(const vec2 s) const
Definition cross_section.cpp:508
static CrossSection Compose(const std::vector< CrossSection > &)
Definition cross_section.cpp:454
Rect Bounds() const
Definition cross_section.cpp:752
CrossSection operator-(const CrossSection &) const
Definition cross_section.cpp:421
static CrossSection Circle(double radius, int circularSegments=0)
Definition cross_section.cpp:333
constexpr double degrees(double a)
Definition common.h:90
OpType
Boolean operation type: Add (Union), Subtract (Difference), and Intersect.
Definition common.h:626
std::vector< SimplePolygon > Polygons
Set of polygons with holes. Order of contours is arbitrary. Can contain any depth of nested holes and...
Definition common.h:155
std::vector< vec2 > SimplePolygon
Single polygon contour, wound CCW. First and last point are implicitly connected. Should ensure all i...
Definition common.h:147
JoinType
Definition common.h:637
@ Round
Definition common.h:641
Definition cross_section.cpp:32
Axis-aligned 2D box, primarily for bounding.
Definition common.h:460