From b829c9bcc8d8c08f7d116f7a16345cad32b7583d Mon Sep 17 00:00:00 2001 From: Joachim Schoeberl Date: Fri, 30 Jul 2021 09:43:29 +0200 Subject: [PATCH] occ-triangulation --- libsrc/occ/python_occ.cpp | 48 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 48 insertions(+) diff --git a/libsrc/occ/python_occ.cpp b/libsrc/occ/python_occ.cpp index 17d9beb7..d83fc368 100644 --- a/libsrc/occ/python_occ.cpp +++ b/libsrc/occ/python_occ.cpp @@ -77,6 +77,9 @@ void CreateOCCParametersFromKwargs(OCCParameters& occparam, py::dict kwargs) DLL_HEADER void ExportNgOCC(py::module &m) { m.attr("occ_version") = OCC_VERSION_COMPLETE; + // not working, since occ - exceptions don't derive from std::exception + // py::register_exception(m, "OCC-Exception"); + py::class_, NetgenGeometry> (m, "OCCGeometry", R"raw_string(Use LoadOCCGeometry to load the geometry from a *.step file.)raw_string") .def(py::init<>()) /* @@ -479,6 +482,51 @@ DLL_HEADER void ExportNgOCC(py::module &m) return builder.Shape(); }) + + .def("Triangulation", [](const TopoDS_Shape & shape) + { + // extracted from vsocc.cpp + + Array< std::array,3> > triangles; + TopoDS_Face face; + try + { + face = TopoDS::Face(shape); + } + catch (Standard_Failure & e) + { + e.Print (cout); + throw NgException ("Triangulation: shape is not a face"); + } + + BRepTools::Clean (shape); + double deflection = 0.01; + BRepMesh_IncrementalMesh (shape, deflection, true); + + Handle(Geom_Surface) surf = BRep_Tool::Surface (face); + + TopLoc_Location loc; + Handle(Poly_Triangulation) triangulation = BRep_Tool::Triangulation (face, loc); + + if (!triangulation.IsNull()) + { + int ntriangles = triangulation -> NbTriangles(); + for (int j = 1; j <= ntriangles; j++) + { + cout << "triangle " << j << "/" << ntriangles << endl; + Poly_Triangle triangle = (triangulation -> Triangles())(j); + std::array,3> pts; + for (int k = 0; k < 3; k++) + pts[k] = occ2ng( (triangulation -> Nodes())(triangle(k+1)).Transformed(loc) ); + + triangles.Append ( pts ); + for (auto p : pts) cout << p << " "; + cout << endl; + } + } + + return triangles; + }) ;