]> SALOME platform Git repositories - plugins/ghs3dplugin.git/commitdiff
Salome HOME
020461: EDF 1102 GHS3DPLUGIN: Bad detection of volumes with Ghs3d mesh
authoreap <eap@opencascade.com>
Fri, 2 Oct 2009 16:18:40 +0000 (16:18 +0000)
committereap <eap@opencascade.com>
Fri, 2 Oct 2009 16:18:40 +0000 (16:18 +0000)
  in findShape(), fix getting GC of tetra

src/GHS3DPlugin_GHS3D.cxx

index a7bc2873d9eb25b255b0207e18808394854407cf..0d14603a40c88ba9a67aca63b76cc352ce292781 100644 (file)
@@ -180,7 +180,7 @@ static TopoDS_Shape findShape(const SMDS_MeshNode *aNode[],
       aPnt = p;
       break;
     }
-    aPnt += p;
+    aPnt += p / nbNode;
   }
 
   BRepClass3d_SolidClassifier SC (aShape, aPnt, Precision::Confusion());
@@ -610,8 +610,8 @@ static int findShapeID(SMESH_Mesh&          mesh,
       nNotOnSeamEdge = node3;
     else
       nNotOnSeamEdge = node2;
-  bool checkUV = true;
-  gp_XY uv = helper.GetNodeUV( geomFace, node1, nNotOnSeamEdge, &checkUV );
+  bool uvOK;
+  gp_XY uv = helper.GetNodeUV( geomFace, node1, nNotOnSeamEdge, &uvOK );
   // check that uv is correct
   double tol = 1e-6;
   TopoDS_Shape nodeShape = helper.GetSubShapeByNode( node1, meshDS );
@@ -624,7 +624,7 @@ static int findShapeID(SMESH_Mesh&          mesh,
     default:;
     }
   BRepAdaptor_Surface surface( geomFace );
-  if ( checkUV && node1Pnt.Distance( surface.Value( uv.X(), uv.Y() )) > 2 * tol )
+  if ( !uvOK || node1Pnt.Distance( surface.Value( uv.X(), uv.Y() )) > 2 * tol )
       return invalidID;
 
   // normale to geomFace at UV