mirror of
https://git.salome-platform.org/gitpub/modules/smesh.git
synced 2025-01-13 10:10:33 +05:00
53416: SALOME crashes when selecting a sub-menu of Control menu item
This commit is contained in:
parent
287b2ac10e
commit
c18fd9d00c
@ -35,7 +35,7 @@ Mesh module provides several ways to create the mesh:
|
|||||||
</li>
|
</li>
|
||||||
<li>Bottom-up way, using \ref modifying_meshes_page "mesh modification"
|
<li>Bottom-up way, using \ref modifying_meshes_page "mesh modification"
|
||||||
operations, especially \ref extrusion_page "extrusion" and \ref
|
operations, especially \ref extrusion_page "extrusion" and \ref
|
||||||
revolution_page "revolution". To create an empty mesh not based on a
|
revolution_page "revolution". To create an empty mesh not based on
|
||||||
geometry, use the same dialog as to \ref constructing_meshes_page
|
geometry, use the same dialog as to \ref constructing_meshes_page
|
||||||
"construct the mesh on geometry" but specify neither the geometry
|
"construct the mesh on geometry" but specify neither the geometry
|
||||||
nor meshing algorithms.
|
nor meshing algorithms.
|
||||||
@ -44,9 +44,9 @@ Mesh module provides several ways to create the mesh:
|
|||||||
(and exported to) the file in MED, UNV, STL, CGNS, DAT, GMF and
|
(and exported to) the file in MED, UNV, STL, CGNS, DAT, GMF and
|
||||||
SAUVE formats.
|
SAUVE formats.
|
||||||
</li>
|
</li>
|
||||||
<li>The 3D mesh can be generated from the 2D mesh not based on the geometry,
|
<li>The 3D mesh can be generated from the 2D mesh not based on geometry,
|
||||||
which was either \ref importing_exporting_meshes_page "imported" or created in
|
which was either \ref importing_exporting_meshes_page "imported" or created in
|
||||||
other way. To setup the meshing parameters of a mesh not based on a geometry,
|
other way. To setup the meshing parameters of a mesh not based on geometry,
|
||||||
just invoke \ref editing_meshes_page "Edit mesh / sub-mesh" command on
|
just invoke \ref editing_meshes_page "Edit mesh / sub-mesh" command on
|
||||||
your 2D mesh.
|
your 2D mesh.
|
||||||
</li>
|
</li>
|
||||||
|
@ -10,6 +10,9 @@ To create a mesh on geometry, it is necessary to create a mesh object by choosin
|
|||||||
taken into account by the chosen meshing algorithms.
|
taken into account by the chosen meshing algorithms.
|
||||||
|
|
||||||
Then you can launch mesh generation by invoking \ref compute_anchor "Compute" command.
|
Then you can launch mesh generation by invoking \ref compute_anchor "Compute" command.
|
||||||
|
The generated mesh will be automatically shown in the Viewer. You can
|
||||||
|
switch off automatic visualization or limit mesh size until which it is
|
||||||
|
automatically shown in \ref mesh_preferences_page (<em>Automatic update</em> entry).
|
||||||
|
|
||||||
\note Sometimes \a hypotheses term is used to refer to both algorithms
|
\note Sometimes \a hypotheses term is used to refer to both algorithms
|
||||||
and hypotheses.
|
and hypotheses.
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
/*!
|
/*!
|
||||||
|
|
||||||
\mainpage Introduction to MESH
|
\mainpage Introduction to Mesh module
|
||||||
|
|
||||||
\image html a-viewgeneral.png
|
\image html a-viewgeneral.png
|
||||||
|
|
||||||
|
@ -2,8 +2,9 @@
|
|||||||
|
|
||||||
\page max_element_length_2d_page Element Diameter 2D
|
\page max_element_length_2d_page Element Diameter 2D
|
||||||
|
|
||||||
\n This quality control criterion consists in calculation of the length of
|
\n This quality control criterion consists in calculation of the maximal length of
|
||||||
edges and diagonals combining 2D mesh elements (triangles and quadrangles).
|
edges and diagonals of 2D mesh elements (triangles and quadrangles). For polygons
|
||||||
|
the value is always zero.
|
||||||
|
|
||||||
<em>To apply the Element Diameter 2D quality criterion to your mesh:</em>
|
<em>To apply the Element Diameter 2D quality criterion to your mesh:</em>
|
||||||
<ol>
|
<ol>
|
||||||
|
@ -2,9 +2,9 @@
|
|||||||
|
|
||||||
\page max_element_length_3d_page Element Diameter 3D
|
\page max_element_length_3d_page Element Diameter 3D
|
||||||
|
|
||||||
\n This quality control criterion consists in calculation of the length of
|
\n This quality control criterion consists in calculation of the maximal length of
|
||||||
edges and diagonals combining 3D mesh elements
|
edges and diagonals of 3D mesh elements (tetrahedrons, pyramids, etc). For polyhedra
|
||||||
(tetrahedrons, pyramids, pentahendrons, hexahedrons and polyhedrons).
|
the value is always zero.
|
||||||
|
|
||||||
<em>To apply the Element Diameter 3D quality criterion to your mesh:</em>
|
<em>To apply the Element Diameter 3D quality criterion to your mesh:</em>
|
||||||
<ol>
|
<ol>
|
||||||
|
@ -195,7 +195,7 @@ namespace
|
|||||||
|
|
||||||
void SetDisplayEntity(int theCommandID);
|
void SetDisplayEntity(int theCommandID);
|
||||||
|
|
||||||
int ActionToControl( int theID, bool theReversed = false );
|
int ActionToControl( int theID, bool theReversed = false );
|
||||||
|
|
||||||
void Control( int theCommandID );
|
void Control( int theCommandID );
|
||||||
|
|
||||||
@ -265,14 +265,16 @@ namespace
|
|||||||
filter,
|
filter,
|
||||||
QObject::tr( "SMESH_IMPORT_MESH" ) );
|
QObject::tr( "SMESH_IMPORT_MESH" ) );
|
||||||
}
|
}
|
||||||
if ( filenames.count() > 0 ) {
|
if ( filenames.count() > 0 )
|
||||||
|
{
|
||||||
SUIT_OverrideCursor wc;
|
SUIT_OverrideCursor wc;
|
||||||
_PTR(Study) aStudy = SMESH::GetActiveStudyDocument();
|
_PTR(Study) aStudy = SMESH::GetActiveStudyDocument();
|
||||||
|
|
||||||
QStringList errors;
|
QStringList errors;
|
||||||
QStringList anEntryList;
|
QStringList anEntryList;
|
||||||
bool isEmpty = false;
|
bool isEmpty = false;
|
||||||
for ( QStringList::ConstIterator it = filenames.begin(); it != filenames.end(); ++it ) {
|
for ( QStringList::ConstIterator it = filenames.begin(); it != filenames.end(); ++it )
|
||||||
|
{
|
||||||
QString filename = *it;
|
QString filename = *it;
|
||||||
SMESH::mesh_array_var aMeshes = new SMESH::mesh_array;
|
SMESH::mesh_array_var aMeshes = new SMESH::mesh_array;
|
||||||
try {
|
try {
|
||||||
@ -365,7 +367,8 @@ namespace
|
|||||||
arg( QObject::tr( "SMESH_ERR_UNKNOWN_IMPORT_ERROR" ) ) );
|
arg( QObject::tr( "SMESH_ERR_UNKNOWN_IMPORT_ERROR" ) ) );
|
||||||
}
|
}
|
||||||
|
|
||||||
for ( int i = 0, iEnd = aMeshes->length(); i < iEnd; i++ ) {
|
for ( int i = 0, iEnd = aMeshes->length(); i < iEnd; i++ )
|
||||||
|
{
|
||||||
_PTR(SObject) aMeshSO = SMESH::FindSObject( aMeshes[i] );
|
_PTR(SObject) aMeshSO = SMESH::FindSObject( aMeshes[i] );
|
||||||
if ( aMeshSO ) {
|
if ( aMeshSO ) {
|
||||||
_PTR(StudyBuilder) aBuilder = aStudy->NewBuilder();
|
_PTR(StudyBuilder) aBuilder = aStudy->NewBuilder();
|
||||||
@ -1634,11 +1637,11 @@ namespace
|
|||||||
|
|
||||||
void Control( int theCommandID )
|
void Control( int theCommandID )
|
||||||
{
|
{
|
||||||
SMESH_Actor::eControl aControl = SMESH_Actor::eControl( ActionToControl( theCommandID ) );
|
SMESH_Actor::eControl aControl = SMESH_Actor::eControl( ActionToControl( theCommandID ));
|
||||||
_PTR(Study) aStudy = SMESH::GetActiveStudyDocument();
|
_PTR(Study) aStudy = SMESH::GetActiveStudyDocument();
|
||||||
LightApp_SelectionMgr *aSel = SMESHGUI::selectionMgr();
|
|
||||||
SALOME_ListIO selected;
|
SALOME_ListIO selected;
|
||||||
if ( aSel )
|
if ( LightApp_SelectionMgr *aSel = SMESHGUI::selectionMgr() )
|
||||||
aSel->selectedObjects( selected );
|
aSel->selectedObjects( selected );
|
||||||
|
|
||||||
if ( !selected.IsEmpty() ) {
|
if ( !selected.IsEmpty() ) {
|
||||||
@ -1646,14 +1649,24 @@ namespace
|
|||||||
for ( ; It.More(); It.Next())
|
for ( ; It.More(); It.Next())
|
||||||
{
|
{
|
||||||
Handle(SALOME_InteractiveObject) anIO = It.Value();
|
Handle(SALOME_InteractiveObject) anIO = It.Value();
|
||||||
if(!anIO.IsNull()){
|
if ( !anIO.IsNull() ) {
|
||||||
_PTR(SObject) SO = aStudy->FindObjectID( It.Value()->getEntry() );
|
_PTR(SObject) SO = aStudy->FindObjectID( It.Value()->getEntry() );
|
||||||
if ( SO ) {
|
if ( SO ) {
|
||||||
CORBA::Object_var aObject = SMESH::SObjectToObject( SO );
|
CORBA::Object_var aObject = SMESH::SObjectToObject( SO );
|
||||||
SMESH::SMESH_IDSource_var anIDSrc = SMESH::SMESH_IDSource::_narrow( aObject );
|
SMESH::SMESH_IDSource_var anIDSrc = SMESH::SMESH_IDSource::_narrow( aObject );
|
||||||
if ( !anIDSrc->_is_nil() ) {
|
if ( !anIDSrc->_is_nil() ) {
|
||||||
if ( SMESH_Actor *anActor = SMESH::FindActorByEntry( anIO->getEntry()) ) {
|
SMESH_Actor *anActor = SMESH::FindActorByEntry( anIO->getEntry());
|
||||||
|
if (( !anActor && selected.Extent() == 1 ) &&
|
||||||
|
( anActor = SMESH::CreateActor( aStudy, anIO->getEntry() )))
|
||||||
|
{
|
||||||
anActor->SetControlMode( aControl );
|
anActor->SetControlMode( aControl );
|
||||||
|
SMESH::DisplayActor( SMESH::GetCurrentVtkView(), anActor );
|
||||||
|
SMESH::UpdateView ( SMESH::eDisplay, anIO->getEntry() );
|
||||||
|
}
|
||||||
|
if ( anActor )
|
||||||
|
{
|
||||||
|
if ( anActor->GetControlMode() != aControl )
|
||||||
|
anActor->SetControlMode( aControl );
|
||||||
QString functorName = functorToString( anActor->GetFunctor() );
|
QString functorName = functorToString( anActor->GetFunctor() );
|
||||||
anActor->GetScalarBarActor()->SetTitle( functorName.toLatin1().constData() );
|
anActor->GetScalarBarActor()->SetTitle( functorName.toLatin1().constData() );
|
||||||
SMESH::RepaintCurrentView();
|
SMESH::RepaintCurrentView();
|
||||||
@ -4148,9 +4161,9 @@ void SMESHGUI::initialize( CAM_Application* app )
|
|||||||
createMenu( SMESHOp::OpPropertiesVolume, basicPropId, -1 );
|
createMenu( SMESHOp::OpPropertiesVolume, basicPropId, -1 );
|
||||||
createMenu( SMESHOp::OpUpdate, viewId, -1 );
|
createMenu( SMESHOp::OpUpdate, viewId, -1 );
|
||||||
|
|
||||||
connect( nodeMenu, SIGNAL( aboutToShow() ), this, SLOT( onUpdateControlActions() ) );
|
connect( nodeMenu, SIGNAL( aboutToShow() ), this, SLOT( onUpdateControlActions() ) );
|
||||||
connect( edgeMenu, SIGNAL( aboutToShow() ), this, SLOT( onUpdateControlActions() ) );
|
connect( edgeMenu, SIGNAL( aboutToShow() ), this, SLOT( onUpdateControlActions() ) );
|
||||||
connect( faceMenu, SIGNAL( aboutToShow() ), this, SLOT( onUpdateControlActions() ) );
|
connect( faceMenu, SIGNAL( aboutToShow() ), this, SLOT( onUpdateControlActions() ) );
|
||||||
connect( volumeMenu, SIGNAL( aboutToShow() ), this, SLOT( onUpdateControlActions() ) );
|
connect( volumeMenu, SIGNAL( aboutToShow() ), this, SLOT( onUpdateControlActions() ) );
|
||||||
|
|
||||||
// ----- create toolbars --------------
|
// ----- create toolbars --------------
|
||||||
@ -6832,23 +6845,24 @@ void SMESHGUI::onHypothesisEdit( int result )
|
|||||||
*/
|
*/
|
||||||
void SMESHGUI::onUpdateControlActions()
|
void SMESHGUI::onUpdateControlActions()
|
||||||
{
|
{
|
||||||
LightApp_SelectionMgr* aSel = SMESHGUI::selectionMgr();
|
|
||||||
SALOME_ListIO selected;
|
SALOME_ListIO selected;
|
||||||
if ( aSel )
|
if ( LightApp_SelectionMgr* aSel = SMESHGUI::selectionMgr() )
|
||||||
aSel->selectedObjects( selected );
|
aSel->selectedObjects( selected );
|
||||||
|
|
||||||
SMESH_Actor::eControl aControl = SMESH_Actor::eNone;
|
SMESH_Actor::eControl aControl = SMESH_Actor::eNone;
|
||||||
if ( selected.Extent() ) {
|
if ( selected.Extent() ) {
|
||||||
if ( selected.First()->hasEntry() ) {
|
if ( selected.First()->hasEntry() ) {
|
||||||
aControl = SMESH::FindActorByEntry( selected.First()->getEntry() )->GetControlMode();
|
if ( SMESH_Actor* anActor = SMESH::FindActorByEntry( selected.First()->getEntry() )) {
|
||||||
SALOME_ListIteratorOfListIO it(selected);
|
aControl = anActor->GetControlMode();
|
||||||
for ( ; it.More(); it.Next() ) {
|
SALOME_ListIteratorOfListIO it(selected);
|
||||||
Handle(SALOME_InteractiveObject) anIO = it.Value();
|
for ( it.Next(); it.More(); it.Next() ) {
|
||||||
if ( anIO->hasEntry() ) {
|
Handle(SALOME_InteractiveObject) anIO = it.Value();
|
||||||
if ( SMESH_Actor* anActor = SMESH::FindActorByEntry( anIO->getEntry() ) ) {
|
if ( anIO->hasEntry() ) {
|
||||||
if ( aControl != anActor->GetControlMode() ) {
|
if ( SMESH_Actor* anActor = SMESH::FindActorByEntry( anIO->getEntry() ) ) {
|
||||||
aControl = SMESH_Actor::eNone;
|
if ( aControl != anActor->GetControlMode() ) {
|
||||||
break;
|
aControl = SMESH_Actor::eNone;
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -953,10 +953,8 @@ void SMESHGUI_BaseComputeOp::computeMesh()
|
|||||||
{
|
{
|
||||||
SMESH::SMESH_GroupBase_var aGrp = aGroups[i];
|
SMESH::SMESH_GroupBase_var aGrp = aGroups[i];
|
||||||
if ( CORBA::is_nil( aGrp ) ) continue;
|
if ( CORBA::is_nil( aGrp ) ) continue;
|
||||||
SMESH::SMESH_Group_var aStdGroup = SMESH::SMESH_Group::_narrow( aGrp );
|
SMESH::SMESH_Group_var aStdGroup = SMESH::SMESH_Group::_narrow( aGrp );
|
||||||
SMESH::SMESH_GroupOnGeom_var aGeomGroup = SMESH::SMESH_GroupOnGeom::_narrow( aGrp );
|
if ( !aStdGroup->_is_nil() ) continue; // don't update standalone groups
|
||||||
SMESH::SMESH_GroupOnFilter_var aFltGroup = SMESH::SMESH_GroupOnFilter::_narrow( aGrp );
|
|
||||||
if ( !aStdGroup->_is_nil() ) continue; // don't update the standalone groups
|
|
||||||
_PTR(SObject) aGroupSO = SMESH::FindSObject( aGrp );
|
_PTR(SObject) aGroupSO = SMESH::FindSObject( aGrp );
|
||||||
if ( !aGroupSO ) continue;
|
if ( !aGroupSO ) continue;
|
||||||
SMESH::SMESH_IDSource_var aGroupObj =
|
SMESH::SMESH_IDSource_var aGroupObj =
|
||||||
|
Loading…
Reference in New Issue
Block a user