mirror of
https://github.com/NGSolve/netgen.git
synced 2025-01-23 11:20:34 +05:00
prepare for periodic occ-geometries
This commit is contained in:
parent
9d2a436749
commit
eba02368a6
@ -44,6 +44,7 @@ namespace netgen
|
|||||||
// std::map<Handle(TopoDS_TShape), string> OCCGeometry::global_shape_names;
|
// std::map<Handle(TopoDS_TShape), string> OCCGeometry::global_shape_names;
|
||||||
// std::map<Handle(TopoDS_TShape), Vec<3>> OCCGeometry::global_shape_cols;
|
// std::map<Handle(TopoDS_TShape), Vec<3>> OCCGeometry::global_shape_cols;
|
||||||
std::map<Handle(TopoDS_TShape), ShapeProperties> OCCGeometry::global_shape_properties;
|
std::map<Handle(TopoDS_TShape), ShapeProperties> OCCGeometry::global_shape_properties;
|
||||||
|
std::map<Handle(TopoDS_TShape), std::vector<OCCIdentification>> OCCGeometry::identifications;
|
||||||
|
|
||||||
OCCGeometry::OCCGeometry(const TopoDS_Shape& _shape)
|
OCCGeometry::OCCGeometry(const TopoDS_Shape& _shape)
|
||||||
{
|
{
|
||||||
|
@ -221,6 +221,15 @@ namespace netgen
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
class OCCIdentification
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
TopoDS_Shape other;
|
||||||
|
Transformation<3> trafo;
|
||||||
|
bool inverse;
|
||||||
|
string name;
|
||||||
|
};
|
||||||
|
|
||||||
class DLL_HEADER OCCGeometry : public NetgenGeometry
|
class DLL_HEADER OCCGeometry : public NetgenGeometry
|
||||||
{
|
{
|
||||||
Point<3> center;
|
Point<3> center;
|
||||||
@ -228,7 +237,7 @@ namespace netgen
|
|||||||
|
|
||||||
public:
|
public:
|
||||||
static std::map<Handle(TopoDS_TShape), ShapeProperties> global_shape_properties;
|
static std::map<Handle(TopoDS_TShape), ShapeProperties> global_shape_properties;
|
||||||
|
static std::map<Handle(TopoDS_TShape), std::vector<OCCIdentification>> identifications;
|
||||||
// static std::map<Handle(TopoDS_TShape), string> global_shape_names;
|
// static std::map<Handle(TopoDS_TShape), string> global_shape_names;
|
||||||
// static std::map<Handle(TopoDS_TShape), Vec<3>> global_shape_cols;
|
// static std::map<Handle(TopoDS_TShape), Vec<3>> global_shape_cols;
|
||||||
|
|
||||||
|
@ -751,6 +751,31 @@ DLL_HEADER void ExportNgOCCShapes(py::module &m)
|
|||||||
BRepMesh_IncrementalMesh (shape, deflection, true);
|
BRepMesh_IncrementalMesh (shape, deflection, true);
|
||||||
})
|
})
|
||||||
|
|
||||||
|
.def("Identify", [](const TopoDS_Shape & me, const TopoDS_Shape & you, string name) {
|
||||||
|
// only edges supported, by now
|
||||||
|
auto me_edge = TopoDS::Edge(me);
|
||||||
|
auto you_edge = TopoDS::Edge(you);
|
||||||
|
|
||||||
|
GProp_GProps props;
|
||||||
|
BRepGProp::LinearProperties(me, props);
|
||||||
|
gp_Pnt cme = props.CentreOfMass();
|
||||||
|
BRepGProp::LinearProperties(you, props);
|
||||||
|
gp_Pnt cyou = props.CentreOfMass();
|
||||||
|
|
||||||
|
double s0, s1;
|
||||||
|
auto curve_me = BRep_Tool::Curve(me_edge, s0, s1);
|
||||||
|
auto vme = occ2ng(curve_me->Value(s1))-occ2ng(curve_me->Value(s0));
|
||||||
|
auto curve_you = BRep_Tool::Curve(you_edge, s0, s1);
|
||||||
|
auto vyou = occ2ng(curve_you->Value(s1))-occ2ng(curve_you->Value(s0));
|
||||||
|
|
||||||
|
bool inv = vme*vyou < 0;
|
||||||
|
OCCGeometry::identifications[me.TShape()].push_back
|
||||||
|
(OCCIdentification { you, Transformation<3>(occ2ng(cyou) - occ2ng(cme)), inv, name });
|
||||||
|
OCCGeometry::identifications[you.TShape()].push_back
|
||||||
|
(OCCIdentification { me, Transformation<3>(occ2ng(cme) - occ2ng(cyou)), inv, name });
|
||||||
|
})
|
||||||
|
|
||||||
|
|
||||||
.def("Triangulation", [](const TopoDS_Shape & shape)
|
.def("Triangulation", [](const TopoDS_Shape & shape)
|
||||||
{
|
{
|
||||||
// extracted from vsocc.cpp
|
// extracted from vsocc.cpp
|
||||||
@ -1146,10 +1171,15 @@ DLL_HEADER void ExportNgOCCShapes(py::module &m)
|
|||||||
BOPAlgo_Builder builder;
|
BOPAlgo_Builder builder;
|
||||||
for (auto & s : shapes)
|
for (auto & s : shapes)
|
||||||
{
|
{
|
||||||
|
bool has_solid = false;
|
||||||
for (TopExp_Explorer e(s, TopAbs_SOLID); e.More(); e.Next())
|
for (TopExp_Explorer e(s, TopAbs_SOLID); e.More(); e.Next())
|
||||||
|
{
|
||||||
|
builder.AddArgument(e.Current());
|
||||||
|
has_solid = true;
|
||||||
|
}
|
||||||
|
if (!has_solid)
|
||||||
|
for (TopExp_Explorer e(s, TopAbs_FACE); e.More(); e.Next())
|
||||||
builder.AddArgument(e.Current());
|
builder.AddArgument(e.Current());
|
||||||
if (s.ShapeType() == TopAbs_FACE)
|
|
||||||
builder.AddArgument(s);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
builder.Perform();
|
builder.Perform();
|
||||||
@ -1363,7 +1393,7 @@ DLL_HEADER void ExportNgOCCShapes(py::module &m)
|
|||||||
|
|
||||||
|
|
||||||
py::class_<WorkPlane, shared_ptr<WorkPlane>> (m, "WorkPlane")
|
py::class_<WorkPlane, shared_ptr<WorkPlane>> (m, "WorkPlane")
|
||||||
.def(py::init<gp_Ax3, gp_Ax2d>(), py::arg("axis"), py::arg("pos")=gp_Ax2d())
|
.def(py::init<gp_Ax3, gp_Ax2d>(), py::arg("axis")=gp_Ax3(), py::arg("pos")=gp_Ax2d())
|
||||||
.def("MoveTo", &WorkPlane::MoveTo)
|
.def("MoveTo", &WorkPlane::MoveTo)
|
||||||
.def("Direction", &WorkPlane::Direction)
|
.def("Direction", &WorkPlane::Direction)
|
||||||
.def("LineTo", &WorkPlane::LineTo)
|
.def("LineTo", &WorkPlane::LineTo)
|
||||||
|
Loading…
Reference in New Issue
Block a user