Salome HOME
projects
/
modules
/
smesh.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Porting to the new version of the OCCT
[modules/smesh.git]
/
src
/
SMDS
/
SMDS_VolumeTool.hxx
diff --git
a/src/SMDS/SMDS_VolumeTool.hxx
b/src/SMDS/SMDS_VolumeTool.hxx
index 1ab139d7b733d79a0b4112e458df4f8b7e25ddfd..69e20860a8996e69681ac49295e1f7dec751d99d 100644
(file)
--- a/
src/SMDS/SMDS_VolumeTool.hxx
+++ b/
src/SMDS/SMDS_VolumeTool.hxx
@@
-1,4
+1,4
@@
-// Copyright (C) 2007-201
3
CEA/DEN, EDF R&D, OPEN CASCADE
+// Copyright (C) 2007-201
4
CEA/DEN, EDF R&D, OPEN CASCADE
//
// Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
// CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
//
// Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
// CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
@@
-6,7
+6,7
@@
// This library is free software; you can redistribute it and/or
// modify it under the terms of the GNU Lesser General Public
// License as published by the Free Software Foundation; either
// This library is free software; you can redistribute it and/or
// modify it under the terms of the GNU Lesser General Public
// License as published by the Free Software Foundation; either
-// version 2.1 of the License.
+// version 2.1 of the License
, or (at your option) any later version
.
//
// This library is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
//
// This library is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
@@
-73,6
+73,8
@@
class SMDS_EXPORT SMDS_VolumeTool
int ID() const;
// return element ID
int ID() const;
// return element ID
+ bool IsPoly() const { return myPolyedre; }
+
// -----------------------
// general info
// -----------------------
// -----------------------
// general info
// -----------------------
@@
-177,7
+179,11
@@
class SMDS_EXPORT SMDS_VolumeTool
// SetExternalNormal() is taken into account.
bool IsFreeFace( int faceIndex, const SMDS_MeshElement** otherVol=0 ) const;
// SetExternalNormal() is taken into account.
bool IsFreeFace( int faceIndex, const SMDS_MeshElement** otherVol=0 ) const;
- // Check that all volumes built on the face nodes lays on one side
+ // Fast check that only one volume is built on nodes of a given face
+ // otherVol returns another volume sharing the given facet
+
+ bool IsFreeFaceAdv( int faceIndex, const SMDS_MeshElement** otherVol=0 ) const;
+ // Thorough check that all volumes built on the face nodes lays on one side
// otherVol returns another volume sharing the given facet
bool GetFaceNormal (int faceIndex, double & X, double & Y, double & Z) const;
// otherVol returns another volume sharing the given facet
bool GetFaceNormal (int faceIndex, double & X, double & Y, double & Z) const;
@@
-195,7
+201,8
@@
class SMDS_EXPORT SMDS_VolumeTool
int GetCenterNodeIndex( int faceIndex ) const;
// Return index of the node located at face center of a quadratic element like HEX27
int GetCenterNodeIndex( int faceIndex ) const;
// Return index of the node located at face center of a quadratic element like HEX27
- int GetFaceIndex( const std::set<const SMDS_MeshNode*>& theFaceNodes ) const;
+ int GetFaceIndex( const std::set<const SMDS_MeshNode*>& theFaceNodes,
+ const int theFaceIndexHint=-1) const;
// Return index of a face formed by theFaceNodes.
// Return -1 if a face not found
// Return index of a face formed by theFaceNodes.
// Return -1 if a face not found
@@
-232,6
+239,9
@@
class SMDS_EXPORT SMDS_VolumeTool
static int NbCornerNodes(VolumeType type);
// Useful to know nb of corner nodes of a quadratic volume
static int NbCornerNodes(VolumeType type);
// Useful to know nb of corner nodes of a quadratic volume
+ static int GetOppFaceIndexOfHex( int faceIndex );
+ // Return index of the opposite face of the hexahedron
+
private:
bool setFace( int faceIndex ) const;
private:
bool setFace( int faceIndex ) const;