#16522 [CEA 7599] Viscous layers hypothesis: extract layers as a group

1) Fix invalid python dump (missing Compute() before GetGroups())
2) Remove a group if group name changes
3) Remove an actor of a removed group
This commit is contained in:
eap 2020-02-07 16:57:31 +03:00
parent 70eb9c09d0
commit 66ec81f68d
8 changed files with 151 additions and 7 deletions

View File

@ -4930,7 +4930,14 @@ bool SMESHGUI::activateModule( SUIT_Study* study )
QList<SUIT_ViewWindow*> wndList = aDesk->windows(); QList<SUIT_ViewWindow*> wndList = aDesk->windows();
SUIT_ViewWindow* wnd; SUIT_ViewWindow* wnd;
foreach ( wnd, wndList ) foreach ( wnd, wndList )
{
connectView( wnd ); connectView( wnd );
// remove actors whose objects are removed in GetSMESHGen()->UpdateStudy()
SMESH::UpdateActorsAfterUpdateStudy(wnd);
wnd->update();
}
} }
Py_XDECREF(pluginsmanager); Py_XDECREF(pluginsmanager);

View File

@ -340,6 +340,8 @@ void SMESHGUI_GenericHypothesisCreator::onDialogFinished( int result )
myDlg->close(); myDlg->close();
//delete myDlg; since WA_DeleteOnClose==true //delete myDlg; since WA_DeleteOnClose==true
myDlg = 0; myDlg = 0;
SMESH::UpdateActorsAfterUpdateStudy();// remove actors of removed groups (#16522)
if (SVTK_ViewWindow* vf = SMESH::GetCurrentVtkView()) { if (SVTK_ViewWindow* vf = SMESH::GetCurrentVtkView()) {
vf->Repaint(); vf->Repaint();
} }

View File

@ -232,6 +232,86 @@ namespace SMESH
} }
} }
//================================================================================
/*!
* \brief Remove/update actors while module activation
* \param [in] wnd - window
*
* At module activation, groups and sub-meshes can be removed on engine side due
* to modification of meshed geometry, while their actors can remain.
* Here we remove/update SMESH_Actor's of changed objects. State (emptiness) of objects
* is defined by their icons in the Object Browser
*/
//================================================================================
void UpdateActorsAfterUpdateStudy( SUIT_ViewWindow* theWindow )
{
const char* emptyIcon = "ICON_SMESH_TREE_MESH_WARN";
_PTR(Study) aStudy = SMESH::getStudy();
if ( SVTK_ViewWindow* aViewWindow = GetVtkViewWindow( theWindow ))
{
vtkRenderer *aRenderer = aViewWindow->getRenderer();
VTK::ActorCollectionCopy aCopy(aRenderer->GetActors());
vtkActorCollection *aCollection = aCopy.GetActors();
aCollection->InitTraversal();
while ( vtkActor *actor = aCollection->GetNextActor() ) {
if ( SMESH_Actor *smeshActor = dynamic_cast<SMESH_Actor*>( actor ))
{
if ( !smeshActor->hasIO() )
continue;
Handle(SALOME_InteractiveObject) io = smeshActor->getIO();
if ( !io->hasEntry() )
continue;
_PTR(SObject) so = aStudy->FindObjectID( io->getEntry() );
if ( !so )
continue; // seems impossible
CORBA::Object_var obj = SMESH::SObjectToObject( so );
if ( CORBA::is_nil( obj )) // removed object
{
RemoveActor( theWindow, smeshActor );
continue;
}
bool toShow = smeshActor->GetVisibility();
_PTR(GenericAttribute) attr;
if ( toShow && so->FindAttribute( attr, "AttributePixMap" )) // check emptiness
{
_PTR(AttributePixMap) pixMap = attr;
toShow = ( pixMap->GetPixMap() != emptyIcon );
}
smeshActor->Update();
UpdateView( theWindow, toShow ? eDisplay : eErase, io->getEntry() );
}
}
}
return;
}
//================================================================================
/*!
* \brief Remove/update actors while module activation
*
* At module activation, groups and sub-meshes can be removed on engine side due
* to modification of meshed geometry, while their actors can remain.
* Here we remove/update SMESH_Actor's of changed objects. State (emptiness) of objects
* is defined by their icons in the Object Browser
*/
//================================================================================
void UpdateActorsAfterUpdateStudy()
{
SUIT_Study* study = SMESH::GetActiveStudy();
if ( SUIT_Desktop* desk = study->application()->desktop() )
{
QList<SUIT_ViewWindow*> wndList = desk->windows();
SUIT_ViewWindow* wnd;
foreach ( wnd, wndList )
SMESH::UpdateActorsAfterUpdateStudy(wnd);
}
}
//================================================================================ //================================================================================
/*! /*!
* \brief Notify the user on problems during visualization * \brief Notify the user on problems during visualization

View File

@ -216,6 +216,12 @@ SMESHGUI_EXPORT
double& theDist ); double& theDist );
SMESHGUI_EXPORT SMESHGUI_EXPORT
void RemoveVisualObjectWithActors( const char* theEntry, bool fromAllViews = false ); void RemoveVisualObjectWithActors( const char* theEntry, bool fromAllViews = false );
SMESHGUI_EXPORT
void UpdateActorsAfterUpdateStudy( SUIT_ViewWindow* wnd );
SMESHGUI_EXPORT
void UpdateActorsAfterUpdateStudy();
}; };
#endif // SMESHGUI_VTKUTILS_H #endif // SMESHGUI_VTKUTILS_H

View File

@ -1827,7 +1827,7 @@ _pyMesh::_pyMesh(const Handle(_pyCommand) theCreationCmd, const _pyID& meshId):
void _pyMesh::Process( const Handle(_pyCommand)& theCommand ) void _pyMesh::Process( const Handle(_pyCommand)& theCommand )
{ {
// some methods of SMESH_Mesh interface needs special conversion // some methods of SMESH_Mesh interface need special conversion
// to methods of Mesh python class // to methods of Mesh python class
// //
// 1. GetSubMesh(geom, name) + AddHypothesis(geom, algo) // 1. GetSubMesh(geom, name) + AddHypothesis(geom, algo)
@ -1980,7 +1980,7 @@ void _pyMesh::Process( const Handle(_pyCommand)& theCommand )
// if GetGroups() is just after Compute(), this can mean that the groups // if GetGroups() is just after Compute(), this can mean that the groups
// were created by some algorithm and hence Compute() should not be discarded // were created by some algorithm and hence Compute() should not be discarded
std::list< Handle(_pyCommand) >& cmdList = theGen->GetCommands(); std::list< Handle(_pyCommand) >& cmdList = theGen->GetCommands();
std::list< Handle(_pyCommand) >::iterator cmd = cmdList.begin(); std::list< Handle(_pyCommand) >::reverse_iterator cmd = cmdList.rbegin();
while ( (*cmd)->GetMethod() == "GetGroups" ) while ( (*cmd)->GetMethod() == "GetGroups" )
++cmd; ++cmd;
if ( myLastComputeCmd == (*cmd)) if ( myLastComputeCmd == (*cmd))
@ -3158,8 +3158,7 @@ void _pyHypothesis::ComputeDiscarded( const Handle(_pyCommand)& theComputeCmd )
continue; continue;
// check if a cmd is a sole command setting its parameter; // check if a cmd is a sole command setting its parameter;
// don't use method name for search as it can change // don't use method name for search as it can change
map<TCollection_AsciiString, list<Handle(_pyCommand)> >::iterator map<_AString, list<Handle(_pyCommand)> >::iterator m2cmds = myMeth2Commands.begin();
m2cmds = myMeth2Commands.begin();
for ( ; m2cmds != myMeth2Commands.end(); ++m2cmds ) for ( ; m2cmds != myMeth2Commands.end(); ++m2cmds )
{ {
list< Handle(_pyCommand)>& cmds = m2cmds->second; list< Handle(_pyCommand)>& cmds = m2cmds->second;

View File

@ -378,6 +378,47 @@ namespace {
} }
} }
//================================================================================
/*!
* \brief Remove a group, whose name is stored by hypothesis, upon group name modification
* \param [in] oldName - old group name
* \param [in] newName - new group name
* \param [in] type - group type
*/
//================================================================================
void StdMeshersGUI_StdHypothesisCreator::
removeOldGroup(const char* oldName, const char* newName, SMESH::ElementType type) const
{
if ( !oldName || !oldName[0] )
return; // old name undefined
if ( newName && strcmp( oldName, newName ) == 0 )
return; // same name
SMESH::SMESH_Hypothesis_var h = hypothesis();
SMESH::SObjectList listSOmesh = SMESH::GetMeshesUsingAlgoOrHypothesis( h );
for ( size_t i = 0; i < listSOmesh.size(); i++ )
{
_PTR(SObject) submSO = listSOmesh[i];
SMESH::SMESH_Mesh_var mesh = SMESH::SObjectToInterface<SMESH::SMESH_Mesh>( submSO );
SMESH::SMESH_subMesh_var subMesh = SMESH::SObjectToInterface<SMESH::SMESH_subMesh>( submSO );
if( !subMesh->_is_nil() )
mesh = subMesh->GetFather();
if ( mesh->_is_nil() )
continue;
SMESH::ListOfGroups_var groups = mesh->GetGroups();
for ( CORBA::ULong iG = 0; iG < groups->length(); iG++ )
{
if ( groups[iG]->GetType() != type )
continue;
CORBA::String_var name = groups[iG]->GetName();
if ( strcmp( name.in(), oldName ))
continue;
mesh->RemoveGroup( groups[iG] );
}
}
}
//================================================================================ //================================================================================
/*! /*!
* \brief Check parameter values before accept() * \brief Check parameter values before accept()
@ -733,7 +774,10 @@ QString StdMeshersGUI_StdHypothesisCreator::storeParams() const
if ( StdMeshersGUI_NameCheckableGrpWdg* nameWg = if ( StdMeshersGUI_NameCheckableGrpWdg* nameWg =
widget< StdMeshersGUI_NameCheckableGrpWdg >( 6 )) widget< StdMeshersGUI_NameCheckableGrpWdg >( 6 ))
{ {
CORBA::String_var oldName = h->GetGroupName();
h->SetGroupName( nameWg->getName().toUtf8().data() ); h->SetGroupName( nameWg->getName().toUtf8().data() );
CORBA::String_var newName = h->GetGroupName();
removeOldGroup( oldName, newName, SMESH::VOLUME );
} }
} }
else if( hypType()=="ViscousLayers2D" ) else if( hypType()=="ViscousLayers2D" )
@ -757,7 +801,10 @@ QString StdMeshersGUI_StdHypothesisCreator::storeParams() const
if ( StdMeshersGUI_NameCheckableGrpWdg* nameWg = if ( StdMeshersGUI_NameCheckableGrpWdg* nameWg =
widget< StdMeshersGUI_NameCheckableGrpWdg >( 5 )) widget< StdMeshersGUI_NameCheckableGrpWdg >( 5 ))
{ {
CORBA::String_var oldName = h->GetGroupName();
h->SetGroupName( nameWg->getName().toUtf8().data() ); h->SetGroupName( nameWg->getName().toUtf8().data() );
CORBA::String_var newName = h->GetGroupName();
removeOldGroup( oldName, newName, SMESH::FACE );
} }
} }
// else if( hypType()=="QuadrangleParams" ) // else if( hypType()=="QuadrangleParams" )

View File

@ -66,6 +66,9 @@ protected:
bool initVariableName(SMESH::SMESH_Hypothesis_var theHyp, StdParam& theParams, const char* theMethod) const; bool initVariableName(SMESH::SMESH_Hypothesis_var theHyp, StdParam& theParams, const char* theMethod) const;
QWidget* makeReverseEdgesWdg( SMESH::long_array_var edgeIDs, QWidget* makeReverseEdgesWdg( SMESH::long_array_var edgeIDs,
CORBA::String_var shapeEntry) const; CORBA::String_var shapeEntry) const;
void removeOldGroup(const char* oldName,
const char* newName,
SMESH::ElementType type) const;