summaryrefslogtreecommitdiff
path: root/src/CGAL_Nef_polyhedron.h
blob: 7f59861e7ccd86d9b379a64b30fd9ad79de716b1 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
#ifndef CGAL_NEF_POLYHEDRON_H_
#define CGAL_NEF_POLYHEDRON_H_

#include "cgal.h"
#include "memory.h"
#include <string>
#include "linalg.h"

class CGAL_Nef_polyhedron
{
public:
	CGAL_Nef_polyhedron(int dim = 0) : dim(dim) {}
	CGAL_Nef_polyhedron(CGAL_Nef_polyhedron2 *p);
	CGAL_Nef_polyhedron(CGAL_Nef_polyhedron3 *p);
	~CGAL_Nef_polyhedron() {}

  // Empty means it is a geometric node which has zero area/volume
	bool isEmpty() const { return (dim > 0 && !p2 && !p3); }
  // Null means the node doesn't contain any geometry (for whatever reason)
	bool isNull() const { return !p2 && !p3; }
	void reset() { dim=0; p2.reset(); p3.reset(); }
	CGAL_Nef_polyhedron &operator+=(const CGAL_Nef_polyhedron &other);
	CGAL_Nef_polyhedron &operator*=(const CGAL_Nef_polyhedron &other);
	CGAL_Nef_polyhedron &operator-=(const CGAL_Nef_polyhedron &other);
	CGAL_Nef_polyhedron &minkowski(const CGAL_Nef_polyhedron &other);
	CGAL_Nef_polyhedron copy() const;
	std::string dump() const;
	int weight() const;
	class PolySet *convertToPolyset();
	class DxfData *convertToDxfData() const;
	void transform( const Transform3d &matrix );
	int dim;
	shared_ptr<CGAL_Nef_polyhedron2> p2;
	shared_ptr<CGAL_Nef_polyhedron3> p3;
};

#endif
contact: Jan Huwald // Impressum