mirror of
https://git.salome-platform.org/gitpub/modules/smesh.git
synced 2025-01-19 10:00:33 +05:00
0021985: [CEA 715] "Clear mesh data" on a skin mesh without geometry does not preserve the skin mesh
New behavior: - mesh is built on geometry -> "Clear mesh data" removes all nodes/elements - mesh w/o geometry (imported, compound, made from scratch) -> "Clear mesh data" removes only nodes/elements computed by algorithms
This commit is contained in:
parent
93f0557a04
commit
8ae4d1e9ae
@ -347,6 +347,8 @@ void SMESH_Mesh::Load()
|
||||
|
||||
void SMESH_Mesh::Clear()
|
||||
{
|
||||
if ( HasShapeToMesh() ) // remove all nodes and elements
|
||||
{
|
||||
// clear mesh data
|
||||
_myMeshDS->ClearMesh();
|
||||
|
||||
@ -358,6 +360,20 @@ void SMESH_Mesh::Clear()
|
||||
sm->ComputeStateEngine( SMESH_subMesh::CLEAN ); // for event listeners (issue 0020918)
|
||||
sm->ComputeSubMeshStateEngine( SMESH_subMesh::CLEAN );
|
||||
}
|
||||
}
|
||||
else // remove only nodes/elements computed by algorithms
|
||||
{
|
||||
if ( SMESH_subMesh *sm = GetSubMeshContaining( GetShapeToMesh() ) )
|
||||
{
|
||||
SMESH_subMeshIteratorPtr smIt = sm->getDependsOnIterator(/*includeSelf=*/true,
|
||||
/*complexShapeFirst=*/true);
|
||||
while ( smIt->more() )
|
||||
{
|
||||
sm = smIt->next();
|
||||
sm->ComputeStateEngine( SMESH_subMesh::CLEAN );
|
||||
}
|
||||
}
|
||||
}
|
||||
_isModified = false;
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user