0022100: EDF 2413 SMESH: Take into account TRIA7

decompose bi-quadratic elements using the central node of face
This commit is contained in:
eap 2013-05-16 16:41:30 +00:00
parent 3e2ff42c86
commit 7868270178
2 changed files with 98 additions and 32 deletions

View File

@ -94,23 +94,31 @@ DriverSTL_W_SMDS_Mesh::~DriverSTL_W_SMDS_Mesh()
void DriverSTL_W_SMDS_Mesh::findVolumeTriangles() void DriverSTL_W_SMDS_Mesh::findVolumeTriangles()
{ {
SMDS_VolumeTool myTool; SMDS_VolumeTool theVolume;
SMDS_VolumeIteratorPtr vIt = myMesh->volumesIterator(); SMDS_VolumeIteratorPtr vIt = myMesh->volumesIterator();
std::vector< const SMDS_MeshNode*> nodes;
while ( vIt->more() ) while ( vIt->more() )
{ {
myTool.Set( vIt->next() ); theVolume.Set( vIt->next(), /*ignoreCentralNodes=*/false );
for ( int iF = 0; iF < myTool.NbFaces(); ++iF ) for ( int iF = 0; iF < theVolume.NbFaces(); ++iF )
if ( myTool.IsFreeFace( iF )) if ( theVolume.IsFreeFace( iF ))
{ {
const SMDS_MeshNode** n = myTool.GetFaceNodes(iF); const SMDS_MeshNode** n = theVolume.GetFaceNodes(iF);
int nbN = myTool.NbFaceNodes(iF); int nbN = theVolume.NbFaceNodes(iF);
std::vector< const SMDS_MeshNode*> nodes( n, n+nbN ); nodes.assign( n, n+nbN );
if ( !myMesh->FindElement( nodes, SMDSAbs_Face, /*Nomedium=*/false)) if ( !myMesh->FindElement( nodes, SMDSAbs_Face, /*Nomedium=*/false))
{ {
int nbTria = nbN - 2; if ( nbN == 9 && !theVolume.IsPoly() ) // facet is SMDSEntity_BiQuad_Quadrangle
for ( int iT = 0; iT < nbTria; ++iT )
{ {
myVolumeTrias.push_back( new SMDS_FaceOfNodes( n[0], n[1+iT], n[2+iT] )); int nbTria = nbN - 1;
for ( int iT = 0; iT < nbTria; ++iT )
myVolumeTrias.push_back( new SMDS_FaceOfNodes( n[8], n[0+iT], n[1+iT] ));
}
else
{
int nbTria = nbN - 2;
for ( int iT = 0; iT < nbTria; ++iT )
myVolumeTrias.push_back( new SMDS_FaceOfNodes( n[0], n[1+iT], n[2+iT] ));
} }
} }
} }
@ -139,13 +147,12 @@ SMDS_ElemIteratorPtr DriverSTL_W_SMDS_Mesh::getFaces() const
// static methods // static methods
static void writeInteger( const Standard_Integer& theVal, static void writeInteger( const Standard_Integer& theVal, OSD_File& ofile )
OSD_File& ofile )
{ {
union { union {
Standard_Integer i; Standard_Integer i;
char c[4]; char c[4];
}u; } u;
u.i = theVal; u.i = theVal;
@ -195,6 +202,33 @@ static gp_XYZ getNormale( const SMDS_MeshNode* n1,
return n; return n;
} }
//================================================================================
/*!
* \brief Return nb triangles in a decomposed mesh face
* \retval int - number of triangles
*/
//================================================================================
static int getNbTriangles( const SMDS_MeshElement* face)
{
// WARNING: counting triangles must be coherent with getTriangles()
switch ( face->GetEntityType() )
{
case SMDSEntity_BiQuad_Triangle:
case SMDSEntity_BiQuad_Quadrangle:
return face->NbNodes() - 1;
// case SMDSEntity_Triangle:
// case SMDSEntity_Quad_Triangle:
// case SMDSEntity_Quadrangle:
// case SMDSEntity_Quad_Quadrangle:
// case SMDSEntity_Polygon:
// case SMDSEntity_Quad_Polygon:
default:
return face->NbNodes() - 2;
}
return 0;
}
//================================================================================ //================================================================================
/*! /*!
* \brief Decompose a mesh face into triangles * \brief Decompose a mesh face into triangles
@ -205,14 +239,45 @@ static gp_XYZ getNormale( const SMDS_MeshNode* n1,
static int getTriangles( const SMDS_MeshElement* face, static int getTriangles( const SMDS_MeshElement* face,
const SMDS_MeshNode** nodes) const SMDS_MeshNode** nodes)
{ {
// WARNING: implementation must be coherent with counting triangles in writeBinary() // WARNING: decomposing into triangles must be coherent with getNbTriangles()
int nbN = face->NbCornerNodes(); int nbTria, i = 0;
const int nbTria = nbN-2; SMDS_NodeIteratorPtr nIt = face->interlacedNodesIterator();
for ( int i = 0; nbN > 1; --nbN ) nodes[ i++ ] = nIt->next();
nodes[ i++ ] = nIt->next();
const SMDSAbs_EntityType type = face->GetEntityType();
switch ( type )
{ {
nodes[ i++ ] = face->GetNode( 0 ); case SMDSEntity_BiQuad_Triangle:
nodes[ i++ ] = face->GetNode( nbN-2 ); case SMDSEntity_BiQuad_Quadrangle:
nodes[ i++ ] = face->GetNode( nbN-1 ); nbTria = ( type == SMDSEntity_BiQuad_Triangle ) ? 6 : 8;
nodes[ i++ ] = face->GetNode( nbTria );
while ( i < 3*(nbTria-1) )
{
nodes[ i++ ] = nodes[ i-2 ];
nodes[ i++ ] = nIt->next();
nodes[ i++ ] = nodes[ 2 ];
}
nodes[ i++ ] = nodes[ i-2 ];
nodes[ i++ ] = nodes[ 0 ];
nodes[ i++ ] = nodes[ 2 ];
break;
default:
// case SMDSEntity_Triangle:
// case SMDSEntity_Quad_Triangle:
// case SMDSEntity_Quadrangle:
// case SMDSEntity_Quad_Quadrangle:
// case SMDSEntity_Polygon:
// case SMDSEntity_Quad_Polygon:
nbTria = face->NbNodes() - 2;
nodes[ i++ ] = nIt->next();
while ( i < 3*nbTria )
{
nodes[ i++ ] = nodes[ 0 ];
nodes[ i++ ] = nodes[ i-2 ];
nodes[ i++ ] = nIt->next();
}
break;
} }
return nbTria; return nbTria;
} }
@ -291,6 +356,13 @@ Driver_Mesh::Status DriverSTL_W_SMDS_Mesh::writeAscii() const
return aResult; return aResult;
} }
//================================================================================
/*!
* \brief Writes all triangles in binary format
* \return Driver_Mesh::Status - DRS_FAIL if no file name is provided
*/
//================================================================================
Driver_Mesh::Status DriverSTL_W_SMDS_Mesh::writeBinary() const Driver_Mesh::Status DriverSTL_W_SMDS_Mesh::writeBinary() const
{ {
Status aResult = DRS_OK; Status aResult = DRS_OK;
@ -304,23 +376,14 @@ Driver_Mesh::Status DriverSTL_W_SMDS_Mesh::writeBinary() const
aFile.Build(OSD_WriteOnly,OSD_Protection()); aFile.Build(OSD_WriteOnly,OSD_Protection());
// we first count the number of triangles // we first count the number of triangles
// WARNING: counting triangles must be coherent with getTriangles() int nbTri = myVolumeTrias.size();
int nbTri = 0;
const SMDS_MeshInfo& info = myMesh->GetMeshInfo();
nbTri += info.NbTriangles();
nbTri += info.NbQuadrangles() * 2;
nbTri += myVolumeTrias.size();
if ( info.NbPolygons() > 0 )
{ {
SMDS_FaceIteratorPtr itFaces = myMesh->facesIterator(); SMDS_FaceIteratorPtr itFaces = myMesh->facesIterator();
while ( itFaces->more() ) while ( itFaces->more() ) {
{
const SMDS_MeshElement* aFace = itFaces->next(); const SMDS_MeshElement* aFace = itFaces->next();
if ( aFace->IsPoly() ) nbTri += getNbTriangles( aFace );
nbTri += aFace->NbNodes() - 2;
} }
} }
// char sval[80]; -- avoid writing not initialized memory // char sval[80]; -- avoid writing not initialized memory
TCollection_AsciiString sval(LABEL_SIZE-1,' '); TCollection_AsciiString sval(LABEL_SIZE-1,' ');
aFile.Write((Standard_Address)sval.ToCString(),LABEL_SIZE); aFile.Write((Standard_Address)sval.ToCString(),LABEL_SIZE);

View File

@ -34,6 +34,9 @@
#include <vector> #include <vector>
/*!
* \brief Writer of a mesh in STL (STereoLithography) file format.
*/
class MESHDRIVERSTL_EXPORT DriverSTL_W_SMDS_Mesh: public Driver_SMDS_Mesh class MESHDRIVERSTL_EXPORT DriverSTL_W_SMDS_Mesh: public Driver_SMDS_Mesh
{ {
public: public: