Fix of issue 0020614: EDF 1133 SMESH : Put new added elements and nodes to group
Before Width: | Height: | Size: 19 KiB After Width: | Height: | Size: 23 KiB |
Before Width: | Height: | Size: 10 KiB After Width: | Height: | Size: 15 KiB |
Before Width: | Height: | Size: 10 KiB After Width: | Height: | Size: 14 KiB |
Before Width: | Height: | Size: 12 KiB After Width: | Height: | Size: 16 KiB |
Before Width: | Height: | Size: 9.0 KiB After Width: | Height: | Size: 13 KiB |
Before Width: | Height: | Size: 12 KiB After Width: | Height: | Size: 14 KiB |
Before Width: | Height: | Size: 12 KiB After Width: | Height: | Size: 17 KiB |
Before Width: | Height: | Size: 13 KiB After Width: | Height: | Size: 18 KiB |
Before Width: | Height: | Size: 12 KiB After Width: | Height: | Size: 16 KiB |
Before Width: | Height: | Size: 12 KiB After Width: | Height: | Size: 16 KiB |
Before Width: | Height: | Size: 20 KiB After Width: | Height: | Size: 25 KiB |
@ -26,6 +26,10 @@ following associated submenu will appear:</li>
|
|||||||
\image html image146.png
|
\image html image146.png
|
||||||
|
|
||||||
From this submenu select the type of element which you would like to add to your mesh.
|
From this submenu select the type of element which you would like to add to your mesh.
|
||||||
|
\note All dialogs intended for adding nodes or elements to mesh provide a possibility
|
||||||
|
to add these nodes/elements to the specified group (or to create the group if it
|
||||||
|
doesn't exist). <b>Add to group</b> box allows to choose an existing group for created
|
||||||
|
node or element or to specify a name for new group.
|
||||||
</ol>
|
</ol>
|
||||||
|
|
||||||
<b>See Also</b> sample TUI Scripts of
|
<b>See Also</b> sample TUI Scripts of
|
||||||
|
@ -18,6 +18,11 @@ one of the following:
|
|||||||
|
|
||||||
\image html image152.png
|
\image html image152.png
|
||||||
|
|
||||||
|
\note All dialogs intended for adding quadratic elements to mesh provide a possibility
|
||||||
|
to add these elements to the specified group (or to create the group if it doesn't exist).
|
||||||
|
<b>Add to group</b> box allows to choose an existing group for created element or
|
||||||
|
to specify a name for new group.
|
||||||
|
|
||||||
To create any <b>Quadratic Element</b> specify the nodes which will form your
|
To create any <b>Quadratic Element</b> specify the nodes which will form your
|
||||||
triangle by selecting them in the 3D viewer with pressed Shift
|
triangle by selecting them in the 3D viewer with pressed Shift
|
||||||
button. Their numbers will appear in the dialog box as <b>Corner Nodes</b>
|
button. Their numbers will appear in the dialog box as <b>Corner Nodes</b>
|
||||||
|
@ -30,6 +30,7 @@
|
|||||||
#include "SMESHGUI_Utils.h"
|
#include "SMESHGUI_Utils.h"
|
||||||
#include "SMESHGUI_VTKUtils.h"
|
#include "SMESHGUI_VTKUtils.h"
|
||||||
#include "SMESHGUI_MeshUtils.h"
|
#include "SMESHGUI_MeshUtils.h"
|
||||||
|
#include "SMESHGUI_GroupUtils.h"
|
||||||
#include "SMESHGUI_IdValidator.h"
|
#include "SMESHGUI_IdValidator.h"
|
||||||
|
|
||||||
#include <SMESH_Actor.h>
|
#include <SMESH_Actor.h>
|
||||||
@ -64,6 +65,7 @@
|
|||||||
#include <vtkProperty.h>
|
#include <vtkProperty.h>
|
||||||
|
|
||||||
// Qt includes
|
// Qt includes
|
||||||
|
#include <QComboBox>
|
||||||
#include <QGroupBox>
|
#include <QGroupBox>
|
||||||
#include <QLabel>
|
#include <QLabel>
|
||||||
#include <QLineEdit>
|
#include <QLineEdit>
|
||||||
@ -358,6 +360,20 @@ SMESHGUI_AddMeshElementDlg::SMESHGUI_AddMeshElementDlg( SMESHGUI* theModule,
|
|||||||
GroupC1Layout->addWidget(LineEditC1A1, 0, 2);
|
GroupC1Layout->addWidget(LineEditC1A1, 0, 2);
|
||||||
if ( Reverse ) GroupC1Layout->addWidget(Reverse, 1, 0, 1, 3);
|
if ( Reverse ) GroupC1Layout->addWidget(Reverse, 1, 0, 1, 3);
|
||||||
|
|
||||||
|
/***************************************************************/
|
||||||
|
GroupGroups = new QGroupBox( tr( "SMESH_ADD_TO_GROUP" ), this );
|
||||||
|
GroupGroups->setCheckable( true );
|
||||||
|
QHBoxLayout* GroupGroupsLayout = new QHBoxLayout(GroupGroups);
|
||||||
|
GroupGroupsLayout->setSpacing(SPACING);
|
||||||
|
GroupGroupsLayout->setMargin(MARGIN);
|
||||||
|
|
||||||
|
TextLabel_GroupName = new QLabel( tr( "SMESH_GROUP" ), GroupGroups );
|
||||||
|
ComboBox_GroupName = new QComboBox( GroupGroups );
|
||||||
|
ComboBox_GroupName->setEditable( true );
|
||||||
|
|
||||||
|
GroupGroupsLayout->addWidget( TextLabel_GroupName );
|
||||||
|
GroupGroupsLayout->addWidget( ComboBox_GroupName, 1 );
|
||||||
|
|
||||||
/***************************************************************/
|
/***************************************************************/
|
||||||
GroupButtons = new QGroupBox(this);
|
GroupButtons = new QGroupBox(this);
|
||||||
QHBoxLayout* GroupButtonsLayout = new QHBoxLayout(GroupButtons);
|
QHBoxLayout* GroupButtonsLayout = new QHBoxLayout(GroupButtons);
|
||||||
@ -385,6 +401,7 @@ SMESHGUI_AddMeshElementDlg::SMESHGUI_AddMeshElementDlg( SMESHGUI* theModule,
|
|||||||
/***************************************************************/
|
/***************************************************************/
|
||||||
aTopLayout->addWidget(GroupConstructors);
|
aTopLayout->addWidget(GroupConstructors);
|
||||||
aTopLayout->addWidget(GroupC1);
|
aTopLayout->addWidget(GroupC1);
|
||||||
|
aTopLayout->addWidget(GroupGroups);
|
||||||
aTopLayout->addWidget(GroupButtons);
|
aTopLayout->addWidget(GroupButtons);
|
||||||
|
|
||||||
Init(); /* Initialisations */
|
Init(); /* Initialisations */
|
||||||
@ -410,6 +427,9 @@ void SMESHGUI_AddMeshElementDlg::Init()
|
|||||||
myEditCurrentArgument = LineEditC1A1;
|
myEditCurrentArgument = LineEditC1A1;
|
||||||
mySMESHGUI->SetActiveDialogBox((QDialog*)this);
|
mySMESHGUI->SetActiveDialogBox((QDialog*)this);
|
||||||
|
|
||||||
|
/* reset "Add to group" control */
|
||||||
|
GroupGroups->setChecked( false );
|
||||||
|
|
||||||
myNbOkNodes = 0;
|
myNbOkNodes = 0;
|
||||||
myActor = 0;
|
myActor = 0;
|
||||||
|
|
||||||
@ -446,6 +466,9 @@ void SMESHGUI_AddMeshElementDlg::Init()
|
|||||||
//=================================================================================
|
//=================================================================================
|
||||||
void SMESHGUI_AddMeshElementDlg::ClickOnApply()
|
void SMESHGUI_AddMeshElementDlg::ClickOnApply()
|
||||||
{
|
{
|
||||||
|
if( !isValid() )
|
||||||
|
return;
|
||||||
|
|
||||||
if (myNbOkNodes && !mySMESHGUI->isActiveStudyLocked()) {
|
if (myNbOkNodes && !mySMESHGUI->isActiveStudyLocked()) {
|
||||||
myBusy = true;
|
myBusy = true;
|
||||||
SMESH::long_array_var anArrayOfIndices = new SMESH::long_array;
|
SMESH::long_array_var anArrayOfIndices = new SMESH::long_array;
|
||||||
@ -458,24 +481,53 @@ void SMESHGUI_AddMeshElementDlg::ClickOnApply()
|
|||||||
else
|
else
|
||||||
anArrayOfIndices[i] = aListId[ i ].toInt();
|
anArrayOfIndices[i] = aListId[ i ].toInt();
|
||||||
|
|
||||||
|
long anElemId = -1;
|
||||||
SMESH::SMESH_MeshEditor_var aMeshEditor = myMesh->GetMeshEditor();
|
SMESH::SMESH_MeshEditor_var aMeshEditor = myMesh->GetMeshEditor();
|
||||||
switch (myElementType) {
|
switch (myElementType) {
|
||||||
case SMDSAbs_0DElement:
|
case SMDSAbs_0DElement:
|
||||||
aMeshEditor->Add0DElement(anArrayOfIndices[0]); break;
|
anElemId = aMeshEditor->Add0DElement(anArrayOfIndices[0]); break;
|
||||||
case SMDSAbs_Edge:
|
case SMDSAbs_Edge:
|
||||||
aMeshEditor->AddEdge(anArrayOfIndices.inout()); break;
|
anElemId = aMeshEditor->AddEdge(anArrayOfIndices.inout()); break;
|
||||||
case SMDSAbs_Face: {
|
case SMDSAbs_Face: {
|
||||||
if(myIsPoly)
|
if(myIsPoly)
|
||||||
aMeshEditor->AddPolygonalFace(anArrayOfIndices.inout());
|
anElemId = aMeshEditor->AddPolygonalFace(anArrayOfIndices.inout());
|
||||||
else
|
else
|
||||||
aMeshEditor->AddFace(anArrayOfIndices.inout());
|
anElemId = aMeshEditor->AddFace(anArrayOfIndices.inout());
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case SMDSAbs_Volume:
|
case SMDSAbs_Volume:
|
||||||
aMeshEditor->AddVolume(anArrayOfIndices.inout()); break;
|
anElemId = aMeshEditor->AddVolume(anArrayOfIndices.inout()); break;
|
||||||
default:;
|
default:;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if( anElemId != -1 && GroupGroups->isChecked() ) {
|
||||||
|
SMESH::SMESH_Group_var aGroup;
|
||||||
|
QString aGroupName = ComboBox_GroupName->currentText();
|
||||||
|
SMESH::ListOfGroups aListOfGroups = *myMesh->GetGroups();
|
||||||
|
for( int i = 0, n = aListOfGroups.length(); i < n; i++ ) {
|
||||||
|
SMESH::SMESH_GroupBase_var aGroupBase = aListOfGroups[i];
|
||||||
|
if( !aGroupBase->_is_nil() ) {
|
||||||
|
SMESH::SMESH_Group_var aRefGroup = SMESH::SMESH_Group::_narrow( aGroupBase );
|
||||||
|
if( !aRefGroup->_is_nil() ) {
|
||||||
|
QString aRefGroupName( aRefGroup->GetName() );
|
||||||
|
if( aRefGroupName == aGroupName ) {
|
||||||
|
aGroup = aRefGroup; // // add node to existing group
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if( aGroup->_is_nil() ) // create new group
|
||||||
|
aGroup = SMESH::AddGroup( myMesh, (SMESH::ElementType)myElementType, aGroupName );
|
||||||
|
|
||||||
|
if( !aGroup->_is_nil() ) {
|
||||||
|
SMESH::long_array_var anIdList = new SMESH::long_array;
|
||||||
|
anIdList->length( 1 );
|
||||||
|
anIdList[0] = anElemId;
|
||||||
|
aGroup->Add( anIdList.inout() );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
SALOME_ListIO aList; aList.Append( myActor->getIO() );
|
SALOME_ListIO aList; aList.Append( myActor->getIO() );
|
||||||
mySelector->ClearIndex();
|
mySelector->ClearIndex();
|
||||||
mySelectionMgr->setSelectedObjects( aList, false );
|
mySelectionMgr->setSelectedObjects( aList, false );
|
||||||
@ -628,6 +680,8 @@ void SMESHGUI_AddMeshElementDlg::SelectionIntoArgument()
|
|||||||
mySimulation->SetVisibility(false);
|
mySimulation->SetVisibility(false);
|
||||||
// SMESH::SetPointRepresentation(true);
|
// SMESH::SetPointRepresentation(true);
|
||||||
|
|
||||||
|
QString aCurrentEntry = myEntry;
|
||||||
|
|
||||||
// get selected mesh
|
// get selected mesh
|
||||||
SALOME_ListIO aList;
|
SALOME_ListIO aList;
|
||||||
mySelectionMgr->selectedObjects(aList,SVTK_Viewer::Type());
|
mySelectionMgr->selectedObjects(aList,SVTK_Viewer::Type());
|
||||||
@ -636,10 +690,29 @@ void SMESHGUI_AddMeshElementDlg::SelectionIntoArgument()
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
Handle(SALOME_InteractiveObject) anIO = aList.First();
|
Handle(SALOME_InteractiveObject) anIO = aList.First();
|
||||||
|
myEntry = anIO->getEntry();
|
||||||
myMesh = SMESH::GetMeshByIO(anIO);
|
myMesh = SMESH::GetMeshByIO(anIO);
|
||||||
if (myMesh->_is_nil())
|
if (myMesh->_is_nil())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
// process groups
|
||||||
|
if ( !myMesh->_is_nil() && myEntry != aCurrentEntry ) {
|
||||||
|
ComboBox_GroupName->clear();
|
||||||
|
ComboBox_GroupName->addItem( QString() );
|
||||||
|
SMESH::ListOfGroups aListOfGroups = *myMesh->GetGroups();
|
||||||
|
for ( int i = 0, n = aListOfGroups.length(); i < n; i++ ) {
|
||||||
|
SMESH::SMESH_GroupBase_var aGroupBase = aListOfGroups[i];
|
||||||
|
if ( !aGroupBase->_is_nil() && aGroupBase->GetType() == (SMESH::ElementType)myElementType ) {
|
||||||
|
SMESH::SMESH_Group_var aGroup = SMESH::SMESH_Group::_narrow( aGroupBase );
|
||||||
|
if ( !aGroup->_is_nil() ) {
|
||||||
|
QString aGroupName( aGroup->GetName() );
|
||||||
|
if ( !aGroupName.isEmpty() )
|
||||||
|
ComboBox_GroupName->addItem( aGroupName );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
myActor = SMESH::FindActorByEntry(anIO->getEntry());
|
myActor = SMESH::FindActorByEntry(anIO->getEntry());
|
||||||
if (!myActor)
|
if (!myActor)
|
||||||
return;
|
return;
|
||||||
@ -812,3 +885,16 @@ void SMESHGUI_AddMeshElementDlg::keyPressEvent( QKeyEvent* e )
|
|||||||
ClickOnHelp();
|
ClickOnHelp();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//=================================================================================
|
||||||
|
// function : isValid
|
||||||
|
// purpose :
|
||||||
|
//=================================================================================
|
||||||
|
bool SMESHGUI_AddMeshElementDlg::isValid()
|
||||||
|
{
|
||||||
|
if( GroupGroups->isChecked() && ComboBox_GroupName->currentText().isEmpty() ) {
|
||||||
|
SUIT_MessageBox::warning( this, tr( "SMESH_WRN_WARNING" ), tr( "GROUP_NAME_IS_EMPTY" ) );
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
@ -38,6 +38,7 @@
|
|||||||
#include <SALOMEconfig.h>
|
#include <SALOMEconfig.h>
|
||||||
#include CORBA_SERVER_HEADER(SMESH_Mesh)
|
#include CORBA_SERVER_HEADER(SMESH_Mesh)
|
||||||
|
|
||||||
|
class QComboBox;
|
||||||
class QGroupBox;
|
class QGroupBox;
|
||||||
class QLabel;
|
class QLabel;
|
||||||
class QLineEdit;
|
class QLineEdit;
|
||||||
@ -74,6 +75,8 @@ private:
|
|||||||
void keyPressEvent( QKeyEvent* );
|
void keyPressEvent( QKeyEvent* );
|
||||||
void displaySimulation();
|
void displaySimulation();
|
||||||
|
|
||||||
|
bool isValid();
|
||||||
|
|
||||||
SMESHGUI* mySMESHGUI; /* Current SMESHGUI object */
|
SMESHGUI* mySMESHGUI; /* Current SMESHGUI object */
|
||||||
LightApp_SelectionMgr* mySelectionMgr; /* User shape selection */
|
LightApp_SelectionMgr* mySelectionMgr; /* User shape selection */
|
||||||
int myNbOkNodes; /* to check when arguments is defined */
|
int myNbOkNodes; /* to check when arguments is defined */
|
||||||
@ -89,9 +92,13 @@ private:
|
|||||||
SMESH::SMESH_Mesh_var myMesh;
|
SMESH::SMESH_Mesh_var myMesh;
|
||||||
SMESH_Actor* myActor;
|
SMESH_Actor* myActor;
|
||||||
SMESH::TElementSimulation* mySimulation;
|
SMESH::TElementSimulation* mySimulation;
|
||||||
|
QString myEntry;
|
||||||
|
|
||||||
QGroupBox* GroupConstructors;
|
QGroupBox* GroupConstructors;
|
||||||
QRadioButton* Constructor1;
|
QRadioButton* Constructor1;
|
||||||
|
QGroupBox* GroupGroups;
|
||||||
|
QLabel* TextLabel_GroupName;
|
||||||
|
QComboBox* ComboBox_GroupName;
|
||||||
QGroupBox* GroupButtons;
|
QGroupBox* GroupButtons;
|
||||||
QPushButton* buttonOk;
|
QPushButton* buttonOk;
|
||||||
QPushButton* buttonCancel;
|
QPushButton* buttonCancel;
|
||||||
|
@ -30,6 +30,7 @@
|
|||||||
#include "SMESHGUI_Utils.h"
|
#include "SMESHGUI_Utils.h"
|
||||||
#include "SMESHGUI_VTKUtils.h"
|
#include "SMESHGUI_VTKUtils.h"
|
||||||
#include "SMESHGUI_MeshUtils.h"
|
#include "SMESHGUI_MeshUtils.h"
|
||||||
|
#include "SMESHGUI_GroupUtils.h"
|
||||||
#include "SMESHGUI_IdValidator.h"
|
#include "SMESHGUI_IdValidator.h"
|
||||||
|
|
||||||
#include <SMESH_Actor.h>
|
#include <SMESH_Actor.h>
|
||||||
@ -69,6 +70,7 @@
|
|||||||
#include <vtkCellType.h>
|
#include <vtkCellType.h>
|
||||||
|
|
||||||
// Qt includes
|
// Qt includes
|
||||||
|
#include <QComboBox>
|
||||||
#include <QGroupBox>
|
#include <QGroupBox>
|
||||||
#include <QLabel>
|
#include <QLabel>
|
||||||
#include <QLineEdit>
|
#include <QLineEdit>
|
||||||
@ -505,6 +507,20 @@ SMESHGUI_AddQuadraticElementDlg::SMESHGUI_AddQuadraticElementDlg( SMESHGUI* theM
|
|||||||
aGroupArgumentsLayout->addWidget(myTable, 1, 0, 1, 3);
|
aGroupArgumentsLayout->addWidget(myTable, 1, 0, 1, 3);
|
||||||
aGroupArgumentsLayout->addWidget(myReverseCB, 2, 0, 1, 3);
|
aGroupArgumentsLayout->addWidget(myReverseCB, 2, 0, 1, 3);
|
||||||
|
|
||||||
|
/***************************************************************/
|
||||||
|
GroupGroups = new QGroupBox( tr( "SMESH_ADD_TO_GROUP" ), this );
|
||||||
|
GroupGroups->setCheckable( true );
|
||||||
|
QHBoxLayout* GroupGroupsLayout = new QHBoxLayout(GroupGroups);
|
||||||
|
GroupGroupsLayout->setSpacing(SPACING);
|
||||||
|
GroupGroupsLayout->setMargin(MARGIN);
|
||||||
|
|
||||||
|
TextLabel_GroupName = new QLabel( tr( "SMESH_GROUP" ), GroupGroups );
|
||||||
|
ComboBox_GroupName = new QComboBox( GroupGroups );
|
||||||
|
ComboBox_GroupName->setEditable( true );
|
||||||
|
|
||||||
|
GroupGroupsLayout->addWidget( TextLabel_GroupName );
|
||||||
|
GroupGroupsLayout->addWidget( ComboBox_GroupName, 1 );
|
||||||
|
|
||||||
/***************************************************************/
|
/***************************************************************/
|
||||||
GroupButtons = new QGroupBox(this);
|
GroupButtons = new QGroupBox(this);
|
||||||
QHBoxLayout* aGroupButtonsLayout = new QHBoxLayout(GroupButtons);
|
QHBoxLayout* aGroupButtonsLayout = new QHBoxLayout(GroupButtons);
|
||||||
@ -532,6 +548,7 @@ SMESHGUI_AddQuadraticElementDlg::SMESHGUI_AddQuadraticElementDlg( SMESHGUI* theM
|
|||||||
/***************************************************************/
|
/***************************************************************/
|
||||||
aDialogLayout->addWidget(GroupConstructors);
|
aDialogLayout->addWidget(GroupConstructors);
|
||||||
aDialogLayout->addWidget(GroupArguments);
|
aDialogLayout->addWidget(GroupArguments);
|
||||||
|
aDialogLayout->addWidget(GroupGroups);
|
||||||
aDialogLayout->addWidget(GroupButtons);
|
aDialogLayout->addWidget(GroupButtons);
|
||||||
|
|
||||||
Init(); /* Initialisations */
|
Init(); /* Initialisations */
|
||||||
@ -555,6 +572,9 @@ void SMESHGUI_AddQuadraticElementDlg::Init()
|
|||||||
myRadioButton1->setChecked(true);
|
myRadioButton1->setChecked(true);
|
||||||
mySMESHGUI->SetActiveDialogBox((QDialog*)this);
|
mySMESHGUI->SetActiveDialogBox((QDialog*)this);
|
||||||
|
|
||||||
|
/* reset "Add to group" control */
|
||||||
|
GroupGroups->setChecked( false );
|
||||||
|
|
||||||
myActor = 0;
|
myActor = 0;
|
||||||
|
|
||||||
int aNumRows;
|
int aNumRows;
|
||||||
@ -661,6 +681,9 @@ void SMESHGUI_AddQuadraticElementDlg::Init()
|
|||||||
//=================================================================================
|
//=================================================================================
|
||||||
void SMESHGUI_AddQuadraticElementDlg::ClickOnApply()
|
void SMESHGUI_AddQuadraticElementDlg::ClickOnApply()
|
||||||
{
|
{
|
||||||
|
if( !isValid() )
|
||||||
|
return;
|
||||||
|
|
||||||
if ( mySMESHGUI->isActiveStudyLocked() || myBusy || !IsValid() )
|
if ( mySMESHGUI->isActiveStudyLocked() || myBusy || !IsValid() )
|
||||||
return;
|
return;
|
||||||
|
|
||||||
@ -696,20 +719,53 @@ void SMESHGUI_AddQuadraticElementDlg::ClickOnApply()
|
|||||||
for (int i = 0; i < aNumberOfIds; i++)
|
for (int i = 0; i < aNumberOfIds; i++)
|
||||||
anArrayOfIdeces[i] = anIds[ i ];
|
anArrayOfIdeces[i] = anIds[ i ];
|
||||||
|
|
||||||
|
SMESH::ElementType anElementType;
|
||||||
|
long anElemId = -1;
|
||||||
SMESH::SMESH_MeshEditor_var aMeshEditor = myMesh->GetMeshEditor();
|
SMESH::SMESH_MeshEditor_var aMeshEditor = myMesh->GetMeshEditor();
|
||||||
switch (myType) {
|
switch (myType) {
|
||||||
case QUAD_EDGE:
|
case QUAD_EDGE:
|
||||||
aMeshEditor->AddEdge(anArrayOfIdeces.inout()); break;
|
anElementType = SMESH::EDGE;
|
||||||
|
anElemId = aMeshEditor->AddEdge(anArrayOfIdeces.inout()); break;
|
||||||
case QUAD_TRIANGLE:
|
case QUAD_TRIANGLE:
|
||||||
case QUAD_QUADRANGLE:
|
case QUAD_QUADRANGLE:
|
||||||
aMeshEditor->AddFace(anArrayOfIdeces.inout()); break;
|
anElementType = SMESH::FACE;
|
||||||
|
anElemId = aMeshEditor->AddFace(anArrayOfIdeces.inout()); break;
|
||||||
case QUAD_TETRAHEDRON:
|
case QUAD_TETRAHEDRON:
|
||||||
case QUAD_PYRAMID:
|
case QUAD_PYRAMID:
|
||||||
case QUAD_PENTAHEDRON:
|
case QUAD_PENTAHEDRON:
|
||||||
case QUAD_HEXAHEDRON:
|
case QUAD_HEXAHEDRON:
|
||||||
aMeshEditor->AddVolume(anArrayOfIdeces.inout()); break;
|
anElementType = SMESH::VOLUME;
|
||||||
|
anElemId = aMeshEditor->AddVolume(anArrayOfIdeces.inout()); break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if( anElemId != -1 && GroupGroups->isChecked() ) {
|
||||||
|
SMESH::SMESH_Group_var aGroup;
|
||||||
|
QString aGroupName = ComboBox_GroupName->currentText();
|
||||||
|
SMESH::ListOfGroups aListOfGroups = *myMesh->GetGroups();
|
||||||
|
for( int i = 0, n = aListOfGroups.length(); i < n; i++ ) {
|
||||||
|
SMESH::SMESH_GroupBase_var aGroupBase = aListOfGroups[i];
|
||||||
|
if( !aGroupBase->_is_nil() ) {
|
||||||
|
SMESH::SMESH_Group_var aRefGroup = SMESH::SMESH_Group::_narrow( aGroupBase );
|
||||||
|
if( !aRefGroup->_is_nil() ) {
|
||||||
|
QString aRefGroupName( aRefGroup->GetName() );
|
||||||
|
if( aRefGroupName == aGroupName ) {
|
||||||
|
aGroup = aRefGroup; // // add node to existing group
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if( aGroup->_is_nil() ) // create new group
|
||||||
|
aGroup = SMESH::AddGroup( myMesh, anElementType, aGroupName );
|
||||||
|
|
||||||
|
if( !aGroup->_is_nil() ) {
|
||||||
|
SMESH::long_array_var anIdList = new SMESH::long_array;
|
||||||
|
anIdList->length( 1 );
|
||||||
|
anIdList[0] = anElemId;
|
||||||
|
aGroup->Add( anIdList.inout() );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
SALOME_ListIO aList; aList.Append( myActor->getIO() );
|
SALOME_ListIO aList; aList.Append( myActor->getIO() );
|
||||||
mySelector->ClearIndex();
|
mySelector->ClearIndex();
|
||||||
mySelectionMgr->setSelectedObjects( aList, false );
|
mySelectionMgr->setSelectedObjects( aList, false );
|
||||||
@ -827,6 +883,8 @@ void SMESHGUI_AddQuadraticElementDlg::SelectionIntoArgument()
|
|||||||
if (myBusy) return;
|
if (myBusy) return;
|
||||||
BusyLocker lock( myBusy );
|
BusyLocker lock( myBusy );
|
||||||
|
|
||||||
|
QString aCurrentEntry = myEntry;
|
||||||
|
|
||||||
if ( myIsEditCorners )
|
if ( myIsEditCorners )
|
||||||
{
|
{
|
||||||
// clear
|
// clear
|
||||||
@ -851,6 +909,7 @@ void SMESHGUI_AddQuadraticElementDlg::SelectionIntoArgument()
|
|||||||
}
|
}
|
||||||
|
|
||||||
Handle(SALOME_InteractiveObject) anIO = aList.First();
|
Handle(SALOME_InteractiveObject) anIO = aList.First();
|
||||||
|
myEntry = anIO->getEntry();
|
||||||
myMesh = SMESH::GetMeshByIO(anIO);
|
myMesh = SMESH::GetMeshByIO(anIO);
|
||||||
if (myMesh->_is_nil()) {
|
if (myMesh->_is_nil()) {
|
||||||
updateButtons();
|
updateButtons();
|
||||||
@ -860,6 +919,37 @@ void SMESHGUI_AddQuadraticElementDlg::SelectionIntoArgument()
|
|||||||
myActor = SMESH::FindActorByEntry(anIO->getEntry());
|
myActor = SMESH::FindActorByEntry(anIO->getEntry());
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// process groups
|
||||||
|
if ( !myMesh->_is_nil() && myEntry != aCurrentEntry ) {
|
||||||
|
SMESH::ElementType anElementType;
|
||||||
|
switch ( myType ) {
|
||||||
|
case QUAD_EDGE:
|
||||||
|
anElementType = SMESH::EDGE; break;
|
||||||
|
case QUAD_TRIANGLE:
|
||||||
|
case QUAD_QUADRANGLE:
|
||||||
|
anElementType = SMESH::FACE; break;
|
||||||
|
case QUAD_TETRAHEDRON:
|
||||||
|
case QUAD_PYRAMID:
|
||||||
|
case QUAD_PENTAHEDRON:
|
||||||
|
case QUAD_HEXAHEDRON:
|
||||||
|
anElementType = SMESH::VOLUME; break;
|
||||||
|
}
|
||||||
|
ComboBox_GroupName->clear();
|
||||||
|
ComboBox_GroupName->addItem( QString() );
|
||||||
|
SMESH::ListOfGroups aListOfGroups = *myMesh->GetGroups();
|
||||||
|
for ( int i = 0, n = aListOfGroups.length(); i < n; i++ ) {
|
||||||
|
SMESH::SMESH_GroupBase_var aGroupBase = aListOfGroups[i];
|
||||||
|
if ( !aGroupBase->_is_nil() && aGroupBase->GetType() == anElementType ) {
|
||||||
|
SMESH::SMESH_Group_var aGroup = SMESH::SMESH_Group::_narrow( aGroupBase );
|
||||||
|
if ( !aGroup->_is_nil() ) {
|
||||||
|
QString aGroupName( aGroup->GetName() );
|
||||||
|
if ( !aGroupName.isEmpty() )
|
||||||
|
ComboBox_GroupName->addItem( aGroupName );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (!myActor) {
|
if (!myActor) {
|
||||||
updateButtons();
|
updateButtons();
|
||||||
@ -1169,3 +1259,16 @@ void SMESHGUI_AddQuadraticElementDlg::updateButtons()
|
|||||||
buttonOk->setEnabled( valid );
|
buttonOk->setEnabled( valid );
|
||||||
buttonApply->setEnabled( valid );
|
buttonApply->setEnabled( valid );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//=================================================================================
|
||||||
|
// function : isValid
|
||||||
|
// purpose :
|
||||||
|
//=================================================================================
|
||||||
|
bool SMESHGUI_AddQuadraticElementDlg::isValid()
|
||||||
|
{
|
||||||
|
if( GroupGroups->isChecked() && ComboBox_GroupName->currentText().isEmpty() ) {
|
||||||
|
SUIT_MessageBox::warning( this, tr( "SMESH_WRN_WARNING" ), tr( "GROUP_NAME_IS_EMPTY" ) );
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
@ -36,7 +36,9 @@
|
|||||||
#include <SALOMEconfig.h>
|
#include <SALOMEconfig.h>
|
||||||
#include CORBA_SERVER_HEADER(SMESH_Mesh)
|
#include CORBA_SERVER_HEADER(SMESH_Mesh)
|
||||||
|
|
||||||
|
class QComboBox;
|
||||||
class QGroupBox;
|
class QGroupBox;
|
||||||
|
class QLabel;
|
||||||
class QLineEdit;
|
class QLineEdit;
|
||||||
class QPushButton;
|
class QPushButton;
|
||||||
class QRadioButton;
|
class QRadioButton;
|
||||||
@ -78,6 +80,8 @@ private:
|
|||||||
bool IsValid();
|
bool IsValid();
|
||||||
void updateButtons();
|
void updateButtons();
|
||||||
|
|
||||||
|
bool isValid();
|
||||||
|
|
||||||
SMESHGUI* mySMESHGUI; /* Current SMESHGUI object */
|
SMESHGUI* mySMESHGUI; /* Current SMESHGUI object */
|
||||||
LightApp_SelectionMgr* mySelectionMgr; /* User shape selection */
|
LightApp_SelectionMgr* mySelectionMgr; /* User shape selection */
|
||||||
int myNbCorners; /* The required number of corners */
|
int myNbCorners; /* The required number of corners */
|
||||||
@ -87,6 +91,7 @@ private:
|
|||||||
SMESH::SMESH_Mesh_var myMesh;
|
SMESH::SMESH_Mesh_var myMesh;
|
||||||
SMESH_Actor* myActor;
|
SMESH_Actor* myActor;
|
||||||
SMESH::TElementSimulation* mySimulation;
|
SMESH::TElementSimulation* mySimulation;
|
||||||
|
QString myEntry;
|
||||||
|
|
||||||
int myType;
|
int myType;
|
||||||
bool myIsEditCorners;
|
bool myIsEditCorners;
|
||||||
@ -100,6 +105,10 @@ private:
|
|||||||
QTableWidget* myTable;
|
QTableWidget* myTable;
|
||||||
QCheckBox* myReverseCB;
|
QCheckBox* myReverseCB;
|
||||||
|
|
||||||
|
QGroupBox* GroupGroups;
|
||||||
|
QLabel* TextLabel_GroupName;
|
||||||
|
QComboBox* ComboBox_GroupName;
|
||||||
|
|
||||||
QGroupBox* GroupButtons;
|
QGroupBox* GroupButtons;
|
||||||
QPushButton* buttonOk;
|
QPushButton* buttonOk;
|
||||||
QPushButton* buttonCancel;
|
QPushButton* buttonCancel;
|
||||||
|
@ -30,6 +30,7 @@
|
|||||||
#include "SMESHGUI_Utils.h"
|
#include "SMESHGUI_Utils.h"
|
||||||
#include "SMESHGUI_VTKUtils.h"
|
#include "SMESHGUI_VTKUtils.h"
|
||||||
#include "SMESHGUI_MeshUtils.h"
|
#include "SMESHGUI_MeshUtils.h"
|
||||||
|
#include "SMESHGUI_GroupUtils.h"
|
||||||
#include "SMESHGUI_IdValidator.h"
|
#include "SMESHGUI_IdValidator.h"
|
||||||
|
|
||||||
#include <SMESH_Actor.h>
|
#include <SMESH_Actor.h>
|
||||||
@ -63,6 +64,7 @@
|
|||||||
// Qt includes
|
// Qt includes
|
||||||
#include <QApplication>
|
#include <QApplication>
|
||||||
#include <QButtonGroup>
|
#include <QButtonGroup>
|
||||||
|
#include <QComboBox>
|
||||||
#include <QGroupBox>
|
#include <QGroupBox>
|
||||||
#include <QLabel>
|
#include <QLabel>
|
||||||
#include <QLineEdit>
|
#include <QLineEdit>
|
||||||
@ -246,6 +248,20 @@ SMESHGUI_CreatePolyhedralVolumeDlg::SMESHGUI_CreatePolyhedralVolumeDlg( SMESHGUI
|
|||||||
GroupContentLayout->addWidget( RemoveButton, 3, 3 );
|
GroupContentLayout->addWidget( RemoveButton, 3, 3 );
|
||||||
GroupContentLayout->addWidget( Preview, 5, 0, 1, 4 );
|
GroupContentLayout->addWidget( Preview, 5, 0, 1, 4 );
|
||||||
|
|
||||||
|
/***************************************************************/
|
||||||
|
GroupGroups = new QGroupBox( tr( "SMESH_ADD_TO_GROUP" ), this );
|
||||||
|
GroupGroups->setCheckable( true );
|
||||||
|
QHBoxLayout* GroupGroupsLayout = new QHBoxLayout(GroupGroups);
|
||||||
|
GroupGroupsLayout->setSpacing(SPACING);
|
||||||
|
GroupGroupsLayout->setMargin(MARGIN);
|
||||||
|
|
||||||
|
TextLabel_GroupName = new QLabel( tr( "SMESH_GROUP" ), GroupGroups );
|
||||||
|
ComboBox_GroupName = new QComboBox( GroupGroups );
|
||||||
|
ComboBox_GroupName->setEditable( true );
|
||||||
|
|
||||||
|
GroupGroupsLayout->addWidget( TextLabel_GroupName );
|
||||||
|
GroupGroupsLayout->addWidget( ComboBox_GroupName, 1 );
|
||||||
|
|
||||||
/***************************************************************/
|
/***************************************************************/
|
||||||
GroupButtons = new QGroupBox( this );
|
GroupButtons = new QGroupBox( this );
|
||||||
QHBoxLayout* GroupButtonsLayout = new QHBoxLayout( GroupButtons );
|
QHBoxLayout* GroupButtonsLayout = new QHBoxLayout( GroupButtons );
|
||||||
@ -273,6 +289,7 @@ SMESHGUI_CreatePolyhedralVolumeDlg::SMESHGUI_CreatePolyhedralVolumeDlg( SMESHGUI
|
|||||||
/***************************************************************/
|
/***************************************************************/
|
||||||
topLayout->addWidget( ConstructorsBox );
|
topLayout->addWidget( ConstructorsBox );
|
||||||
topLayout->addWidget( GroupContent );
|
topLayout->addWidget( GroupContent );
|
||||||
|
topLayout->addWidget( GroupGroups );
|
||||||
topLayout->addWidget( GroupButtons );
|
topLayout->addWidget( GroupButtons );
|
||||||
|
|
||||||
mySelector = (SMESH::GetViewWindow( mySMESHGUI ))->GetSelector();
|
mySelector = (SMESH::GetViewWindow( mySMESHGUI ))->GetSelector();
|
||||||
@ -306,6 +323,9 @@ void SMESHGUI_CreatePolyhedralVolumeDlg::Init()
|
|||||||
myEditCurrentArgument = LineEditElements;
|
myEditCurrentArgument = LineEditElements;
|
||||||
mySMESHGUI->SetActiveDialogBox( (QDialog*)this );
|
mySMESHGUI->SetActiveDialogBox( (QDialog*)this );
|
||||||
|
|
||||||
|
/* reset "Add to group" control */
|
||||||
|
GroupGroups->setChecked( false );
|
||||||
|
|
||||||
myNbOkElements = 0;
|
myNbOkElements = 0;
|
||||||
myActor = 0;
|
myActor = 0;
|
||||||
|
|
||||||
@ -420,10 +440,14 @@ void SMESHGUI_CreatePolyhedralVolumeDlg::ClickOnPreview(bool theToggled){
|
|||||||
//=================================================================================
|
//=================================================================================
|
||||||
void SMESHGUI_CreatePolyhedralVolumeDlg::ClickOnApply()
|
void SMESHGUI_CreatePolyhedralVolumeDlg::ClickOnApply()
|
||||||
{
|
{
|
||||||
|
if( !isValid() )
|
||||||
|
return;
|
||||||
|
|
||||||
if ( myNbOkElements>0 && !mySMESHGUI->isActiveStudyLocked())
|
if ( myNbOkElements>0 && !mySMESHGUI->isActiveStudyLocked())
|
||||||
{
|
{
|
||||||
if(checkEditLine(false) == -1) {return;}
|
if(checkEditLine(false) == -1) {return;}
|
||||||
busy = true;
|
busy = true;
|
||||||
|
long anElemId = -1;
|
||||||
if (GetConstructorId() == 0)
|
if (GetConstructorId() == 0)
|
||||||
{
|
{
|
||||||
SMESH::long_array_var anIdsOfNodes = new SMESH::long_array;
|
SMESH::long_array_var anIdsOfNodes = new SMESH::long_array;
|
||||||
@ -453,7 +477,7 @@ void SMESHGUI_CreatePolyhedralVolumeDlg::ClickOnApply()
|
|||||||
try{
|
try{
|
||||||
SUIT_OverrideCursor aWaitCursor;
|
SUIT_OverrideCursor aWaitCursor;
|
||||||
SMESH::SMESH_MeshEditor_var aMeshEditor = myMesh->GetMeshEditor();
|
SMESH::SMESH_MeshEditor_var aMeshEditor = myMesh->GetMeshEditor();
|
||||||
aMeshEditor->AddPolyhedralVolume(anIdsOfNodes, aQuantities);
|
anElemId = aMeshEditor->AddPolyhedralVolume(anIdsOfNodes, aQuantities);
|
||||||
}catch(SALOME::SALOME_Exception& exc){
|
}catch(SALOME::SALOME_Exception& exc){
|
||||||
INFOS("Follow exception was cought:\n\t"<<exc.details.text);
|
INFOS("Follow exception was cought:\n\t"<<exc.details.text);
|
||||||
}catch(std::exception& exc){
|
}catch(std::exception& exc){
|
||||||
@ -474,7 +498,7 @@ void SMESHGUI_CreatePolyhedralVolumeDlg::ClickOnApply()
|
|||||||
try{
|
try{
|
||||||
SUIT_OverrideCursor aWaitCursor;
|
SUIT_OverrideCursor aWaitCursor;
|
||||||
SMESH::SMESH_MeshEditor_var aMeshEditor = myMesh->GetMeshEditor();
|
SMESH::SMESH_MeshEditor_var aMeshEditor = myMesh->GetMeshEditor();
|
||||||
aMeshEditor->AddPolyhedralVolumeByFaces(anIdsOfFaces);
|
anElemId = aMeshEditor->AddPolyhedralVolumeByFaces(anIdsOfFaces);
|
||||||
}catch(SALOME::SALOME_Exception& exc){
|
}catch(SALOME::SALOME_Exception& exc){
|
||||||
INFOS("Follow exception was cought:\n\t"<<exc.details.text);
|
INFOS("Follow exception was cought:\n\t"<<exc.details.text);
|
||||||
}catch(std::exception& exc){
|
}catch(std::exception& exc){
|
||||||
@ -483,7 +507,35 @@ void SMESHGUI_CreatePolyhedralVolumeDlg::ClickOnApply()
|
|||||||
INFOS("Unknown exception was cought !!!");
|
INFOS("Unknown exception was cought !!!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if( anElemId != -1 && GroupGroups->isChecked() ) {
|
||||||
|
SMESH::SMESH_Group_var aGroup;
|
||||||
|
QString aGroupName = ComboBox_GroupName->currentText();
|
||||||
|
SMESH::ListOfGroups aListOfGroups = *myMesh->GetGroups();
|
||||||
|
for( int i = 0, n = aListOfGroups.length(); i < n; i++ ) {
|
||||||
|
SMESH::SMESH_GroupBase_var aGroupBase = aListOfGroups[i];
|
||||||
|
if( !aGroupBase->_is_nil() ) {
|
||||||
|
SMESH::SMESH_Group_var aRefGroup = SMESH::SMESH_Group::_narrow( aGroupBase );
|
||||||
|
if( !aRefGroup->_is_nil() ) {
|
||||||
|
QString aRefGroupName( aRefGroup->GetName() );
|
||||||
|
if( aRefGroupName == aGroupName ) {
|
||||||
|
aGroup = aRefGroup; // // add node to existing group
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if( aGroup->_is_nil() ) // create new group
|
||||||
|
aGroup = SMESH::AddGroup( myMesh, SMESH::VOLUME, aGroupName );
|
||||||
|
|
||||||
|
if( !aGroup->_is_nil() ) {
|
||||||
|
SMESH::long_array_var anIdList = new SMESH::long_array;
|
||||||
|
anIdList->length( 1 );
|
||||||
|
anIdList[0] = anElemId;
|
||||||
|
aGroup->Add( anIdList.inout() );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
//SALOME_ListIO aList;
|
//SALOME_ListIO aList;
|
||||||
//mySelectionMgr->setSelectedObjects( aList );
|
//mySelectionMgr->setSelectedObjects( aList );
|
||||||
SMESH::UpdateView();
|
SMESH::UpdateView();
|
||||||
@ -663,6 +715,8 @@ void SMESHGUI_CreatePolyhedralVolumeDlg::SelectionIntoArgument()
|
|||||||
|
|
||||||
mySimulation->SetVisibility(false);
|
mySimulation->SetVisibility(false);
|
||||||
|
|
||||||
|
QString aCurrentEntry = myEntry;
|
||||||
|
|
||||||
// get selected mesh
|
// get selected mesh
|
||||||
|
|
||||||
SALOME_ListIO selected;
|
SALOME_ListIO selected;
|
||||||
@ -672,10 +726,29 @@ void SMESHGUI_CreatePolyhedralVolumeDlg::SelectionIntoArgument()
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
myEntry = selected.First()->getEntry();
|
||||||
myMesh = SMESH::GetMeshByIO( selected.First() );
|
myMesh = SMESH::GetMeshByIO( selected.First() );
|
||||||
if ( myMesh->_is_nil() )
|
if ( myMesh->_is_nil() )
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
// process groups
|
||||||
|
if ( !myMesh->_is_nil() && myEntry != aCurrentEntry ) {
|
||||||
|
ComboBox_GroupName->clear();
|
||||||
|
ComboBox_GroupName->addItem( QString() );
|
||||||
|
SMESH::ListOfGroups aListOfGroups = *myMesh->GetGroups();
|
||||||
|
for ( int i = 0, n = aListOfGroups.length(); i < n; i++ ) {
|
||||||
|
SMESH::SMESH_GroupBase_var aGroupBase = aListOfGroups[i];
|
||||||
|
if ( !aGroupBase->_is_nil() && aGroupBase->GetType() == SMESH::VOLUME ) {
|
||||||
|
SMESH::SMESH_Group_var aGroup = SMESH::SMESH_Group::_narrow( aGroupBase );
|
||||||
|
if ( !aGroup->_is_nil() ) {
|
||||||
|
QString aGroupName( aGroup->GetName() );
|
||||||
|
if ( !aGroupName.isEmpty() )
|
||||||
|
ComboBox_GroupName->addItem( aGroupName );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
myActor = SMESH::FindActorByObject(myMesh);
|
myActor = SMESH::FindActorByObject(myMesh);
|
||||||
if ( !myActor )
|
if ( !myActor )
|
||||||
return;
|
return;
|
||||||
@ -1062,3 +1135,16 @@ void SMESHGUI_CreatePolyhedralVolumeDlg::keyPressEvent( QKeyEvent* e )
|
|||||||
ClickOnHelp();
|
ClickOnHelp();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//=================================================================================
|
||||||
|
// function : isValid
|
||||||
|
// purpose :
|
||||||
|
//=================================================================================
|
||||||
|
bool SMESHGUI_CreatePolyhedralVolumeDlg::isValid()
|
||||||
|
{
|
||||||
|
if( GroupGroups->isChecked() && ComboBox_GroupName->currentText().isEmpty() ) {
|
||||||
|
SUIT_MessageBox::warning( this, tr( "SMESH_WRN_WARNING" ), tr( "GROUP_NAME_IS_EMPTY" ) );
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
@ -37,6 +37,7 @@
|
|||||||
#include CORBA_SERVER_HEADER(SMESH_Mesh)
|
#include CORBA_SERVER_HEADER(SMESH_Mesh)
|
||||||
|
|
||||||
class QButtonGroup;
|
class QButtonGroup;
|
||||||
|
class QComboBox;
|
||||||
class QGroupBox;
|
class QGroupBox;
|
||||||
class QListWidget;
|
class QListWidget;
|
||||||
class QLabel;
|
class QLabel;
|
||||||
@ -75,6 +76,8 @@ private:
|
|||||||
int GetConstructorId();
|
int GetConstructorId();
|
||||||
void displaySimulation();
|
void displaySimulation();
|
||||||
|
|
||||||
|
bool isValid();
|
||||||
|
|
||||||
int checkEditLine( bool = true ); /*! Checking for indices, return 1 if all ok, esle -1*/
|
int checkEditLine( bool = true ); /*! Checking for indices, return 1 if all ok, esle -1*/
|
||||||
|
|
||||||
SMESHGUI* mySMESHGUI; /* Current SMESHGUI object */
|
SMESHGUI* mySMESHGUI; /* Current SMESHGUI object */
|
||||||
@ -88,12 +91,16 @@ private:
|
|||||||
SMESH::SMESH_Mesh_var myMesh;
|
SMESH::SMESH_Mesh_var myMesh;
|
||||||
SMESH_Actor* myActor;
|
SMESH_Actor* myActor;
|
||||||
SMESH::TPolySimulation* mySimulation;
|
SMESH::TPolySimulation* mySimulation;
|
||||||
|
QString myEntry;
|
||||||
|
|
||||||
QGroupBox* ConstructorsBox;
|
QGroupBox* ConstructorsBox;
|
||||||
QButtonGroup* GroupConstructors;
|
QButtonGroup* GroupConstructors;
|
||||||
QRadioButton* RadioButton1;
|
QRadioButton* RadioButton1;
|
||||||
QRadioButton* RadioButton2;
|
QRadioButton* RadioButton2;
|
||||||
QCheckBox* Preview;
|
QCheckBox* Preview;
|
||||||
|
QGroupBox* GroupGroups;
|
||||||
|
QLabel* TextLabel_GroupName;
|
||||||
|
QComboBox* ComboBox_GroupName;
|
||||||
QGroupBox* GroupButtons;
|
QGroupBox* GroupButtons;
|
||||||
QPushButton* buttonOk;
|
QPushButton* buttonOk;
|
||||||
QPushButton* buttonCancel;
|
QPushButton* buttonCancel;
|
||||||
|
@ -31,6 +31,7 @@
|
|||||||
#include "SMESHGUI_Utils.h"
|
#include "SMESHGUI_Utils.h"
|
||||||
#include "SMESHGUI_VTKUtils.h"
|
#include "SMESHGUI_VTKUtils.h"
|
||||||
#include "SMESHGUI_MeshUtils.h"
|
#include "SMESHGUI_MeshUtils.h"
|
||||||
|
#include "SMESHGUI_GroupUtils.h"
|
||||||
|
|
||||||
#include <SMESH_Actor.h>
|
#include <SMESH_Actor.h>
|
||||||
#include <SMESH_ActorUtils.h>
|
#include <SMESH_ActorUtils.h>
|
||||||
@ -70,6 +71,7 @@
|
|||||||
#include <vtkPoints.h>
|
#include <vtkPoints.h>
|
||||||
|
|
||||||
// Qt includes
|
// Qt includes
|
||||||
|
#include <QComboBox>
|
||||||
#include <QGroupBox>
|
#include <QGroupBox>
|
||||||
#include <QLabel>
|
#include <QLabel>
|
||||||
#include <QPushButton>
|
#include <QPushButton>
|
||||||
@ -88,13 +90,14 @@
|
|||||||
|
|
||||||
namespace SMESH
|
namespace SMESH
|
||||||
{
|
{
|
||||||
void AddNode( SMESH::SMESH_Mesh_ptr theMesh, float x, float y, float z, const QStringList& theParameters )
|
long AddNode( SMESH::SMESH_Mesh_ptr theMesh, float x, float y, float z, const QStringList& theParameters )
|
||||||
{
|
{
|
||||||
|
long aNodeId = -1;
|
||||||
SUIT_OverrideCursor wc;
|
SUIT_OverrideCursor wc;
|
||||||
try {
|
try {
|
||||||
_PTR(SObject) aSobj = SMESH::FindSObject( theMesh );
|
_PTR(SObject) aSobj = SMESH::FindSObject( theMesh );
|
||||||
SMESH::SMESH_MeshEditor_var aMeshEditor = theMesh->GetMeshEditor();
|
SMESH::SMESH_MeshEditor_var aMeshEditor = theMesh->GetMeshEditor();
|
||||||
aMeshEditor->AddNode( x, y, z );
|
aNodeId = aMeshEditor->AddNode( x, y, z );
|
||||||
theMesh->SetParameters( theParameters.join(":").toLatin1().constData() );
|
theMesh->SetParameters( theParameters.join(":").toLatin1().constData() );
|
||||||
_PTR(Study) aStudy = GetActiveStudyDocument();
|
_PTR(Study) aStudy = GetActiveStudyDocument();
|
||||||
CORBA::Long anId = aStudy->StudyId();
|
CORBA::Long anId = aStudy->StudyId();
|
||||||
@ -111,6 +114,7 @@ namespace SMESH
|
|||||||
catch ( ... ) {
|
catch ( ... ) {
|
||||||
INFOS( "Unknown exception was cought !!!" );
|
INFOS( "Unknown exception was cought !!!" );
|
||||||
}
|
}
|
||||||
|
return aNodeId;
|
||||||
}
|
}
|
||||||
|
|
||||||
class TNodeSimulation
|
class TNodeSimulation
|
||||||
@ -277,6 +281,21 @@ SMESHGUI_NodesDlg::SMESHGUI_NodesDlg( SMESHGUI* theModule ):
|
|||||||
GroupCoordinatesLayout->addWidget( TextLabel_Z );
|
GroupCoordinatesLayout->addWidget( TextLabel_Z );
|
||||||
GroupCoordinatesLayout->addWidget( SpinBox_Z );
|
GroupCoordinatesLayout->addWidget( SpinBox_Z );
|
||||||
|
|
||||||
|
|
||||||
|
/***************************************************************/
|
||||||
|
GroupGroups = new QGroupBox( tr( "SMESH_ADD_TO_GROUP" ), this );
|
||||||
|
GroupGroups->setCheckable( true );
|
||||||
|
QHBoxLayout* GroupGroupsLayout = new QHBoxLayout(GroupGroups);
|
||||||
|
GroupGroupsLayout->setSpacing(SPACING);
|
||||||
|
GroupGroupsLayout->setMargin(MARGIN);
|
||||||
|
|
||||||
|
TextLabel_GroupName = new QLabel( tr( "SMESH_GROUP" ), GroupGroups );
|
||||||
|
ComboBox_GroupName = new QComboBox( GroupGroups );
|
||||||
|
ComboBox_GroupName->setEditable( true );
|
||||||
|
|
||||||
|
GroupGroupsLayout->addWidget( TextLabel_GroupName );
|
||||||
|
GroupGroupsLayout->addWidget( ComboBox_GroupName, 1 );
|
||||||
|
|
||||||
/***************************************************************/
|
/***************************************************************/
|
||||||
GroupButtons = new QGroupBox( this );
|
GroupButtons = new QGroupBox( this );
|
||||||
QHBoxLayout* GroupButtonsLayout = new QHBoxLayout( GroupButtons );
|
QHBoxLayout* GroupButtonsLayout = new QHBoxLayout( GroupButtons );
|
||||||
@ -303,6 +322,7 @@ SMESHGUI_NodesDlg::SMESHGUI_NodesDlg( SMESHGUI* theModule ):
|
|||||||
/***************************************************************/
|
/***************************************************************/
|
||||||
SMESHGUI_NodesDlgLayout->addWidget( GroupConstructors );
|
SMESHGUI_NodesDlgLayout->addWidget( GroupConstructors );
|
||||||
SMESHGUI_NodesDlgLayout->addWidget( GroupCoordinates );
|
SMESHGUI_NodesDlgLayout->addWidget( GroupCoordinates );
|
||||||
|
SMESHGUI_NodesDlgLayout->addWidget( GroupGroups );
|
||||||
SMESHGUI_NodesDlgLayout->addWidget( GroupButtons );
|
SMESHGUI_NodesDlgLayout->addWidget( GroupButtons );
|
||||||
|
|
||||||
myHelpFileName = "adding_nodes_and_elements_page.html#adding_nodes_anchor";
|
myHelpFileName = "adding_nodes_and_elements_page.html#adding_nodes_anchor";
|
||||||
@ -337,6 +357,9 @@ void SMESHGUI_NodesDlg::Init()
|
|||||||
SpinBox_Y->SetValue( 0.0 );
|
SpinBox_Y->SetValue( 0.0 );
|
||||||
SpinBox_Z->SetValue( 0.0 );
|
SpinBox_Z->SetValue( 0.0 );
|
||||||
|
|
||||||
|
/* reset "Add to group" control */
|
||||||
|
GroupGroups->setChecked( false );
|
||||||
|
|
||||||
mySMESHGUI->SetActiveDialogBox( this );
|
mySMESHGUI->SetActiveDialogBox( this );
|
||||||
|
|
||||||
/* signals and slots connections */
|
/* signals and slots connections */
|
||||||
@ -416,9 +439,37 @@ bool SMESHGUI_NodesDlg::ClickOnApply()
|
|||||||
aParameters << SpinBox_Z->text();
|
aParameters << SpinBox_Z->text();
|
||||||
|
|
||||||
mySimulation->SetVisibility( false );
|
mySimulation->SetVisibility( false );
|
||||||
SMESH::AddNode( myMesh, x, y, z, aParameters );
|
long aNodeId = SMESH::AddNode( myMesh, x, y, z, aParameters );
|
||||||
SMESH::SetPointRepresentation( true );
|
SMESH::SetPointRepresentation( true );
|
||||||
|
|
||||||
|
if( aNodeId != -1 && GroupGroups->isChecked() ) {
|
||||||
|
SMESH::SMESH_Group_var aGroup;
|
||||||
|
QString aGroupName = ComboBox_GroupName->currentText();
|
||||||
|
SMESH::ListOfGroups aListOfGroups = *myMesh->GetGroups();
|
||||||
|
for( int i = 0, n = aListOfGroups.length(); i < n; i++ ) {
|
||||||
|
SMESH::SMESH_GroupBase_var aGroupBase = aListOfGroups[i];
|
||||||
|
if( !aGroupBase->_is_nil() ) {
|
||||||
|
SMESH::SMESH_Group_var aRefGroup = SMESH::SMESH_Group::_narrow( aGroupBase );
|
||||||
|
if( !aRefGroup->_is_nil() ) {
|
||||||
|
QString aRefGroupName( aRefGroup->GetName() );
|
||||||
|
if( aRefGroupName == aGroupName ) {
|
||||||
|
aGroup = aRefGroup; // // add node to existing group
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if( aGroup->_is_nil() ) // create new group
|
||||||
|
aGroup = SMESH::AddGroup( myMesh, SMESH::NODE, aGroupName );
|
||||||
|
|
||||||
|
if( !aGroup->_is_nil() ) {
|
||||||
|
SMESH::long_array_var anIdList = new SMESH::long_array;
|
||||||
|
anIdList->length( 1 );
|
||||||
|
anIdList[0] = aNodeId;
|
||||||
|
aGroup->Add( anIdList.inout() );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// select myMesh
|
// select myMesh
|
||||||
SALOME_ListIO aList;
|
SALOME_ListIO aList;
|
||||||
mySelectionMgr->selectedObjects( aList );
|
mySelectionMgr->selectedObjects( aList );
|
||||||
@ -500,10 +551,13 @@ void SMESHGUI_NodesDlg::SelectionIntoArgument()
|
|||||||
mySimulation->SetVisibility( false );
|
mySimulation->SetVisibility( false );
|
||||||
SMESH::SetPointRepresentation( true );
|
SMESH::SetPointRepresentation( true );
|
||||||
|
|
||||||
|
QString aCurrentEntry = myEntry;
|
||||||
|
|
||||||
const SALOME_ListIO& aList = mySelector->StoredIObjects();
|
const SALOME_ListIO& aList = mySelector->StoredIObjects();
|
||||||
if ( aList.Extent() == 1 ) {
|
if ( aList.Extent() == 1 ) {
|
||||||
Handle(SALOME_InteractiveObject) anIO = aList.First();
|
Handle(SALOME_InteractiveObject) anIO = aList.First();
|
||||||
if ( anIO->hasEntry() ) {
|
if ( anIO->hasEntry() ) {
|
||||||
|
myEntry = anIO->getEntry();
|
||||||
myMesh = SMESH::GetMeshByIO( anIO );
|
myMesh = SMESH::GetMeshByIO( anIO );
|
||||||
if ( myMesh->_is_nil() ) return;
|
if ( myMesh->_is_nil() ) return;
|
||||||
QString aText;
|
QString aText;
|
||||||
@ -523,6 +577,24 @@ void SMESHGUI_NodesDlg::SelectionIntoArgument()
|
|||||||
SpinBox_Z->GetValue() );
|
SpinBox_Z->GetValue() );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// process groups
|
||||||
|
if ( !myMesh->_is_nil() && myEntry != aCurrentEntry ) {
|
||||||
|
ComboBox_GroupName->clear();
|
||||||
|
ComboBox_GroupName->addItem( QString() );
|
||||||
|
SMESH::ListOfGroups aListOfGroups = *myMesh->GetGroups();
|
||||||
|
for( int i = 0, n = aListOfGroups.length(); i < n; i++ ) {
|
||||||
|
SMESH::SMESH_GroupBase_var aGroupBase = aListOfGroups[i];
|
||||||
|
if ( !aGroupBase->_is_nil() && aGroupBase->GetType() == SMESH::NODE ) {
|
||||||
|
SMESH::SMESH_Group_var aGroup = SMESH::SMESH_Group::_narrow( aGroupBase );
|
||||||
|
if ( !aGroup->_is_nil() ) {
|
||||||
|
QString aGroupName( aGroup->GetName() );
|
||||||
|
if ( !aGroupName.isEmpty() )
|
||||||
|
ComboBox_GroupName->addItem( aGroupName );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//=================================================================================
|
//=================================================================================
|
||||||
@ -623,5 +695,10 @@ bool SMESHGUI_NodesDlg::isValid()
|
|||||||
SUIT_MessageBox::critical( this, tr( "SMESH_ERROR" ), str );
|
SUIT_MessageBox::critical( this, tr( "SMESH_ERROR" ), str );
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if( GroupGroups->isChecked() && ComboBox_GroupName->currentText().isEmpty() ) {
|
||||||
|
SUIT_MessageBox::warning( this, tr( "SMESH_WRN_WARNING" ), tr( "GROUP_NAME_IS_EMPTY" ) );
|
||||||
|
return false;
|
||||||
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -36,6 +36,7 @@
|
|||||||
#include <SALOMEconfig.h>
|
#include <SALOMEconfig.h>
|
||||||
#include CORBA_SERVER_HEADER(SMESH_Mesh)
|
#include CORBA_SERVER_HEADER(SMESH_Mesh)
|
||||||
|
|
||||||
|
class QComboBox;
|
||||||
class QGroupBox;
|
class QGroupBox;
|
||||||
class QLabel;
|
class QLabel;
|
||||||
class QPushButton;
|
class QPushButton;
|
||||||
@ -70,6 +71,7 @@ private:
|
|||||||
|
|
||||||
SMESH::SMESH_Mesh_var myMesh;
|
SMESH::SMESH_Mesh_var myMesh;
|
||||||
SMESH::TNodeSimulation* mySimulation;
|
SMESH::TNodeSimulation* mySimulation;
|
||||||
|
QString myEntry;
|
||||||
|
|
||||||
void Init();
|
void Init();
|
||||||
void enterEvent( QEvent* );
|
void enterEvent( QEvent* );
|
||||||
@ -90,6 +92,10 @@ private:
|
|||||||
QLabel* TextLabel_Y;
|
QLabel* TextLabel_Y;
|
||||||
QLabel* TextLabel_Z;
|
QLabel* TextLabel_Z;
|
||||||
|
|
||||||
|
QGroupBox* GroupGroups;
|
||||||
|
QLabel* TextLabel_GroupName;
|
||||||
|
QComboBox* ComboBox_GroupName;
|
||||||
|
|
||||||
QGroupBox* GroupButtons;
|
QGroupBox* GroupButtons;
|
||||||
QPushButton* buttonApply;
|
QPushButton* buttonApply;
|
||||||
QPushButton* buttonOk;
|
QPushButton* buttonOk;
|
||||||
|
@ -742,6 +742,11 @@ Please, select a mesh and try again</translation>
|
|||||||
<source>MULTI_BORDERS</source>
|
<source>MULTI_BORDERS</source>
|
||||||
<translation>Borders at Multi-Connections</translation>
|
<translation>Borders at Multi-Connections</translation>
|
||||||
</message>
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>GROUP_NAME_IS_EMPTY</source>
|
||||||
|
<translation>Name of group is empty
|
||||||
|
Please input a name of new group or choose the existing one</translation>
|
||||||
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<source>NODE_ID</source>
|
<source>NODE_ID</source>
|
||||||
<translation>Node ID</translation>
|
<translation>Node ID</translation>
|
||||||
@ -864,6 +869,10 @@ Please enter correct values and try again</translation>
|
|||||||
<source>SMESH_ADD_TETRAS_TITLE</source>
|
<source>SMESH_ADD_TETRAS_TITLE</source>
|
||||||
<translation>Add Tetrahedron</translation>
|
<translation>Add Tetrahedron</translation>
|
||||||
</message>
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>SMESH_ADD_TO_GROUP</source>
|
||||||
|
<translation>Add to group</translation>
|
||||||
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<source>SMESH_ADD_TRIANGLE</source>
|
<source>SMESH_ADD_TRIANGLE</source>
|
||||||
<translation>Add Triangle</translation>
|
<translation>Add Triangle</translation>
|
||||||
|