diff options
author | clifford <clifford@b57f626f-c46c-0410-a088-ec61d464b74c> | 2009-12-27 23:49:27 (GMT) |
---|---|---|
committer | clifford <clifford@b57f626f-c46c-0410-a088-ec61d464b74c> | 2009-12-27 23:49:27 (GMT) |
commit | f7799a8e4ea0c31bd284dc4cf5e2d23b13029a4c (patch) | |
tree | 608ae6c2f862db9d60ad3d9310645d8ef4fb319b /csgops.cc | |
parent | 612f04dfdf6378dcae3ca3de4d445ffbe53e1c75 (diff) |
Clifford Wolf:
Added CGAL Nef Polyhedron 2D/3D abstraction
git-svn-id: http://svn.clifford.at/openscad/trunk@187 b57f626f-c46c-0410-a088-ec61d464b74c
Diffstat (limited to 'csgops.cc')
-rw-r--r-- | csgops.cc | 24 |
1 files changed, 17 insertions, 7 deletions
@@ -77,16 +77,26 @@ CGAL_Nef_polyhedron CsgNode::render_cgal_nef_polyhedron() const if (first) { N = v->render_cgal_nef_polyhedron(); first = false; - } else if (type == CSG_TYPE_UNION) { - N += v->render_cgal_nef_polyhedron(); - } else if (type == CSG_TYPE_DIFFERENCE) { - N -= v->render_cgal_nef_polyhedron(); - } else if (type == CSG_TYPE_INTERSECTION) { - N *= v->render_cgal_nef_polyhedron(); + } else if (N.dim == 2) { + if (type == CSG_TYPE_UNION) { + N.p2 += v->render_cgal_nef_polyhedron().p2; + } else if (type == CSG_TYPE_DIFFERENCE) { + N.p2 -= v->render_cgal_nef_polyhedron().p2; + } else if (type == CSG_TYPE_INTERSECTION) { + N.p2 *= v->render_cgal_nef_polyhedron().p2; + } + } else if (N.dim == 3) { + if (type == CSG_TYPE_UNION) { + N.p3 += v->render_cgal_nef_polyhedron().p3; + } else if (type == CSG_TYPE_DIFFERENCE) { + N.p3 -= v->render_cgal_nef_polyhedron().p3; + } else if (type == CSG_TYPE_INTERSECTION) { + N.p3 *= v->render_cgal_nef_polyhedron().p3; + } } } - cgal_nef_cache.insert(cache_id, new CGAL_Nef_polyhedron(N), N.number_of_vertices()); + cgal_nef_cache.insert(cache_id, new CGAL_Nef_polyhedron(N), N.weight()); progress_report(); return N; } |