mirror of
https://git.salome-platform.org/gitpub/modules/smesh.git
synced 2025-01-14 02:30:33 +05:00
redesigned MeshInfo panel
This commit is contained in:
parent
2e38d9bd0b
commit
f356e699a0
@ -3432,6 +3432,9 @@ SMESHGUI_CtrlInfo::SMESHGUI_CtrlInfo( QWidget* parent ): SMESHGUI_Info( parent )
|
|||||||
QIcon aComputeIcon( SUIT_Session::session()->resourceMgr()->loadPixmap( "SMESH", tr( "ICON_COMPUTE" ) ) );
|
QIcon aComputeIcon( SUIT_Session::session()->resourceMgr()->loadPixmap( "SMESH", tr( "ICON_COMPUTE" ) ) );
|
||||||
SMESH::FilterManager_var aFilterMgr = SMESH::GetFilterManager();
|
SMESH::FilterManager_var aFilterMgr = SMESH::GetFilterManager();
|
||||||
|
|
||||||
|
// QToolBox with MeshInfo
|
||||||
|
myMeshTB = new QToolBox(this);
|
||||||
|
|
||||||
// name
|
// name
|
||||||
QLabel* aNameLab = createLabel( tr( "NAME_LAB" ), this, Bold );
|
QLabel* aNameLab = createLabel( tr( "NAME_LAB" ), this, Bold );
|
||||||
QLabel* aName = createField( this, "ctrlName" );
|
QLabel* aName = createField( this, "ctrlName" );
|
||||||
@ -3547,50 +3550,82 @@ SMESHGUI_CtrlInfo::SMESHGUI_CtrlInfo( QWidget* parent ): SMESHGUI_Info( parent )
|
|||||||
connect( aOverContVolumesBtn,SIGNAL( clicked() ), this, SLOT( computeOverConstrainedVolumesInfo() ) );
|
connect( aOverContVolumesBtn,SIGNAL( clicked() ), this, SLOT( computeOverConstrainedVolumesInfo() ) );
|
||||||
connect( myToleranceWidget, SIGNAL( valueChanged( double ) ), this, SLOT( setTolerance( double ) ) );
|
connect( myToleranceWidget, SIGNAL( valueChanged( double ) ), this, SLOT( setTolerance( double ) ) );
|
||||||
|
|
||||||
l->addWidget( aNameLab, 0, 0 ); //0
|
l->addWidget( aNameLab, 0, 0 ); //0
|
||||||
l->addWidget( aName, 0, 1, 1, 2 ); //1
|
l->addWidget( aName, 0, 1 ); //1
|
||||||
l->addWidget( aNodesLab, 1, 0, 1, 3 ); //2
|
|
||||||
l->addWidget( aNodesFreeLab, 2, 0 ); //3
|
|
||||||
l->addWidget( aNodesFree, 2, 1 ); //4
|
|
||||||
l->addWidget( aFreeNodesBtn, 2, 2 ); //5
|
|
||||||
l->addWidget( aNodesNbConnLab, 3, 0 ); //6
|
|
||||||
l->addWidget( aNodesNbConn, 3, 1 ); //7
|
|
||||||
l->addWidget( aNodesNbConnBtn, 3, 2 ); //8
|
|
||||||
l->addWidget( aNodesDoubleLab, 4, 0 ); //9
|
|
||||||
l->addWidget( aNodesDouble, 4, 1 ); //10
|
|
||||||
l->addWidget( aDoubleNodesBtn, 4, 2 ); //11
|
|
||||||
l->addWidget( aToleranceLab, 5, 0 ); //12
|
|
||||||
l->addWidget( myToleranceWidget, 5, 1 ); //13
|
|
||||||
l->addWidget( anEdgesLab, 6, 0, 1, 3 ); //14
|
|
||||||
l->addWidget( anEdgesDoubleLab, 7, 0 ); //15
|
|
||||||
l->addWidget( anEdgesDouble, 7, 1 ); //16
|
|
||||||
l->addWidget( aDoubleEdgesBtn, 7, 2 ); //17
|
|
||||||
l->addWidget( aFacesLab, 8, 0, 1, 3 ); //18
|
|
||||||
l->addWidget( aFacesDoubleLab, 9, 0 ); //19
|
|
||||||
l->addWidget( aFacesDouble, 9, 1 ); //20
|
|
||||||
l->addWidget( aDoubleFacesBtn, 9, 2 ); //21
|
|
||||||
l->addWidget( aFacesOverLab, 10, 0 ); //22
|
|
||||||
l->addWidget( aFacesOver, 10, 1 ); //23
|
|
||||||
l->addWidget( aOverContFacesBtn, 10, 2 ); //24
|
|
||||||
l->addWidget( anAspectRatioLab, 11, 0 ); //25
|
|
||||||
l->addWidget( aComputeFaceBtn, 11, 2 ); //26
|
|
||||||
l->addWidget( myPlot, 12, 0, 1, 3 );//27
|
|
||||||
l->addWidget( aVolumesLab, 13, 0, 1, 3 );//28
|
|
||||||
l->addWidget( aVolumesDoubleLab, 14, 0 ); //29
|
|
||||||
l->addWidget( aVolumesDouble, 14, 1 ); //30
|
|
||||||
l->addWidget( aDoubleVolumesBtn, 14, 2 ); //31
|
|
||||||
l->addWidget( aVolumesOverLab, 15, 0 ); //32
|
|
||||||
l->addWidget( aVolumesOver, 15, 1 ); //33
|
|
||||||
l->addWidget( aOverContVolumesBtn,15, 2 ); //34
|
|
||||||
l->addWidget( anAspectRatio3DLab, 16, 0 ); //35
|
|
||||||
l->addWidget( aComputeVolumeBtn, 16, 2 ); //36
|
|
||||||
l->addWidget( myPlot3D, 17, 0, 1, 3 );//37
|
|
||||||
|
|
||||||
l->setColumnStretch( 0, 0 );
|
// Node group
|
||||||
l->setColumnStretch( 1, 5 );
|
QWidget* NodeGrp = new QWidget();
|
||||||
l->setRowStretch ( 12, 5 );
|
QGridLayout* NodeLayout = new QGridLayout(NodeGrp);
|
||||||
l->setRowStretch ( 17, 5 );
|
NodeLayout->setSpacing(SPACING); NodeLayout->setMargin(MARGIN);
|
||||||
l->setRowStretch ( 18, 1 );
|
|
||||||
|
NodeLayout->addWidget( aNodesFreeLab, 0, 0 );
|
||||||
|
NodeLayout->addWidget( aNodesFree, 0, 1 );
|
||||||
|
NodeLayout->addWidget( aFreeNodesBtn, 0, 2 );
|
||||||
|
NodeLayout->addWidget( aNodesNbConnLab, 1, 0 );
|
||||||
|
NodeLayout->addWidget( aNodesNbConn, 1, 1 );
|
||||||
|
NodeLayout->addWidget( aNodesNbConnBtn, 1, 2 );
|
||||||
|
NodeLayout->addWidget( aNodesDoubleLab, 2, 0 );
|
||||||
|
NodeLayout->addWidget( aNodesDouble, 2, 1 );
|
||||||
|
NodeLayout->addWidget( aDoubleNodesBtn, 2, 2 );
|
||||||
|
NodeLayout->addWidget( aToleranceLab, 3, 0 );
|
||||||
|
NodeLayout->addWidget( myToleranceWidget, 3, 1 );
|
||||||
|
NodeLayout->addWidget( myToleranceWidget, 3, 1 );
|
||||||
|
NodeLayout->setRowStretch(4, 5);
|
||||||
|
|
||||||
|
myMeshTB->addItem(NodeGrp, aNodesLab->text());
|
||||||
|
aNodesLab->setVisible(false);
|
||||||
|
|
||||||
|
// Edge group
|
||||||
|
QWidget* EdgeGrp = new QWidget();
|
||||||
|
QGridLayout* EdgeLayout = new QGridLayout(EdgeGrp);
|
||||||
|
EdgeLayout->setSpacing(SPACING); EdgeLayout->setMargin(MARGIN);
|
||||||
|
|
||||||
|
EdgeLayout->addWidget( anEdgesDoubleLab, 0, 0 );
|
||||||
|
EdgeLayout->addWidget( anEdgesDouble, 0, 1 );
|
||||||
|
EdgeLayout->addWidget( aDoubleEdgesBtn, 0, 2 );
|
||||||
|
EdgeLayout->setRowStretch(1, 5);
|
||||||
|
|
||||||
|
myMeshTB->addItem(EdgeGrp, anEdgesLab->text());
|
||||||
|
anEdgesLab->setVisible(false);
|
||||||
|
|
||||||
|
// Face group
|
||||||
|
QWidget* FaceGrp = new QWidget();
|
||||||
|
QGridLayout* FaceLayout = new QGridLayout(FaceGrp);
|
||||||
|
FaceLayout->setSpacing(SPACING); FaceLayout->setMargin(MARGIN);
|
||||||
|
|
||||||
|
FaceLayout->addWidget( aFacesDoubleLab, 0, 0 );
|
||||||
|
FaceLayout->addWidget( aFacesDouble, 0, 1 );
|
||||||
|
FaceLayout->addWidget( aDoubleFacesBtn, 0, 2 );
|
||||||
|
FaceLayout->addWidget( aFacesOverLab, 1, 0 );
|
||||||
|
FaceLayout->addWidget( aFacesOver, 1, 1 );
|
||||||
|
FaceLayout->addWidget( aOverContFacesBtn, 1, 2 );
|
||||||
|
FaceLayout->addWidget( anAspectRatioLab, 2, 0 );
|
||||||
|
FaceLayout->addWidget( aComputeFaceBtn, 2, 2 );
|
||||||
|
FaceLayout->addWidget( myPlot, 3, 0, 1, 3 );
|
||||||
|
|
||||||
|
myMeshTB->addItem(FaceGrp, aFacesLab->text());
|
||||||
|
aFacesLab->setVisible(false);
|
||||||
|
|
||||||
|
// Volume group
|
||||||
|
QWidget* VolumeGrp = new QWidget();
|
||||||
|
QGridLayout* VolumeLayout = new QGridLayout(VolumeGrp);
|
||||||
|
VolumeLayout->setSpacing(SPACING); VolumeLayout->setMargin(MARGIN);
|
||||||
|
|
||||||
|
VolumeLayout->addWidget( aVolumesDoubleLab, 0, 0 );
|
||||||
|
VolumeLayout->addWidget( aVolumesDouble, 0, 1 );
|
||||||
|
VolumeLayout->addWidget( aDoubleVolumesBtn, 0, 2 );
|
||||||
|
VolumeLayout->addWidget( aVolumesOverLab, 1, 0 );
|
||||||
|
VolumeLayout->addWidget( aVolumesOver, 1, 1 );
|
||||||
|
VolumeLayout->addWidget( aOverContVolumesBtn,1, 2 );
|
||||||
|
VolumeLayout->addWidget( anAspectRatio3DLab, 2, 0 );
|
||||||
|
VolumeLayout->addWidget( aComputeVolumeBtn, 2, 2 );
|
||||||
|
VolumeLayout->addWidget( myPlot3D, 3, 0, 1, 3 );
|
||||||
|
|
||||||
|
myMeshTB->addItem(VolumeGrp, aVolumesLab->text());
|
||||||
|
aVolumesLab->setVisible(false);
|
||||||
|
|
||||||
|
l->addWidget( myMeshTB, 1, 0, 1, 2 ); //2
|
||||||
|
l->setRowStretch( 2, 5 );
|
||||||
|
|
||||||
clearInternal();
|
clearInternal();
|
||||||
}
|
}
|
||||||
@ -3673,8 +3708,8 @@ void SMESHGUI_CtrlInfo::showInfo( const SMESH::SelectionProxy& proxy )
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
for( int i=2; i<=13; i++)
|
myMeshTB->setItemEnabled(0, false );
|
||||||
dynamic_cast<QGridLayout*>(layout())->itemAt(i)->widget()->setVisible( false );
|
myMeshTB->widget(0)->setVisible( false );
|
||||||
}
|
}
|
||||||
|
|
||||||
// edges info
|
// edges info
|
||||||
@ -3686,8 +3721,8 @@ void SMESHGUI_CtrlInfo::showInfo( const SMESH::SelectionProxy& proxy )
|
|||||||
myButtons[3]->setEnabled( true );
|
myButtons[3]->setEnabled( true );
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
for( int i=14; i<=17; i++)
|
myMeshTB->setItemEnabled(1, false );
|
||||||
dynamic_cast<QGridLayout*>(layout())->itemAt(i)->widget()->setVisible( false );
|
myMeshTB->widget(1)->setVisible( false );
|
||||||
}
|
}
|
||||||
|
|
||||||
// faces info
|
// faces info
|
||||||
@ -3705,14 +3740,10 @@ void SMESHGUI_CtrlInfo::showInfo( const SMESH::SelectionProxy& proxy )
|
|||||||
myButtons[5]->setEnabled( true );
|
myButtons[5]->setEnabled( true );
|
||||||
myButtons[6]->setEnabled( true );
|
myButtons[6]->setEnabled( true );
|
||||||
}
|
}
|
||||||
#ifdef DISABLE_PLOT2DVIEWER
|
|
||||||
for( int i=25; i<=27; i++)
|
|
||||||
dynamic_cast<QGridLayout*>(layout())->itemAt(i)->widget()->setVisible( false );
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
for( int i=18; i<=27; i++)
|
myMeshTB->setItemEnabled(2, false );
|
||||||
dynamic_cast<QGridLayout*>(layout())->itemAt(i)->widget()->setVisible( false );
|
myMeshTB->widget(2)->setVisible( false );
|
||||||
}
|
}
|
||||||
|
|
||||||
// volumes info
|
// volumes info
|
||||||
@ -3730,15 +3761,15 @@ void SMESHGUI_CtrlInfo::showInfo( const SMESH::SelectionProxy& proxy )
|
|||||||
myButtons[8]->setEnabled( true );
|
myButtons[8]->setEnabled( true );
|
||||||
myButtons[9]->setEnabled( true );
|
myButtons[9]->setEnabled( true );
|
||||||
}
|
}
|
||||||
#ifdef DISABLE_PLOT2DVIEWER
|
|
||||||
for( int i=35; i<=37; i++)
|
|
||||||
dynamic_cast<QGridLayout*>(layout())->itemAt(i)->widget()->setVisible( false );
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
for( int i=28; i<=37; i++)
|
myMeshTB->setItemEnabled(3, false );
|
||||||
dynamic_cast<QGridLayout*>(layout())->itemAt(i)->widget()->setVisible( false );
|
myMeshTB->widget(3)->setVisible( false );
|
||||||
}
|
}
|
||||||
|
myMeshTB->setCurrentIndex(0);
|
||||||
|
myMeshTB->setVisible( (nbNodes + nbElemsByType[ SMESH::EDGE ] +
|
||||||
|
nbElemsByType[ SMESH::FACE ] +
|
||||||
|
nbElemsByType[ SMESH::VOLUME ]) > 0 );
|
||||||
}
|
}
|
||||||
|
|
||||||
//================================================================================
|
//================================================================================
|
||||||
@ -3892,8 +3923,10 @@ void SMESHGUI_CtrlInfo::computeAspectRatio3D()
|
|||||||
*/
|
*/
|
||||||
void SMESHGUI_CtrlInfo::clearInternal()
|
void SMESHGUI_CtrlInfo::clearInternal()
|
||||||
{
|
{
|
||||||
for( int i=0; i<=37; i++)
|
for (int i=0; i<=3;i++) {
|
||||||
dynamic_cast<QGridLayout*>(layout())->itemAt(i)->widget()->setVisible( true );
|
myMeshTB->setItemEnabled(i, true );
|
||||||
|
myMeshTB->widget(i)->setVisible( true );
|
||||||
|
}
|
||||||
for( int i=0; i<=9; i++)
|
for( int i=0; i<=9; i++)
|
||||||
myButtons[i]->setEnabled( false );
|
myButtons[i]->setEnabled( false );
|
||||||
myPlot->detachItems();
|
myPlot->detachItems();
|
||||||
|
@ -36,6 +36,7 @@
|
|||||||
#include <QList>
|
#include <QList>
|
||||||
#include <QMap>
|
#include <QMap>
|
||||||
#include <QSet>
|
#include <QSet>
|
||||||
|
#include <QToolBox>
|
||||||
|
|
||||||
#include <SALOMEconfig.h>
|
#include <SALOMEconfig.h>
|
||||||
#include CORBA_SERVER_HEADER(SMESH_Filter)
|
#include CORBA_SERVER_HEADER(SMESH_Filter)
|
||||||
@ -345,6 +346,7 @@ private:
|
|||||||
ObjectType myObjectType;
|
ObjectType myObjectType;
|
||||||
SMESHGUI_SpinBox* myToleranceWidget;
|
SMESHGUI_SpinBox* myToleranceWidget;
|
||||||
QList<QLabel*> myWidgets;
|
QList<QLabel*> myWidgets;
|
||||||
|
QToolBox* myMeshTB;
|
||||||
QwtPlot* myPlot;
|
QwtPlot* myPlot;
|
||||||
QwtPlot* myPlot3D;
|
QwtPlot* myPlot3D;
|
||||||
QList<QAbstractButton*> myButtons;
|
QList<QAbstractButton*> myButtons;
|
||||||
|
Loading…
Reference in New Issue
Block a user