From 462a9ae64ceaf4c99b1c7ba91da37c582b0a82bf Mon Sep 17 00:00:00 2001 From: Joachim Schoeberl Date: Wed, 18 Aug 2021 22:31:41 +0200 Subject: [PATCH] Implicit conversion from edge to wire, Circle at current position --- libsrc/occ/python_occ_shapes.cpp | 50 ++++++++++++++++++++++++++++---- 1 file changed, 45 insertions(+), 5 deletions(-) diff --git a/libsrc/occ/python_occ_shapes.cpp b/libsrc/occ/python_occ_shapes.cpp index ea432d9a..e957a003 100644 --- a/libsrc/occ/python_occ_shapes.cpp +++ b/libsrc/occ/python_occ_shapes.cpp @@ -428,7 +428,6 @@ public: auto Circle(double x, double y, double r) { - MoveTo(x+r, y); Direction (0, 1); Arc(r, 180); @@ -462,6 +461,11 @@ public: */ } + auto Circle (double r) + { + gp_Pnt2d pos = localpos.Location(); + return Circle (pos.X(), pos.Y(), r); + } shared_ptr Close () { @@ -1079,7 +1083,39 @@ DLL_HEADER void ExportNgOCCShapes(py::module &m) return v; }) ; - py::class_ (m, "TopoDS_Wire"); + py::class_ (m, "Wire") + .def(py::init([](const TopoDS_Edge & edge) { + BRepBuilderAPI_MakeWire builder; + builder.Add(edge); + return builder.Wire(); + })) + .def(py::init([](std::vector edges) { + BRepBuilderAPI_MakeWire builder; + try + { + for (auto s : edges) + switch (s.ShapeType()) + { + case TopAbs_EDGE: + builder.Add(TopoDS::Edge(s)); break; + case TopAbs_WIRE: + builder.Add(TopoDS::Wire(s)); break; + default: + throw Exception("can make wire only from edges and wires"); + } + return builder.Wire(); + } + catch (Standard_Failure & e) + { + stringstream errstr; + e.Print(errstr); + throw NgException("error in wire builder: "+errstr.str()); + } + })) + ; + + + ; py::class_ (m, "TopoDS_Face") .def(py::init([] (const TopoDS_Shape & shape) { return TopoDS::Face(shape); @@ -1122,6 +1158,7 @@ DLL_HEADER void ExportNgOCCShapes(py::module &m) py::implicitly_convertible(); + py::implicitly_convertible(); @@ -1506,7 +1543,8 @@ DLL_HEADER void ExportNgOCCShapes(py::module &m) BRepLib::BuildCurves3d(edge); return edge; }); - + + /* m.def("Wire", [](std::vector edges) { BRepBuilderAPI_MakeWire builder; try @@ -1530,7 +1568,7 @@ DLL_HEADER void ExportNgOCCShapes(py::module &m) throw NgException("error in wire builder: "+errstr.str()); } }); - + */ m.def("Face", [](TopoDS_Wire wire) { return BRepBuilderAPI_MakeFace(wire).Face(); }, py::arg("w")); @@ -1608,7 +1646,9 @@ DLL_HEADER void ExportNgOCCShapes(py::module &m) .def("Line", [](WorkPlane&wp,double h,double v, optional name) { return wp.Line(h,v,name); }, py::arg("dx"), py::arg("dy"), py::arg("name")=nullopt) .def("Rectangle", &WorkPlane::Rectangle) - .def("Circle", &WorkPlane::Circle) + .def("Circle", [](WorkPlane&wp, double x, double y, double r) { + return wp.Circle(x,y,r); }, py::arg("x"), py::arg("y"), py::arg("r")) + .def("Circle", [](WorkPlane&wp, double r) { return wp.Circle(r); }, py::arg("r")) .def("Offset", &WorkPlane::Offset) .def("Reverse", &WorkPlane::Reverse) .def("Close", &WorkPlane::Close)