PAL13639 (EDF PAL 317 : SMESH : Create "0D Hypothesis")

enable submeshes on vertices
This commit is contained in:
eap 2007-02-19 16:32:46 +00:00
parent 2aab1df9bb
commit 331304764c

View File

@ -210,12 +210,18 @@ CORBA::Long SMESH_subMesh_i::GetNumberOfNodes(CORBA::Boolean all)
for ( ; sm != smList.end(); ++sm ) for ( ; sm != smList.end(); ++sm )
{ {
SMDS_ElemIteratorPtr eIt = (*sm)->GetElements(); SMDS_ElemIteratorPtr eIt = (*sm)->GetElements();
while ( eIt->more() ) { if ( eIt->more() ) {
const SMDS_MeshElement* anElem = eIt->next(); while ( eIt->more() ) {
SMDS_ElemIteratorPtr nIt = anElem->nodesIterator(); const SMDS_MeshElement* anElem = eIt->next();
SMDS_ElemIteratorPtr nIt = anElem->nodesIterator();
while ( nIt->more() )
nodeIds.insert( nIt->next()->GetID() );
}
} else {
SMDS_NodeIteratorPtr nIt = (*sm)->GetNodes();
while ( nIt->more() ) while ( nIt->more() )
nodeIds.insert( nIt->next()->GetID() ); nodeIds.insert( nIt->next()->GetID() );
} }
} }
return nodeIds.size(); return nodeIds.size();
} }
@ -225,15 +231,21 @@ CORBA::Long SMESH_subMesh_i::GetNumberOfNodes(CORBA::Boolean all)
if ( all ) { // all nodes of submesh elements if ( all ) { // all nodes of submesh elements
SMDS_ElemIteratorPtr eIt = aSubMeshDS->GetElements(); SMDS_ElemIteratorPtr eIt = aSubMeshDS->GetElements();
while ( eIt->more() ) { if ( eIt->more() ) {
const SMDS_MeshElement* anElem = eIt->next(); while ( eIt->more() ) {
SMDS_ElemIteratorPtr nIt = anElem->nodesIterator(); const SMDS_MeshElement* anElem = eIt->next();
SMDS_ElemIteratorPtr nIt = anElem->nodesIterator();
while ( nIt->more() )
nodeIds.insert( nIt->next()->GetID() );
}
} else {
SMDS_NodeIteratorPtr nIt = aSubMeshDS->GetNodes();
while ( nIt->more() ) while ( nIt->more() )
nodeIds.insert( nIt->next()->GetID() ); nodeIds.insert( nIt->next()->GetID() );
} }
return nodeIds.size(); return nodeIds.size();
} }
return aSubMeshDS->NbNodes(); return aSubMeshDS->NbNodes();
} }
@ -242,7 +254,7 @@ CORBA::Long SMESH_subMesh_i::GetNumberOfNodes(CORBA::Boolean all)
* *
*/ */
//============================================================================= //=============================================================================
SMESH::long_array* SMESH_subMesh_i::GetElementsId() SMESH::long_array* SMESH_subMesh_i::GetElementsId()
throw (SALOME::SALOME_Exception) throw (SALOME::SALOME_Exception)
{ {
@ -317,9 +329,15 @@ SMESH::long_array* SMESH_subMesh_i::GetElementsByType( SMESH::ElementType theEle
if ( theElemType == SMESH::NODE ) if ( theElemType == SMESH::NODE )
{ {
SMDS_ElemIteratorPtr eIt = (*sm)->GetElements(); SMDS_ElemIteratorPtr eIt = (*sm)->GetElements();
while ( eIt->more() ) { if ( eIt->more() ) {
const SMDS_MeshElement* anElem = eIt->next(); while ( eIt->more() ) {
SMDS_ElemIteratorPtr nIt = anElem->nodesIterator(); const SMDS_MeshElement* anElem = eIt->next();
SMDS_ElemIteratorPtr nIt = anElem->nodesIterator();
while ( nIt->more() )
nodeIds.insert( nIt->next()->GetID() );
}
} else {
SMDS_NodeIteratorPtr nIt = (*sm)->GetNodes();
while ( nIt->more() ) while ( nIt->more() )
nodeIds.insert( nIt->next()->GetID() ); nodeIds.insert( nIt->next()->GetID() );
} }
@ -340,9 +358,15 @@ SMESH::long_array* SMESH_subMesh_i::GetElementsByType( SMESH::ElementType theEle
if ( theElemType == SMESH::NODE && aSubMeshDS ) if ( theElemType == SMESH::NODE && aSubMeshDS )
{ {
SMDS_ElemIteratorPtr eIt = aSubMeshDS->GetElements(); SMDS_ElemIteratorPtr eIt = aSubMeshDS->GetElements();
while ( eIt->more() ) { if ( eIt->more() ) {
const SMDS_MeshElement* anElem = eIt->next(); while ( eIt->more() ) {
SMDS_ElemIteratorPtr nIt = anElem->nodesIterator(); const SMDS_MeshElement* anElem = eIt->next();
SMDS_ElemIteratorPtr nIt = anElem->nodesIterator();
while ( nIt->more() )
nodeIds.insert( nIt->next()->GetID() );
}
} else {
SMDS_NodeIteratorPtr nIt = aSubMeshDS->GetNodes();
while ( nIt->more() ) while ( nIt->more() )
nodeIds.insert( nIt->next()->GetID() ); nodeIds.insert( nIt->next()->GetID() );
} }