OCC - version compatibility fixes

This commit is contained in:
Joachim Schoeberl 2021-08-31 13:16:30 +02:00
parent 69f6a9cc90
commit 36a7b24315
2 changed files with 13 additions and 4 deletions

View File

@ -223,15 +223,15 @@ DLL_HEADER void ExportNgOCC(py::module &m)
normals.reserve(normals.size() + triangulation->NbTriangles()*3*3); normals.reserve(normals.size() + triangulation->NbTriangles()*3*3);
for (int j = 1; j < triangulation->NbTriangles()+1; j++) for (int j = 1; j < triangulation->NbTriangles()+1; j++)
{ {
auto triangle = (triangulation->Triangles())(j); auto triangle = triangulation->Triangle(j);
for (int k = 1; k < 4; k++) for (int k = 1; k < 4; k++)
p[k-1] = (triangulation->Nodes())(triangle(k)).Transformed(loc); p[k-1] = triangulation->Node(triangle(k)).Transformed(loc);
for (int k = 1; k < 4; k++) for (int k = 1; k < 4; k++)
{ {
vertices.insert(vertices.end(),{float(p[k-1].X()), float(p[k-1].Y()), float(p[k-1].Z())}); vertices.insert(vertices.end(),{float(p[k-1].X()), float(p[k-1].Y()), float(p[k-1].Z())});
trigs.insert(trigs.end(),{count, count+1, count+2,i}); trigs.insert(trigs.end(),{count, count+1, count+2,i});
count += 3; count += 3;
uv = (triangulation->UVNodes())(triangle(k)); uv = triangulation->UVNode(triangle(k));
prop.SetParameters(uv.X(), uv.Y()); prop.SetParameters(uv.X(), uv.Y());
if (prop.IsNormalDefined()) if (prop.IsNormalDefined())
n = prop.Normal(); n = prop.Normal();

View File

@ -463,11 +463,14 @@ namespace netgen
glBegin (GL_LINE_STRIP); glBegin (GL_LINE_STRIP);
for (int j = 1; j <= nbnodes; j++) for (int j = 1; j <= nbnodes; j++)
{ {
/*
#if OCC_VERSION_MAJOR>=7 && OCC_VERSION_MINOR>=5 #if OCC_VERSION_MAJOR>=7 && OCC_VERSION_MINOR>=5
gp_Pnt p = T -> Node(aEdgePoly->Node(j)).Transformed(aEdgeLoc); gp_Pnt p = T -> Node(aEdgePoly->Nodes()(j)).Transformed(aEdgeLoc);
#else #else
gp_Pnt p = T -> Nodes()(aEdgePoly->Nodes()(j)).Transformed(aEdgeLoc); gp_Pnt p = T -> Nodes()(aEdgePoly->Nodes()(j)).Transformed(aEdgeLoc);
#endif #endif
*/
gp_Pnt p = T -> Node(aEdgePoly->Nodes()(j)).Transformed(aEdgeLoc);
glVertex3f (p.X(), p.Y(), p.Z()); glVertex3f (p.X(), p.Y(), p.Z());
} }
glEnd (); glEnd ();
@ -514,11 +517,14 @@ namespace netgen
glBegin (GL_LINE_STRIP); glBegin (GL_LINE_STRIP);
for (int j = 1; j <= nbnodes; j++) for (int j = 1; j <= nbnodes; j++)
{ {
/*
#if OCC_VERSION_MAJOR>=7 && OCC_VERSION_MINOR>=5 #if OCC_VERSION_MAJOR>=7 && OCC_VERSION_MINOR>=5
gp_Pnt p = T -> Node(aEdgePoly->Node(j)).Transformed(aEdgeLoc); gp_Pnt p = T -> Node(aEdgePoly->Node(j)).Transformed(aEdgeLoc);
#else #else
gp_Pnt p = (T -> Nodes())(aEdgePoly->Nodes()(j)).Transformed(aEdgeLoc); gp_Pnt p = (T -> Nodes())(aEdgePoly->Nodes()(j)).Transformed(aEdgeLoc);
#endif #endif
*/
gp_Pnt p = T -> Node(aEdgePoly->Nodes()(j)).Transformed(aEdgeLoc);
glVertex3f (p.X(), p.Y(), p.Z()); glVertex3f (p.X(), p.Y(), p.Z());
} }
glEnd (); glEnd ();
@ -593,11 +599,14 @@ namespace netgen
int ntriangles = triangulation -> NbTriangles(); int ntriangles = triangulation -> NbTriangles();
for (int j = 1; j <= ntriangles; j++) for (int j = 1; j <= ntriangles; j++)
{ {
/*
#if OCC_VERSION_MAJOR>=7 && OCC_VERSION_MINOR>=5 #if OCC_VERSION_MAJOR>=7 && OCC_VERSION_MINOR>=5
Poly_Triangle triangle = triangulation -> Triangle(j); Poly_Triangle triangle = triangulation -> Triangle(j);
#else #else
Poly_Triangle triangle = triangulation -> Triangles()(j); Poly_Triangle triangle = triangulation -> Triangles()(j);
#endif #endif
*/
Poly_Triangle triangle = triangulation -> Triangle(j);
gp_Pnt p[3]; gp_Pnt p[3];
for (int k = 1; k <= 3; k++) for (int k = 1; k <= 3; k++)