mirror of
https://github.com/NGSolve/netgen.git
synced 2025-01-12 14:10:34 +05:00
Implicit conversion from edge to wire, Circle at current position
This commit is contained in:
parent
18c30805ab
commit
462a9ae64c
@ -428,7 +428,6 @@ public:
|
|||||||
|
|
||||||
auto Circle(double x, double y, double r)
|
auto Circle(double x, double y, double r)
|
||||||
{
|
{
|
||||||
|
|
||||||
MoveTo(x+r, y);
|
MoveTo(x+r, y);
|
||||||
Direction (0, 1);
|
Direction (0, 1);
|
||||||
Arc(r, 180);
|
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<WorkPlane> Close ()
|
shared_ptr<WorkPlane> Close ()
|
||||||
{
|
{
|
||||||
@ -1079,7 +1083,39 @@ DLL_HEADER void ExportNgOCCShapes(py::module &m)
|
|||||||
return v;
|
return v;
|
||||||
})
|
})
|
||||||
;
|
;
|
||||||
py::class_<TopoDS_Wire, TopoDS_Shape> (m, "TopoDS_Wire");
|
py::class_<TopoDS_Wire, TopoDS_Shape> (m, "Wire")
|
||||||
|
.def(py::init([](const TopoDS_Edge & edge) {
|
||||||
|
BRepBuilderAPI_MakeWire builder;
|
||||||
|
builder.Add(edge);
|
||||||
|
return builder.Wire();
|
||||||
|
}))
|
||||||
|
.def(py::init([](std::vector<TopoDS_Shape> 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_<TopoDS_Face, TopoDS_Shape> (m, "TopoDS_Face")
|
py::class_<TopoDS_Face, TopoDS_Shape> (m, "TopoDS_Face")
|
||||||
.def(py::init([] (const TopoDS_Shape & shape) {
|
.def(py::init([] (const TopoDS_Shape & shape) {
|
||||||
return TopoDS::Face(shape);
|
return TopoDS::Face(shape);
|
||||||
@ -1122,6 +1158,7 @@ DLL_HEADER void ExportNgOCCShapes(py::module &m)
|
|||||||
|
|
||||||
|
|
||||||
py::implicitly_convertible<TopoDS_Shape, TopoDS_Face>();
|
py::implicitly_convertible<TopoDS_Shape, TopoDS_Face>();
|
||||||
|
py::implicitly_convertible<TopoDS_Edge, TopoDS_Wire>();
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@ -1507,6 +1544,7 @@ DLL_HEADER void ExportNgOCCShapes(py::module &m)
|
|||||||
return edge;
|
return edge;
|
||||||
});
|
});
|
||||||
|
|
||||||
|
/*
|
||||||
m.def("Wire", [](std::vector<TopoDS_Shape> edges) {
|
m.def("Wire", [](std::vector<TopoDS_Shape> edges) {
|
||||||
BRepBuilderAPI_MakeWire builder;
|
BRepBuilderAPI_MakeWire builder;
|
||||||
try
|
try
|
||||||
@ -1530,7 +1568,7 @@ DLL_HEADER void ExportNgOCCShapes(py::module &m)
|
|||||||
throw NgException("error in wire builder: "+errstr.str());
|
throw NgException("error in wire builder: "+errstr.str());
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
*/
|
||||||
m.def("Face", [](TopoDS_Wire wire) {
|
m.def("Face", [](TopoDS_Wire wire) {
|
||||||
return BRepBuilderAPI_MakeFace(wire).Face();
|
return BRepBuilderAPI_MakeFace(wire).Face();
|
||||||
}, py::arg("w"));
|
}, py::arg("w"));
|
||||||
@ -1608,7 +1646,9 @@ DLL_HEADER void ExportNgOCCShapes(py::module &m)
|
|||||||
.def("Line", [](WorkPlane&wp,double h,double v, optional<string> name) { return wp.Line(h,v,name); },
|
.def("Line", [](WorkPlane&wp,double h,double v, optional<string> name) { return wp.Line(h,v,name); },
|
||||||
py::arg("dx"), py::arg("dy"), py::arg("name")=nullopt)
|
py::arg("dx"), py::arg("dy"), py::arg("name")=nullopt)
|
||||||
.def("Rectangle", &WorkPlane::Rectangle)
|
.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("Offset", &WorkPlane::Offset)
|
||||||
.def("Reverse", &WorkPlane::Reverse)
|
.def("Reverse", &WorkPlane::Reverse)
|
||||||
.def("Close", &WorkPlane::Close)
|
.def("Close", &WorkPlane::Close)
|
||||||
|
Loading…
Reference in New Issue
Block a user