mirror of
https://github.com/NGSolve/netgen.git
synced 2025-01-11 21:50:34 +05:00
Vertex and Edge ctors
This commit is contained in:
parent
ab3801314c
commit
ffc6d90094
@ -1081,18 +1081,27 @@ DLL_HEADER void ExportNgOCCShapes(py::module &m)
|
|||||||
})
|
})
|
||||||
;
|
;
|
||||||
|
|
||||||
py::class_<TopoDS_Vertex, TopoDS_Shape> (m, "TopoDS_Vertex")
|
py::class_<TopoDS_Vertex, TopoDS_Shape> (m, "Vertex")
|
||||||
.def(py::init([] (const TopoDS_Shape & shape) {
|
.def(py::init([] (const TopoDS_Shape & shape) {
|
||||||
return TopoDS::Vertex(shape);
|
return TopoDS::Vertex(shape);
|
||||||
}))
|
}))
|
||||||
|
.def(py::init([] (const gp_Pnt & p) {
|
||||||
|
return BRepBuilderAPI_MakeVertex (p).Vertex();
|
||||||
|
}))
|
||||||
.def_property_readonly("p", [] (const TopoDS_Vertex & v) -> gp_Pnt {
|
.def_property_readonly("p", [] (const TopoDS_Vertex & v) -> gp_Pnt {
|
||||||
return BRep_Tool::Pnt (v); })
|
return BRep_Tool::Pnt (v); })
|
||||||
;
|
;
|
||||||
|
|
||||||
py::class_<TopoDS_Edge, TopoDS_Shape> (m, "TopoDS_Edge")
|
py::class_<TopoDS_Edge, TopoDS_Shape> (m, "Edge")
|
||||||
.def(py::init([] (const TopoDS_Shape & shape) {
|
.def(py::init([] (const TopoDS_Shape & shape) {
|
||||||
return TopoDS::Edge(shape);
|
return TopoDS::Edge(shape);
|
||||||
}))
|
}))
|
||||||
|
.def(py::init([] (Handle(Geom2d_Curve) curve2d, TopoDS_Face face) {
|
||||||
|
auto edge = BRepBuilderAPI_MakeEdge(curve2d, BRep_Tool::Surface (face)).Edge();
|
||||||
|
BRepLib::BuildCurves3d(edge);
|
||||||
|
return edge;
|
||||||
|
}))
|
||||||
|
|
||||||
.def_property_readonly("start",
|
.def_property_readonly("start",
|
||||||
[](const TopoDS_Edge & e) {
|
[](const TopoDS_Edge & e) {
|
||||||
double s0, s1;
|
double s0, s1;
|
||||||
@ -1489,9 +1498,29 @@ DLL_HEADER void ExportNgOCCShapes(py::module &m)
|
|||||||
builder.AddArgument(e.Current());
|
builder.AddArgument(e.Current());
|
||||||
has_solid = true;
|
has_solid = true;
|
||||||
}
|
}
|
||||||
if (!has_solid)
|
if (has_solid) continue;
|
||||||
for (TopExp_Explorer e(s, TopAbs_FACE); e.More(); e.Next())
|
|
||||||
|
bool has_face = false;
|
||||||
|
for (TopExp_Explorer e(s, TopAbs_FACE); e.More(); e.Next())
|
||||||
|
{
|
||||||
builder.AddArgument(e.Current());
|
builder.AddArgument(e.Current());
|
||||||
|
has_face = true;
|
||||||
|
}
|
||||||
|
if (has_face) continue;
|
||||||
|
|
||||||
|
bool has_edge = false;
|
||||||
|
for (TopExp_Explorer e(s, TopAbs_EDGE); e.More(); e.Next())
|
||||||
|
{
|
||||||
|
builder.AddArgument(e.Current());
|
||||||
|
has_edge = true;
|
||||||
|
}
|
||||||
|
if (has_edge) continue;
|
||||||
|
|
||||||
|
|
||||||
|
for (TopExp_Explorer e(s, TopAbs_VERTEX); e.More(); e.Next())
|
||||||
|
{
|
||||||
|
builder.AddArgument(e.Current());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
builder.Perform();
|
builder.Perform();
|
||||||
@ -1612,13 +1641,14 @@ DLL_HEADER void ExportNgOCCShapes(py::module &m)
|
|||||||
throw NgException("cannot create Bezier-spline: "+errstr.str());
|
throw NgException("cannot create Bezier-spline: "+errstr.str());
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
/*
|
||||||
m.def("Edge", [](Handle(Geom2d_Curve) curve2d, TopoDS_Face face) {
|
m.def("Edge", [](Handle(Geom2d_Curve) curve2d, TopoDS_Face face) {
|
||||||
auto edge = BRepBuilderAPI_MakeEdge(curve2d, BRep_Tool::Surface (face)).Edge();
|
auto edge = BRepBuilderAPI_MakeEdge(curve2d, BRep_Tool::Surface (face)).Edge();
|
||||||
BRepLib::BuildCurves3d(edge);
|
BRepLib::BuildCurves3d(edge);
|
||||||
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;
|
||||||
|
Loading…
Reference in New Issue
Block a user