mirror of
https://git.salome-platform.org/gitpub/modules/smesh.git
synced 2025-01-18 16:00:35 +05:00
0021542: EDF 1699 SMESH: Reorient a group of faces
+ SMESHGUI_ReorientFacesDlg.h \
This commit is contained in:
parent
e42414f211
commit
356b0f81d3
@ -96,6 +96,7 @@ salomeinclude_HEADERS = \
|
|||||||
SMESHGUI_FileValidator.h \
|
SMESHGUI_FileValidator.h \
|
||||||
SMESHGUI_CopyMeshDlg.h \
|
SMESHGUI_CopyMeshDlg.h \
|
||||||
SMESHGUI_PreviewDlg.h \
|
SMESHGUI_PreviewDlg.h \
|
||||||
|
SMESHGUI_ReorientFacesDlg.h \
|
||||||
SMESH_SMESHGUI.hxx
|
SMESH_SMESHGUI.hxx
|
||||||
|
|
||||||
# Libraries targets
|
# Libraries targets
|
||||||
@ -171,7 +172,8 @@ dist_libSMESH_la_SOURCES = \
|
|||||||
SMESHGUI_MeshOrderOp.cxx \
|
SMESHGUI_MeshOrderOp.cxx \
|
||||||
SMESHGUI_CopyMeshDlg.cxx \
|
SMESHGUI_CopyMeshDlg.cxx \
|
||||||
SMESHGUI_FileValidator.cxx \
|
SMESHGUI_FileValidator.cxx \
|
||||||
SMESHGUI_PreviewDlg.cxx
|
SMESHGUI_PreviewDlg.cxx \
|
||||||
|
SMESHGUI_ReorientFacesDlg.cxx
|
||||||
|
|
||||||
MOC_FILES = \
|
MOC_FILES = \
|
||||||
SMESHGUI_moc.cxx \
|
SMESHGUI_moc.cxx \
|
||||||
@ -230,7 +232,8 @@ MOC_FILES = \
|
|||||||
SMESHGUI_MeshOrderDlg_moc.cxx \
|
SMESHGUI_MeshOrderDlg_moc.cxx \
|
||||||
SMESHGUI_CopyMeshDlg_moc.cxx \
|
SMESHGUI_CopyMeshDlg_moc.cxx \
|
||||||
SMESHGUI_MeshOrderOp_moc.cxx \
|
SMESHGUI_MeshOrderOp_moc.cxx \
|
||||||
SMESHGUI_PreviewDlg_moc.cxx
|
SMESHGUI_PreviewDlg_moc.cxx \
|
||||||
|
SMESHGUI_ReorientFacesDlg_moc.cxx
|
||||||
|
|
||||||
nodist_libSMESH_la_SOURCES= \
|
nodist_libSMESH_la_SOURCES= \
|
||||||
$(MOC_FILES)
|
$(MOC_FILES)
|
||||||
|
@ -76,6 +76,7 @@
|
|||||||
#include "SMESHGUI_TransparencyDlg.h"
|
#include "SMESHGUI_TransparencyDlg.h"
|
||||||
#include "SMESHGUI_DuplicateNodesDlg.h"
|
#include "SMESHGUI_DuplicateNodesDlg.h"
|
||||||
#include "SMESHGUI_CopyMeshDlg.h"
|
#include "SMESHGUI_CopyMeshDlg.h"
|
||||||
|
#include "SMESHGUI_ReorientFacesDlg.h"
|
||||||
|
|
||||||
#include "SMESHGUI_Utils.h"
|
#include "SMESHGUI_Utils.h"
|
||||||
#include "SMESHGUI_MeshUtils.h"
|
#include "SMESHGUI_MeshUtils.h"
|
||||||
@ -2331,12 +2332,6 @@ bool SMESHGUI::OnGUIEvent( int theCommandID )
|
|||||||
case 711: // PRECOMPUTE MESH
|
case 711: // PRECOMPUTE MESH
|
||||||
case 712: // EVALUATE MESH
|
case 712: // EVALUATE MESH
|
||||||
case 713: // MESH ORDER
|
case 713: // MESH ORDER
|
||||||
{
|
|
||||||
if (checkLock(aStudy)) break;
|
|
||||||
startOperation( theCommandID );
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
|
|
||||||
case 702: // Create mesh
|
case 702: // Create mesh
|
||||||
case 703: // Create sub-mesh
|
case 703: // Create sub-mesh
|
||||||
case 704: // Edit mesh/sub-mesh
|
case 704: // Edit mesh/sub-mesh
|
||||||
@ -2481,26 +2476,11 @@ bool SMESHGUI::OnGUIEvent( int theCommandID )
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case 417: // Convert mesh to quadratic
|
case 417: // Convert mesh to quadratic
|
||||||
{
|
|
||||||
startOperation( 417 );
|
|
||||||
/* if (checkLock(aStudy)) break;
|
|
||||||
if (vtkwnd) {
|
|
||||||
EmitSignalDeactivateDialog();
|
|
||||||
new SMESHGUI_ConvToQuadDlg();
|
|
||||||
} else {
|
|
||||||
SUIT_MessageBox::warning(desktop(),
|
|
||||||
tr("SMESH_WRN_WARNING"), tr("SMESH_WRN_VIEWER_VTK"));
|
|
||||||
}*/
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case 418: // create 2D mesh from 3D
|
case 418: // create 2D mesh from 3D
|
||||||
{
|
case 420: // Reorient faces
|
||||||
startOperation( 418 );
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case 806: // CREATE GEO GROUP
|
case 806: // CREATE GEO GROUP
|
||||||
{
|
{
|
||||||
startOperation( 806 );
|
startOperation( theCommandID );
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case 801: // CREATE GROUP
|
case 801: // CREATE GROUP
|
||||||
@ -3558,6 +3538,7 @@ void SMESHGUI::initialize( CAM_Application* app )
|
|||||||
createSMESHAction( 417, "CONV_TO_QUAD", "ICON_CONV_TO_QUAD" );
|
createSMESHAction( 417, "CONV_TO_QUAD", "ICON_CONV_TO_QUAD" );
|
||||||
createSMESHAction( 418, "2D_FROM_3D", "ICON_2D_FROM_3D" );
|
createSMESHAction( 418, "2D_FROM_3D", "ICON_2D_FROM_3D" );
|
||||||
createSMESHAction( 419, "SPLIT_TO_TETRA", "ICON_SPLIT_TO_TETRA" );
|
createSMESHAction( 419, "SPLIT_TO_TETRA", "ICON_SPLIT_TO_TETRA" );
|
||||||
|
createSMESHAction( 420, "REORIENT_2D", "ICON_REORIENT_2D" );
|
||||||
createSMESHAction( 200, "RESET" );
|
createSMESHAction( 200, "RESET" );
|
||||||
createSMESHAction( 201, "SCALAR_BAR_PROP" );
|
createSMESHAction( 201, "SCALAR_BAR_PROP" );
|
||||||
createSMESHAction( 2021, "SAVE_DISTRIBUTION" );
|
createSMESHAction( 2021, "SAVE_DISTRIBUTION" );
|
||||||
@ -3748,6 +3729,7 @@ void SMESHGUI::initialize( CAM_Application* app )
|
|||||||
createMenu( 407, modifyId, -1 );
|
createMenu( 407, modifyId, -1 );
|
||||||
createMenu( 408, modifyId, -1 );
|
createMenu( 408, modifyId, -1 );
|
||||||
createMenu( 409, modifyId, -1 );
|
createMenu( 409, modifyId, -1 );
|
||||||
|
createMenu( 420, modifyId, -1 );
|
||||||
createMenu( 410, modifyId, -1 );
|
createMenu( 410, modifyId, -1 );
|
||||||
createMenu( 411, modifyId, -1 );
|
createMenu( 411, modifyId, -1 );
|
||||||
createMenu( 419, modifyId, -1 );
|
createMenu( 419, modifyId, -1 );
|
||||||
@ -3869,6 +3851,7 @@ void SMESHGUI::initialize( CAM_Application* app )
|
|||||||
createTool( 407, modifyTb );
|
createTool( 407, modifyTb );
|
||||||
createTool( 408, modifyTb );
|
createTool( 408, modifyTb );
|
||||||
createTool( 409, modifyTb );
|
createTool( 409, modifyTb );
|
||||||
|
createTool( 420, modifyTb );
|
||||||
createTool( 410, modifyTb );
|
createTool( 410, modifyTb );
|
||||||
createTool( 411, modifyTb );
|
createTool( 411, modifyTb );
|
||||||
createTool( 419, modifyTb );
|
createTool( 419, modifyTb );
|
||||||
@ -4972,6 +4955,9 @@ LightApp_Operation* SMESHGUI::createOperation( const int id ) const
|
|||||||
case 418: // create 2D mesh as boundary on 3D
|
case 418: // create 2D mesh as boundary on 3D
|
||||||
op = new SMESHGUI_Make2DFrom3DOp();
|
op = new SMESHGUI_Make2DFrom3DOp();
|
||||||
break;
|
break;
|
||||||
|
case 420: // Reorient faces
|
||||||
|
op = new SMESHGUI_ReorientFacesOp();
|
||||||
|
break;
|
||||||
case 701: // Compute mesh
|
case 701: // Compute mesh
|
||||||
op = new SMESHGUI_ComputeOp();
|
op = new SMESHGUI_ComputeOp();
|
||||||
break;
|
break;
|
||||||
|
852
src/SMESHGUI/SMESHGUI_ReorientFacesDlg.cxx
Normal file
852
src/SMESHGUI/SMESHGUI_ReorientFacesDlg.cxx
Normal file
@ -0,0 +1,852 @@
|
|||||||
|
// Copyright (C) 2007-2012 CEA/DEN, EDF R&D, OPEN CASCADE
|
||||||
|
//
|
||||||
|
// Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
|
||||||
|
// CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
|
||||||
|
//
|
||||||
|
// This library is free software; you can redistribute it and/or
|
||||||
|
// modify it under the terms of the GNU Lesser General Public
|
||||||
|
// License as published by the Free Software Foundation; either
|
||||||
|
// version 2.1 of the License.
|
||||||
|
//
|
||||||
|
// This library is distributed in the hope that it will be useful,
|
||||||
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||||
|
// Lesser General Public License for more details.
|
||||||
|
//
|
||||||
|
// You should have received a copy of the GNU Lesser General Public
|
||||||
|
// License along with this library; if not, write to the Free Software
|
||||||
|
// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
|
//
|
||||||
|
// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
|
||||||
|
//
|
||||||
|
|
||||||
|
// File : SMESHGUI_ReorientFacesDlg.cxx
|
||||||
|
// Author : Edward AGAPOV, Open CASCADE S.A.S.
|
||||||
|
// SMESH includes
|
||||||
|
//
|
||||||
|
#include "SMESHGUI_ReorientFacesDlg.h"
|
||||||
|
|
||||||
|
#include "SMESHGUI.h"
|
||||||
|
#include "SMESHGUI_IdValidator.h"
|
||||||
|
#include "SMESHGUI_MeshUtils.h"
|
||||||
|
#include "SMESHGUI_VTKUtils.h"
|
||||||
|
#include "SMESHGUI_SpinBox.h"
|
||||||
|
#include "SMESHGUI_MeshEditPreview.h"
|
||||||
|
|
||||||
|
#include <SMDS_Mesh.hxx>
|
||||||
|
#include <SMESH_Actor.h>
|
||||||
|
#include <SMESH_ActorUtils.h>
|
||||||
|
#include <SMESH_NumberFilter.hxx>
|
||||||
|
#include <SMESH_LogicalFilter.hxx>
|
||||||
|
#include <SMESH_TypeFilter.hxx>
|
||||||
|
|
||||||
|
// SALOME GEOM includes
|
||||||
|
#include <GEOMBase.h>
|
||||||
|
|
||||||
|
// SALOME GUI includes
|
||||||
|
#include <LightApp_SelectionMgr.h>
|
||||||
|
#include <SALOME_ListIO.hxx>
|
||||||
|
#include <SALOME_ListIteratorOfListIO.hxx>
|
||||||
|
#include <SUIT_Desktop.h>
|
||||||
|
#include <SUIT_MessageBox.h>
|
||||||
|
#include <SUIT_OverrideCursor.h>
|
||||||
|
#include <SUIT_ResourceMgr.h>
|
||||||
|
#include <SVTK_ViewModel.h>
|
||||||
|
#include <SVTK_ViewWindow.h>
|
||||||
|
#include <SalomeApp_Tools.h>
|
||||||
|
#include <SalomeApp_TypeFilter.h>
|
||||||
|
|
||||||
|
// SALOME KERNEL includes
|
||||||
|
#include <SALOMEDS_SObject.hxx>
|
||||||
|
|
||||||
|
// OCCT includes
|
||||||
|
#include <BRep_Tool.hxx>
|
||||||
|
#include <TColStd_MapOfInteger.hxx>
|
||||||
|
#include <TColgp_SequenceOfXYZ.hxx>
|
||||||
|
#include <TopoDS_Vertex.hxx>
|
||||||
|
#include <gp_Pnt.hxx>
|
||||||
|
|
||||||
|
// Qt includes
|
||||||
|
#include <QGroupBox>
|
||||||
|
#include <QGridLayout>
|
||||||
|
#include <QHBoxLayout>
|
||||||
|
#include <QVBoxLayout>
|
||||||
|
#include <QLineEdit>
|
||||||
|
#include <QPushButton>
|
||||||
|
#include <QLabel>
|
||||||
|
#include <QRadioButton>
|
||||||
|
#include <QCheckBox>
|
||||||
|
#include <QButtonGroup>
|
||||||
|
|
||||||
|
// VTK includes
|
||||||
|
#include <vtkProperty.h>
|
||||||
|
|
||||||
|
// IDL includes
|
||||||
|
#include <SALOMEconfig.h>
|
||||||
|
#include CORBA_SERVER_HEADER(SMESH_Mesh)
|
||||||
|
#include CORBA_SERVER_HEADER(SMESH_MeshEditor)
|
||||||
|
|
||||||
|
// std
|
||||||
|
#include <limits>
|
||||||
|
|
||||||
|
#define SPACING 6
|
||||||
|
#define MARGIN 11
|
||||||
|
|
||||||
|
enum { CONSTRUCTOR_POINT=0, CONSTRUCTOR_FACE,
|
||||||
|
EObject, EPoint, EFace, EDirection };
|
||||||
|
|
||||||
|
//=======================================================================
|
||||||
|
/*!
|
||||||
|
* \brief Dialog to reorient faces acoording to vector
|
||||||
|
*/
|
||||||
|
//=======================================================================
|
||||||
|
|
||||||
|
SMESHGUI_ReorientFacesDlg::SMESHGUI_ReorientFacesDlg()
|
||||||
|
: SMESHGUI_Dialog( 0, false, true )
|
||||||
|
{
|
||||||
|
setWindowTitle(tr("CAPTION"));
|
||||||
|
|
||||||
|
QVBoxLayout* aDlgLay = new QVBoxLayout (mainFrame());
|
||||||
|
aDlgLay->setMargin(0);
|
||||||
|
aDlgLay->setSpacing(SPACING);
|
||||||
|
|
||||||
|
QWidget* aMainFrame = createMainFrame (mainFrame());
|
||||||
|
|
||||||
|
aDlgLay->addWidget(aMainFrame);
|
||||||
|
|
||||||
|
aDlgLay->setStretchFactor(aMainFrame, 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
//================================================================================
|
||||||
|
/*!
|
||||||
|
* \brief Create frame containing dialog's input fields
|
||||||
|
*/
|
||||||
|
//================================================================================
|
||||||
|
|
||||||
|
QWidget* SMESHGUI_ReorientFacesDlg::createMainFrame (QWidget* theParent)
|
||||||
|
{
|
||||||
|
QWidget* aFrame = new QWidget(theParent);
|
||||||
|
|
||||||
|
// constructors
|
||||||
|
|
||||||
|
QPixmap iconReoriPoint (resMgr()->loadPixmap("SMESH", tr("ICON_DLG_REORIENT2D_POINT")));
|
||||||
|
QPixmap iconReoriFace (resMgr()->loadPixmap("SMESH", tr("ICON_DLG_REORIENT2D_FACE")));
|
||||||
|
|
||||||
|
QGroupBox* aConstructorBox = new QGroupBox(tr("REORIENT_FACES"), aFrame);
|
||||||
|
myConstructorGrp = new QButtonGroup(aConstructorBox);
|
||||||
|
QHBoxLayout* aConstructorGrpLayout = new QHBoxLayout(aConstructorBox);
|
||||||
|
aConstructorGrpLayout->setMargin(MARGIN);
|
||||||
|
aConstructorGrpLayout->setSpacing(SPACING);
|
||||||
|
|
||||||
|
QRadioButton* aPntBut = new QRadioButton(aConstructorBox);
|
||||||
|
aPntBut->setIcon(iconReoriPoint);
|
||||||
|
aPntBut->setChecked(true);
|
||||||
|
aConstructorGrpLayout->addWidget(aPntBut);
|
||||||
|
myConstructorGrp->addButton(aPntBut, CONSTRUCTOR_POINT);
|
||||||
|
|
||||||
|
QRadioButton* aFaceBut= new QRadioButton(aConstructorBox);
|
||||||
|
aFaceBut->setIcon(iconReoriFace);
|
||||||
|
aConstructorGrpLayout->addWidget(aFaceBut);
|
||||||
|
myConstructorGrp->addButton(aFaceBut, CONSTRUCTOR_FACE);
|
||||||
|
|
||||||
|
// Create other controls
|
||||||
|
|
||||||
|
setObjectPixmap( "SMESH", tr( "ICON_SELECT" ) );
|
||||||
|
|
||||||
|
createObject( tr("OBJECT") , aFrame, EObject );
|
||||||
|
createObject( tr("POINT") , aFrame, EPoint );
|
||||||
|
createObject( tr("FACE") , aFrame, EFace );
|
||||||
|
createObject( tr("DIRECTION"), aFrame, EDirection );
|
||||||
|
setNameIndication( EObject, OneName );
|
||||||
|
setNameIndication( EFace, OneName );
|
||||||
|
setReadOnly( EFace, false );
|
||||||
|
if ( QLineEdit* le = qobject_cast<QLineEdit*>( objectWg( EFace, Control ) ))
|
||||||
|
le->setValidator( new SMESHGUI_IdValidator( this,1 ));
|
||||||
|
|
||||||
|
const int width = aFaceBut->fontMetrics().width( tr("DIRECTION"));
|
||||||
|
objectWg( EDirection, Label )->setFixedWidth( width );
|
||||||
|
objectWg( EObject , Label )->setFixedWidth( width );
|
||||||
|
objectWg( EPoint , Label )->setFixedWidth( width );
|
||||||
|
objectWg( EFace , Label )->setFixedWidth( width );
|
||||||
|
|
||||||
|
QLabel* aXLabel = new QLabel(tr("SMESH_X"), aFrame);
|
||||||
|
myX = new SMESHGUI_SpinBox(aFrame);
|
||||||
|
QLabel* aYLabel = new QLabel(tr("SMESH_Y"), aFrame);
|
||||||
|
myY = new SMESHGUI_SpinBox(aFrame);
|
||||||
|
QLabel* aZLabel = new QLabel(tr("SMESH_Z"), aFrame);
|
||||||
|
myZ = new SMESHGUI_SpinBox(aFrame);
|
||||||
|
|
||||||
|
myX->RangeStepAndValidator(COORD_MIN, COORD_MAX, 10.0, "length_precision");
|
||||||
|
myY->RangeStepAndValidator(COORD_MIN, COORD_MAX, 10.0, "length_precision");
|
||||||
|
myZ->RangeStepAndValidator(COORD_MIN, COORD_MAX, 10.0, "length_precision");
|
||||||
|
myX->SetValue(0);
|
||||||
|
myY->SetValue(0);
|
||||||
|
myZ->SetValue(0);
|
||||||
|
|
||||||
|
QLabel* aDXLabel = new QLabel(tr("SMESH_DX"), aFrame);
|
||||||
|
myDX = new SMESHGUI_SpinBox(aFrame);
|
||||||
|
QLabel* aDYLabel = new QLabel(tr("SMESH_DY"), aFrame);
|
||||||
|
myDY = new SMESHGUI_SpinBox(aFrame);
|
||||||
|
QLabel* aDZLabel = new QLabel(tr("SMESH_DZ"), aFrame);
|
||||||
|
myDZ = new SMESHGUI_SpinBox(aFrame);
|
||||||
|
myDX->SetValue(1);
|
||||||
|
myDY->SetValue(0);
|
||||||
|
myDZ->SetValue(0);
|
||||||
|
|
||||||
|
myDX->RangeStepAndValidator(COORD_MIN, COORD_MAX, 10.0, "length_precision");
|
||||||
|
myDY->RangeStepAndValidator(COORD_MIN, COORD_MAX, 10.0, "length_precision");
|
||||||
|
myDZ->RangeStepAndValidator(COORD_MIN, COORD_MAX, 10.0, "length_precision");
|
||||||
|
|
||||||
|
// Layouting
|
||||||
|
|
||||||
|
QGroupBox* anObjectGrp = new QGroupBox(tr("FACES"), aFrame);
|
||||||
|
QHBoxLayout* anObjectGrpLayout = new QHBoxLayout(anObjectGrp);
|
||||||
|
anObjectGrpLayout->setMargin(MARGIN);
|
||||||
|
anObjectGrpLayout->setSpacing(SPACING);
|
||||||
|
anObjectGrpLayout->addWidget( objectWg( EObject, Label ));
|
||||||
|
anObjectGrpLayout->addWidget( objectWg( EObject, Btn ));
|
||||||
|
anObjectGrpLayout->addWidget( objectWg( EObject, Control ));
|
||||||
|
|
||||||
|
myPointFrm = new QFrame(aFrame);
|
||||||
|
QHBoxLayout* aPointGrpLayout = new QHBoxLayout(myPointFrm);
|
||||||
|
aPointGrpLayout->setMargin(0);
|
||||||
|
objectWg( EPoint, Control )->hide();
|
||||||
|
aPointGrpLayout->addWidget( objectWg( EPoint, Label ) );
|
||||||
|
aPointGrpLayout->addWidget( objectWg( EPoint, Btn ) );
|
||||||
|
aPointGrpLayout->addWidget( aXLabel );
|
||||||
|
aPointGrpLayout->addWidget( myX );
|
||||||
|
aPointGrpLayout->addWidget( aYLabel );
|
||||||
|
aPointGrpLayout->addWidget( myY );
|
||||||
|
aPointGrpLayout->addWidget( aZLabel );
|
||||||
|
aPointGrpLayout->addWidget( myZ );
|
||||||
|
|
||||||
|
myFaceFrm = new QFrame(aFrame);
|
||||||
|
QHBoxLayout* aFaceGrpLayout = new QHBoxLayout(myFaceFrm);
|
||||||
|
aFaceGrpLayout->setMargin(0);
|
||||||
|
aFaceGrpLayout->addWidget( objectWg( EFace, Label ) );
|
||||||
|
aFaceGrpLayout->addWidget( objectWg( EFace, Btn ) );
|
||||||
|
aFaceGrpLayout->addWidget( objectWg( EFace, Control ) );
|
||||||
|
|
||||||
|
QFrame* aDirectFrm = new QFrame(aFrame);
|
||||||
|
QHBoxLayout* aDirectGrpLayout = new QHBoxLayout(aDirectFrm);
|
||||||
|
aDirectGrpLayout->setMargin(0);
|
||||||
|
objectWg( EDirection, Control )->hide();
|
||||||
|
aDirectGrpLayout->addWidget( objectWg( EDirection, Label ) );
|
||||||
|
aDirectGrpLayout->addWidget( objectWg( EDirection, Btn ) );
|
||||||
|
aDirectGrpLayout->addWidget(aDXLabel );
|
||||||
|
aDirectGrpLayout->addWidget(myDX );
|
||||||
|
aDirectGrpLayout->addWidget(aDYLabel );
|
||||||
|
aDirectGrpLayout->addWidget(myDY );
|
||||||
|
aDirectGrpLayout->addWidget(aDZLabel );
|
||||||
|
aDirectGrpLayout->addWidget(myDZ );
|
||||||
|
|
||||||
|
|
||||||
|
QGroupBox* anOrientGrp = new QGroupBox(tr("ORIENTATION"), aFrame);
|
||||||
|
QVBoxLayout* anOrientGrpLayout = new QVBoxLayout ( anOrientGrp );
|
||||||
|
anOrientGrpLayout->addWidget(myPointFrm);
|
||||||
|
anOrientGrpLayout->addWidget(myFaceFrm);
|
||||||
|
anOrientGrpLayout->addWidget(aDirectFrm);
|
||||||
|
|
||||||
|
|
||||||
|
QVBoxLayout* aLay = new QVBoxLayout(aFrame);
|
||||||
|
aLay->addWidget(aConstructorBox);
|
||||||
|
aLay->addWidget(anObjectGrp);
|
||||||
|
aLay->addWidget(anOrientGrp);
|
||||||
|
|
||||||
|
connect( myConstructorGrp, SIGNAL(buttonClicked (int)), this, SLOT(constructorChange(int)));
|
||||||
|
|
||||||
|
return aFrame;
|
||||||
|
}
|
||||||
|
|
||||||
|
//================================================================================
|
||||||
|
/*!
|
||||||
|
* \brief Show point or face
|
||||||
|
*/
|
||||||
|
//================================================================================
|
||||||
|
|
||||||
|
void SMESHGUI_ReorientFacesDlg::constructorChange(int id)
|
||||||
|
{
|
||||||
|
if ( id == CONSTRUCTOR_FACE )
|
||||||
|
{
|
||||||
|
myPointFrm->hide();
|
||||||
|
myFaceFrm->show();
|
||||||
|
activateObject( EFace );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
myFaceFrm->hide();
|
||||||
|
myPointFrm->show();
|
||||||
|
activateObject( EPoint );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//================================================================================
|
||||||
|
/*!
|
||||||
|
* \brief Constructor
|
||||||
|
*/
|
||||||
|
//================================================================================
|
||||||
|
|
||||||
|
SMESHGUI_ReorientFacesOp::SMESHGUI_ReorientFacesOp()
|
||||||
|
:SMESHGUI_SelectionOp( ActorSelection )
|
||||||
|
{
|
||||||
|
//myVectorPreview = 0;
|
||||||
|
myHelpFileName = "reorient_faces_page.html";
|
||||||
|
|
||||||
|
myDlg = new SMESHGUI_ReorientFacesDlg;
|
||||||
|
myDlg->constructorChange( CONSTRUCTOR_POINT );
|
||||||
|
|
||||||
|
// connect signals and slots
|
||||||
|
connect( myDlg->objectWg( EFace, LightApp_Dialog::Control ), SIGNAL(textChanged(const QString&)),
|
||||||
|
this, SLOT(onTextChange(const QString&)));
|
||||||
|
// connect(myDlg->myX, SIGNAL (valueChanged(double)), this, SLOT(redisplayPreview()));
|
||||||
|
// connect(myDlg->myY, SIGNAL (valueChanged(double)), this, SLOT(redisplayPreview()));
|
||||||
|
// connect(myDlg->myZ, SIGNAL (valueChanged(double)), this, SLOT(redisplayPreview()));
|
||||||
|
// connect(myDlg->myDX, SIGNAL (valueChanged(double)), this, SLOT(redisplayPreview()));
|
||||||
|
// connect(myDlg->myDY, SIGNAL (valueChanged(double)), this, SLOT(redisplayPreview()));
|
||||||
|
// connect(myDlg->myDZ, SIGNAL (valueChanged(double)), this, SLOT(redisplayPreview()));
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
//=======================================================================
|
||||||
|
// function : startOperation()
|
||||||
|
// purpose : Init dialog fields, connect signals and slots, show dialog
|
||||||
|
//=======================================================================
|
||||||
|
|
||||||
|
void SMESHGUI_ReorientFacesOp::startOperation()
|
||||||
|
{
|
||||||
|
myObjectActor = 0;
|
||||||
|
|
||||||
|
// init simulation with a current View
|
||||||
|
//if ( myVectorPreview ) delete myVectorPreview;
|
||||||
|
// myVectorPreview = new SMESHGUI_MeshEditPreview(SMESH::GetViewWindow( getSMESHGUI() ));
|
||||||
|
// vtkProperty* aProp = vtkProperty::New();
|
||||||
|
// aProp->SetRepresentationToWireframe();
|
||||||
|
// aProp->SetColor(250, 0, 250);
|
||||||
|
// aProp->SetPointSize(5);
|
||||||
|
// aProp->SetLineWidth( SMESH::GetFloat("SMESH:element_width",1) + 1);
|
||||||
|
// myVectorPreview->GetActor()->SetProperty(aProp);
|
||||||
|
// aProp->Delete();
|
||||||
|
|
||||||
|
SMESHGUI_SelectionOp::startOperation();
|
||||||
|
|
||||||
|
myDlg->show();
|
||||||
|
|
||||||
|
mySelectionMode = 0;
|
||||||
|
myDlg->activateObject( EObject );
|
||||||
|
}
|
||||||
|
|
||||||
|
//================================================================================
|
||||||
|
/*!
|
||||||
|
* \brief Stops operation
|
||||||
|
*/
|
||||||
|
//================================================================================
|
||||||
|
|
||||||
|
void SMESHGUI_ReorientFacesOp::stopOperation()
|
||||||
|
{
|
||||||
|
//myVectorPreview->SetVisibility(false);
|
||||||
|
if ( myObjectActor ) {
|
||||||
|
myObjectActor->SetPointRepresentation(false);
|
||||||
|
SMESH::RepaintCurrentView();
|
||||||
|
myObjectActor = 0;
|
||||||
|
}
|
||||||
|
SMESHGUI_SelectionOp::stopOperation();
|
||||||
|
myDlg->deactivateAll();
|
||||||
|
}
|
||||||
|
|
||||||
|
//================================================================================
|
||||||
|
/*!
|
||||||
|
* \brief Set selection mode corresponding to a pressed selection button
|
||||||
|
*/
|
||||||
|
//================================================================================
|
||||||
|
|
||||||
|
void SMESHGUI_ReorientFacesOp::onActivateObject( int what )
|
||||||
|
{
|
||||||
|
if ( what == mySelectionMode )
|
||||||
|
return;
|
||||||
|
mySelectionMode = what;
|
||||||
|
switch ( mySelectionMode )
|
||||||
|
{
|
||||||
|
case EPoint:
|
||||||
|
case EDirection:
|
||||||
|
SMESH::SetPointRepresentation(true);
|
||||||
|
setSelectionMode( NodeSelection );
|
||||||
|
SMESH::SetPickable();
|
||||||
|
break;
|
||||||
|
case EObject:
|
||||||
|
SMESH::SetPointRepresentation(false);
|
||||||
|
setSelectionMode( ActorSelection );
|
||||||
|
break;
|
||||||
|
case EFace:
|
||||||
|
SMESH::SetPointRepresentation(false);
|
||||||
|
setSelectionMode( FaceSelection );
|
||||||
|
if ( myObjectActor )
|
||||||
|
SMESH::SetPickable( myObjectActor );
|
||||||
|
else
|
||||||
|
SMESH::SetPickable();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
SMESHGUI_SelectionOp::onActivateObject( what );
|
||||||
|
}
|
||||||
|
|
||||||
|
//================================================================================
|
||||||
|
/*!
|
||||||
|
* \brief Creates a filter corresponding to a pressed selection button
|
||||||
|
*/
|
||||||
|
//================================================================================
|
||||||
|
|
||||||
|
SUIT_SelectionFilter* SMESHGUI_ReorientFacesOp::createFilter( const int what ) const
|
||||||
|
{
|
||||||
|
switch ( what )
|
||||||
|
{
|
||||||
|
case EObject:
|
||||||
|
{
|
||||||
|
QList<SUIT_SelectionFilter*> filters;
|
||||||
|
filters.append( new SMESH_TypeFilter( MESH ));
|
||||||
|
filters.append( new SMESH_TypeFilter( SUBMESH_FACE ));
|
||||||
|
filters.append( new SMESH_TypeFilter( GROUP_FACE ));
|
||||||
|
return new SMESH_LogicalFilter( filters, SMESH_LogicalFilter::LO_OR );
|
||||||
|
}
|
||||||
|
case EPoint:
|
||||||
|
{
|
||||||
|
QList<SUIT_SelectionFilter*> filters;
|
||||||
|
filters.append( new SMESH_TypeFilter( IDSOURCE ));
|
||||||
|
filters.append( new SMESH_NumberFilter( "GEOM",TopAbs_VERTEX, 1, TopAbs_VERTEX ));
|
||||||
|
return new SMESH_LogicalFilter( filters, SMESH_LogicalFilter::LO_OR );
|
||||||
|
}
|
||||||
|
case EFace:
|
||||||
|
case EDirection:
|
||||||
|
{
|
||||||
|
return new SMESH_TypeFilter( IDSOURCE );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
//================================================================================
|
||||||
|
/*!
|
||||||
|
* \brief get data from selection
|
||||||
|
*/
|
||||||
|
//================================================================================
|
||||||
|
|
||||||
|
void SMESHGUI_ReorientFacesOp::selectionDone()
|
||||||
|
{
|
||||||
|
if ( !myDlg->isVisible() || !myDlg->isEnabled() )
|
||||||
|
return;
|
||||||
|
|
||||||
|
myDlg->clearSelection( mySelectionMode );
|
||||||
|
|
||||||
|
SALOME_ListIO aList;
|
||||||
|
selectionMgr()->selectedObjects(aList);
|
||||||
|
const int nbSelected = aList.Extent();
|
||||||
|
if ( nbSelected == 0 )
|
||||||
|
return;
|
||||||
|
|
||||||
|
Handle(SALOME_InteractiveObject) anIO = aList.First();
|
||||||
|
|
||||||
|
try
|
||||||
|
{
|
||||||
|
switch ( mySelectionMode )
|
||||||
|
{
|
||||||
|
case EObject: { // get an actor of object
|
||||||
|
|
||||||
|
if ( nbSelected == 1 )
|
||||||
|
{
|
||||||
|
myDlg->selectObject( EObject, anIO->getName(), 0, anIO->getEntry(), true );
|
||||||
|
// typeById( aList.First()->getEntry(),
|
||||||
|
// SMESHGUI_SelectionOp::Object ),
|
||||||
|
myObjectActor = SMESH::FindActorByEntry( anIO->getEntry() );
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case EFace: { // get a face ID
|
||||||
|
|
||||||
|
if ( nbSelected == 1 )
|
||||||
|
{
|
||||||
|
TColStd_IndexedMapOfInteger faceIndices;
|
||||||
|
selector()->GetIndex( anIO, faceIndices );
|
||||||
|
if ( faceIndices.Extent() == 1 )
|
||||||
|
{
|
||||||
|
SMESH_Actor* savedActor = myObjectActor;
|
||||||
|
myObjectActor = 0; // to prevent work of onTextChange()
|
||||||
|
myDlg->setObjectText( EFace, QString("%1").arg( faceIndices(1) ));
|
||||||
|
myObjectActor = savedActor;
|
||||||
|
|
||||||
|
if ( !myObjectActor )
|
||||||
|
{
|
||||||
|
myDlg->selectObject( EObject, anIO->getName(), 0, anIO->getEntry(), true );
|
||||||
|
// typeById( aList.First()->getEntry(),
|
||||||
|
// SMESHGUI_SelectionOp::Object ),
|
||||||
|
myObjectActor = SMESH::FindActorByEntry( anIO->getEntry() );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case EPoint:
|
||||||
|
case EDirection: { // set XYZ by selected nodes or vertices
|
||||||
|
|
||||||
|
if ( mySelectionMode == EPoint && aList.Extent() > 1 )
|
||||||
|
return;
|
||||||
|
|
||||||
|
TColgp_SequenceOfXYZ points;
|
||||||
|
for( SALOME_ListIteratorOfListIO anIt( aList ); anIt.More(); anIt.Next() )
|
||||||
|
{
|
||||||
|
anIO = anIt.Value();
|
||||||
|
GEOM::GEOM_Object_var geom = SMESH::IObjectToInterface<GEOM::GEOM_Object>(anIO);
|
||||||
|
if ( !geom->_is_nil() ) {
|
||||||
|
TopoDS_Vertex aShape;
|
||||||
|
if ( GEOMBase::GetShape(geom, aShape) && aShape.ShapeType() == TopAbs_VERTEX ) {
|
||||||
|
gp_Pnt P = BRep_Tool::Pnt(aShape);
|
||||||
|
points.Append( P.XYZ() );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
TColStd_IndexedMapOfInteger nodeIndices;
|
||||||
|
selector()->GetIndex( anIO, nodeIndices );
|
||||||
|
if ( nodeIndices.Extent() > 0 && nodeIndices.Extent() <=2 )
|
||||||
|
{
|
||||||
|
if ( SMESH_Actor* aMeshActor = SMESH::FindActorByEntry(anIO->getEntry()))
|
||||||
|
if (SMDS_Mesh* aMesh = aMeshActor->GetObject()->GetMesh())
|
||||||
|
{
|
||||||
|
if (const SMDS_MeshNode* aNode = aMesh->FindNode( nodeIndices(1)))
|
||||||
|
points.Append( gp_XYZ( aNode->X(), aNode->Y(), aNode->Z()));
|
||||||
|
if ( nodeIndices.Extent() == 2 )
|
||||||
|
if (const SMDS_MeshNode* aNode = aMesh->FindNode( nodeIndices(2)))
|
||||||
|
points.Append( gp_XYZ( aNode->X(), aNode->Y(), aNode->Z()));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
gp_XYZ xyz;
|
||||||
|
if ( points.Length() == 1 )
|
||||||
|
xyz = points(1);
|
||||||
|
else if ( points.Length() == 2 )
|
||||||
|
xyz = points(2) - points(1);
|
||||||
|
else
|
||||||
|
return;
|
||||||
|
if ( points.Length() == 1 && mySelectionMode == EPoint )
|
||||||
|
{
|
||||||
|
myDlg->myX->SetValue( xyz.X() );
|
||||||
|
myDlg->myY->SetValue( xyz.Y() );
|
||||||
|
myDlg->myZ->SetValue( xyz.Z() );
|
||||||
|
redisplayPreview();
|
||||||
|
}
|
||||||
|
if ( mySelectionMode == EDirection )
|
||||||
|
{
|
||||||
|
myDlg->myDX->SetValue( xyz.X() );
|
||||||
|
myDlg->myDY->SetValue( xyz.Y() );
|
||||||
|
myDlg->myDZ->SetValue( xyz.Z() );
|
||||||
|
redisplayPreview();
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
} // case EPoint || EDirection
|
||||||
|
} // switch
|
||||||
|
}
|
||||||
|
catch (...)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//================================================================================
|
||||||
|
/*!
|
||||||
|
* \brief SLOT called when the face id is changed
|
||||||
|
*/
|
||||||
|
//================================================================================
|
||||||
|
|
||||||
|
void SMESHGUI_ReorientFacesOp::onTextChange( const QString& theText )
|
||||||
|
{
|
||||||
|
if( myObjectActor )
|
||||||
|
{
|
||||||
|
sender()->blockSignals( true );
|
||||||
|
if ( mySelectionMode != EFace )
|
||||||
|
{
|
||||||
|
myDlg->activateObject( EFace );
|
||||||
|
myDlg->setObjectText( EFace, theText );
|
||||||
|
}
|
||||||
|
TColStd_MapOfInteger ids;
|
||||||
|
if ( !theText.isEmpty() && theText.toInt() > 0 )
|
||||||
|
ids.Add( theText.toInt() );
|
||||||
|
|
||||||
|
SMESHGUI_SelectionOp::addOrRemoveIndex( myObjectActor->getIO(), ids, false );
|
||||||
|
SMESHGUI_SelectionOp::highlight( myObjectActor->getIO(), true, true );
|
||||||
|
sender()->blockSignals( false );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//================================================================================
|
||||||
|
/*!
|
||||||
|
* \brief perform it's intention action: reorient faces of myObject
|
||||||
|
*/
|
||||||
|
//================================================================================
|
||||||
|
|
||||||
|
bool SMESHGUI_ReorientFacesOp::onApply()
|
||||||
|
{
|
||||||
|
if( isStudyLocked() )
|
||||||
|
return false;
|
||||||
|
|
||||||
|
QString msg;
|
||||||
|
if ( !isValid( msg ) ) { // node id is invalid
|
||||||
|
if( !msg.isEmpty() )
|
||||||
|
SUIT_MessageBox::warning( dlg(), tr( "SMESH_WRN_WARNING" ), msg );
|
||||||
|
dlg()->show();
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
QStringList aParameters;
|
||||||
|
aParameters << myDlg->myDX->text();
|
||||||
|
aParameters << myDlg->myDY->text();
|
||||||
|
aParameters << myDlg->myDZ->text();
|
||||||
|
aParameters << myDlg->myX->text();
|
||||||
|
aParameters << myDlg->myY->text();
|
||||||
|
aParameters << myDlg->myZ->text();
|
||||||
|
|
||||||
|
try {
|
||||||
|
SUIT_OverrideCursor wc;
|
||||||
|
SMESH::SMESH_Mesh_var aMesh = myObject->GetMesh();
|
||||||
|
if ( aMesh->_is_nil() ) return false;
|
||||||
|
|
||||||
|
SMESH::DirStruct direction;
|
||||||
|
direction.PS.x = myDlg->myDX->GetValue();
|
||||||
|
direction.PS.y = myDlg->myDY->GetValue();
|
||||||
|
direction.PS.z = myDlg->myDZ->GetValue();
|
||||||
|
|
||||||
|
long face = myDlg->objectText( EFace ).toInt();
|
||||||
|
if ( myDlg->myConstructorGrp->checkedId() == CONSTRUCTOR_POINT )
|
||||||
|
face = -1;
|
||||||
|
|
||||||
|
SMESH::PointStruct point;
|
||||||
|
point.x = myDlg->myX->GetValue();
|
||||||
|
point.y = myDlg->myY->GetValue();
|
||||||
|
point.z = myDlg->myZ->GetValue();
|
||||||
|
|
||||||
|
SMESH::SMESH_MeshEditor_var aMeshEditor = aMesh->GetMeshEditor();
|
||||||
|
if (aMeshEditor->_is_nil()) return false;
|
||||||
|
|
||||||
|
aMesh->SetParameters( aParameters.join(":").toLatin1().constData() );
|
||||||
|
|
||||||
|
int aResult = aMeshEditor->Reorient2D( myObject, direction, face, point );
|
||||||
|
if (aResult)
|
||||||
|
{
|
||||||
|
SALOME_ListIO aList;
|
||||||
|
selectionMgr()->setSelectedObjects(aList,false);
|
||||||
|
SMESH::UpdateView();
|
||||||
|
SMESHGUI::Modified();
|
||||||
|
}
|
||||||
|
wc.suspend();
|
||||||
|
SUIT_MessageBox::information(SMESHGUI::desktop(), tr("SMESH_INFORMATION"),
|
||||||
|
tr("NB_REORIENTED").arg(aResult));
|
||||||
|
}
|
||||||
|
catch (const SALOME::SALOME_Exception& S_ex) {
|
||||||
|
SalomeApp_Tools::QtCatchCorbaException(S_ex);
|
||||||
|
}
|
||||||
|
catch (...) {
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
//================================================================================
|
||||||
|
/*!
|
||||||
|
* \brief Check data validity
|
||||||
|
*/
|
||||||
|
//================================================================================
|
||||||
|
|
||||||
|
bool SMESHGUI_ReorientFacesOp::isValid( QString& msg )
|
||||||
|
{
|
||||||
|
// check object
|
||||||
|
QString objectEntry = myDlg->selectedObject( EObject );
|
||||||
|
_PTR(SObject) pSObject = studyDS()->FindObjectID( objectEntry.toLatin1().data() );
|
||||||
|
myObject = SMESH::SMESH_IDSource::_narrow( _CAST( SObject,pSObject )->GetObject() );
|
||||||
|
if ( myObject->_is_nil() )
|
||||||
|
{
|
||||||
|
msg = tr("NO_OBJECT_SELECTED");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
bool hasFaces = false;
|
||||||
|
SMESH::array_of_ElementType_var types = myObject->GetTypes();
|
||||||
|
for ( size_t i = 0; i < types->length() && !hasFaces; ++i )
|
||||||
|
hasFaces = ( types[i] == SMESH::FACE );
|
||||||
|
if ( !hasFaces )
|
||||||
|
{
|
||||||
|
msg = tr("NO_FACES");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
// check vector
|
||||||
|
gp_Vec vec( myDlg->myDX->GetValue(),
|
||||||
|
myDlg->myDY->GetValue(),
|
||||||
|
myDlg->myDZ->GetValue() );
|
||||||
|
if ( vec.Magnitude() < std::numeric_limits<double>::min() )
|
||||||
|
{
|
||||||
|
msg = tr("ZERO_SIZE_VECTOR");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
// check face ID
|
||||||
|
if ( myDlg->myConstructorGrp->checkedId() == CONSTRUCTOR_FACE )
|
||||||
|
{
|
||||||
|
int faceID = myDlg->objectText( EFace ).toInt();
|
||||||
|
bool faceOK = ( faceID > 0 );
|
||||||
|
if ( faceOK )
|
||||||
|
{
|
||||||
|
if ( myObjectActor )
|
||||||
|
{
|
||||||
|
faceOK = ( myObjectActor->GetObject()->GetElemDimension( faceID ) == 2 );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
SMESH::SMESH_Mesh_var aMesh = myObject->GetMesh();
|
||||||
|
if ( !aMesh->_is_nil() )
|
||||||
|
faceOK = ( aMesh->GetElementType( faceID, true ) == SMESH::FACE );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if ( !faceOK )
|
||||||
|
{
|
||||||
|
msg = tr("INVALID_FACE");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
//================================================================================
|
||||||
|
/*!
|
||||||
|
* \brief Destructor
|
||||||
|
*/
|
||||||
|
//================================================================================
|
||||||
|
|
||||||
|
SMESHGUI_ReorientFacesOp::~SMESHGUI_ReorientFacesOp()
|
||||||
|
{
|
||||||
|
if ( myDlg ) delete myDlg;
|
||||||
|
//if ( myVectorPreview ) delete myVectorPreview;
|
||||||
|
}
|
||||||
|
|
||||||
|
//================================================================================
|
||||||
|
/*!
|
||||||
|
* \brief Gets dialog of this operation
|
||||||
|
* \retval LightApp_Dialog* - pointer to dialog of this operation
|
||||||
|
*/
|
||||||
|
//================================================================================
|
||||||
|
|
||||||
|
LightApp_Dialog* SMESHGUI_ReorientFacesOp::dlg() const
|
||||||
|
{
|
||||||
|
return myDlg;
|
||||||
|
}
|
||||||
|
|
||||||
|
//================================================================================
|
||||||
|
/*!
|
||||||
|
* \brief update preview
|
||||||
|
*/
|
||||||
|
//================================================================================
|
||||||
|
|
||||||
|
void SMESHGUI_ReorientFacesOp::redisplayPreview()
|
||||||
|
{
|
||||||
|
// SMESH::MeshPreviewStruct_var aMeshPreviewStruct;
|
||||||
|
|
||||||
|
// bool moveShown = false;
|
||||||
|
// if ( myObjectActor)
|
||||||
|
// {
|
||||||
|
// const bool autoSearch = myDlg->myAutoSearchChkBox->isChecked();
|
||||||
|
// const bool preview = myDlg->myPreviewChkBox->isChecked();
|
||||||
|
// if ( autoSearch )
|
||||||
|
// {
|
||||||
|
// myDlg->myCurrentX->SetValue(0);
|
||||||
|
// myDlg->myCurrentY->SetValue(0);
|
||||||
|
// myDlg->myCurrentZ->SetValue(0);
|
||||||
|
// myDlg->myDX->SetValue(0);
|
||||||
|
// myDlg->myDY->SetValue(0);
|
||||||
|
// myDlg->myDZ->SetValue(0);
|
||||||
|
// myDlg->myId->setText("");
|
||||||
|
// }
|
||||||
|
// QString msg;
|
||||||
|
// if ( autoSearch || isValid( msg ) )
|
||||||
|
// {
|
||||||
|
// try {
|
||||||
|
// SMESH::SMESH_Mesh_var aMesh = SMESH::GetMeshByIO(myObjectActor->getIO());
|
||||||
|
// if (!aMesh->_is_nil()) {
|
||||||
|
// SMESH::SMESH_MeshEditor_var aPreviewer = aMesh->GetMeshEditPreviewer();
|
||||||
|
// if (!aPreviewer->_is_nil())
|
||||||
|
// {
|
||||||
|
// SUIT_OverrideCursor aWaitCursor;
|
||||||
|
|
||||||
|
// int anId = 0;
|
||||||
|
// if ( autoSearch )
|
||||||
|
// anId = aPreviewer->FindNodeClosestTo(myDlg->myX->GetValue(),
|
||||||
|
// myDlg->myY->GetValue(),
|
||||||
|
// myDlg->myZ->GetValue());
|
||||||
|
// else
|
||||||
|
// anId = myDlg->myId->text().toInt();
|
||||||
|
|
||||||
|
// // find id and/or just compute preview
|
||||||
|
// aPreviewer->MoveNode(anId,
|
||||||
|
// myDlg->myX->GetValue(),
|
||||||
|
// myDlg->myY->GetValue(),
|
||||||
|
// myDlg->myZ->GetValue());
|
||||||
|
// if ( autoSearch ) { // set found id
|
||||||
|
// QString idTxt("%1");
|
||||||
|
// if ( anId > 0 )
|
||||||
|
// idTxt = idTxt.arg( anId );
|
||||||
|
// else
|
||||||
|
// idTxt = "";
|
||||||
|
// myDlg->myId->setText( idTxt );
|
||||||
|
// }
|
||||||
|
|
||||||
|
// SMESH::double_array* aXYZ = aMesh->GetNodeXYZ( anId );
|
||||||
|
// if( aXYZ && aXYZ->length() >= 3 )
|
||||||
|
// {
|
||||||
|
// double x = aXYZ->operator[](0);
|
||||||
|
// double y = aXYZ->operator[](1);
|
||||||
|
// double z = aXYZ->operator[](2);
|
||||||
|
// double dx = myDlg->myX->GetValue() - x;
|
||||||
|
// double dy = myDlg->myY->GetValue() - y;
|
||||||
|
// double dz = myDlg->myZ->GetValue() - z;
|
||||||
|
// myDlg->myCurrentX->SetValue(x);
|
||||||
|
// myDlg->myCurrentY->SetValue(y);
|
||||||
|
// myDlg->myCurrentZ->SetValue(z);
|
||||||
|
// myDlg->myDX->SetValue(dx);
|
||||||
|
// myDlg->myDY->SetValue(dy);
|
||||||
|
// myDlg->myDZ->SetValue(dz);
|
||||||
|
// }
|
||||||
|
|
||||||
|
// if ( preview ) { // fill preview data
|
||||||
|
// aMeshPreviewStruct = aPreviewer->GetPreviewData();
|
||||||
|
// moveShown = ( anId > 0 );
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
// }catch (...) {
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
|
||||||
|
// if ( !moveShown )
|
||||||
|
// {
|
||||||
|
// aMeshPreviewStruct = new SMESH::MeshPreviewStruct();
|
||||||
|
|
||||||
|
// aMeshPreviewStruct->nodesXYZ.length(1);
|
||||||
|
// aMeshPreviewStruct->nodesXYZ[0].x = myDlg->myX->GetValue();
|
||||||
|
// aMeshPreviewStruct->nodesXYZ[0].y = myDlg->myY->GetValue();
|
||||||
|
// aMeshPreviewStruct->nodesXYZ[0].z = myDlg->myZ->GetValue();
|
||||||
|
|
||||||
|
// aMeshPreviewStruct->elementTypes.length(1);
|
||||||
|
// aMeshPreviewStruct->elementTypes[0].SMDS_ElementType = SMESH::NODE;
|
||||||
|
// aMeshPreviewStruct->elementTypes[0].isPoly = false;
|
||||||
|
// aMeshPreviewStruct->elementTypes[0].nbNodesInElement = 1;
|
||||||
|
|
||||||
|
// aMeshPreviewStruct->elementConnectivities.length(1);
|
||||||
|
// aMeshPreviewStruct->elementConnectivities[0] = 0;
|
||||||
|
// }
|
||||||
|
|
||||||
|
// // display data
|
||||||
|
// if ( aMeshPreviewStruct.operator->() )
|
||||||
|
// {
|
||||||
|
// myVectorPreview->SetData(aMeshPreviewStruct._retn());
|
||||||
|
// }
|
||||||
|
// else
|
||||||
|
// {
|
||||||
|
// myVectorPreview->SetVisibility(false);
|
||||||
|
// }
|
||||||
|
|
||||||
|
}
|
118
src/SMESHGUI/SMESHGUI_ReorientFacesDlg.h
Normal file
118
src/SMESHGUI/SMESHGUI_ReorientFacesDlg.h
Normal file
@ -0,0 +1,118 @@
|
|||||||
|
// Copyright (C) 2007-2012 CEA/DEN, EDF R&D, OPEN CASCADE
|
||||||
|
//
|
||||||
|
// Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
|
||||||
|
// CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
|
||||||
|
//
|
||||||
|
// This library is free software; you can redistribute it and/or
|
||||||
|
// modify it under the terms of the GNU Lesser General Public
|
||||||
|
// License as published by the Free Software Foundation; either
|
||||||
|
// version 2.1 of the License.
|
||||||
|
//
|
||||||
|
// This library is distributed in the hope that it will be useful,
|
||||||
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||||
|
// Lesser General Public License for more details.
|
||||||
|
//
|
||||||
|
// You should have received a copy of the GNU Lesser General Public
|
||||||
|
// License along with this library; if not, write to the Free Software
|
||||||
|
// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
|
//
|
||||||
|
// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
|
||||||
|
//
|
||||||
|
|
||||||
|
// File : SMESHGUI_ReorientFacesDlg.h
|
||||||
|
// Author : Edward AGAPOV, Open CASCADE S.A.S.
|
||||||
|
//
|
||||||
|
#ifndef SMESHGUI_ReorientFacesDlg_H
|
||||||
|
#define SMESHGUI_ReorientFacesDlg_H
|
||||||
|
|
||||||
|
// SMESH includes
|
||||||
|
#include "SMESH_SMESHGUI.hxx"
|
||||||
|
|
||||||
|
#include "SMESHGUI_Dialog.h"
|
||||||
|
#include "SMESHGUI_SelectionOp.h"
|
||||||
|
|
||||||
|
class QButtonGroup;
|
||||||
|
class QLineEdit;
|
||||||
|
class SMESHGUI_SpinBox;
|
||||||
|
class SMESHGUI_ReorientFacesDlg;
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief Operation to reorient faces acoording to vector
|
||||||
|
*/
|
||||||
|
class SMESHGUI_EXPORT SMESHGUI_ReorientFacesOp: public SMESHGUI_SelectionOp
|
||||||
|
{
|
||||||
|
Q_OBJECT
|
||||||
|
|
||||||
|
public:
|
||||||
|
SMESHGUI_ReorientFacesOp();
|
||||||
|
virtual ~SMESHGUI_ReorientFacesOp();
|
||||||
|
|
||||||
|
virtual LightApp_Dialog* dlg() const;
|
||||||
|
|
||||||
|
protected:
|
||||||
|
|
||||||
|
virtual void startOperation();
|
||||||
|
virtual void stopOperation();
|
||||||
|
|
||||||
|
virtual SUIT_SelectionFilter* createFilter( const int ) const;
|
||||||
|
virtual void selectionDone();
|
||||||
|
|
||||||
|
bool isValid( QString& );
|
||||||
|
|
||||||
|
protected slots:
|
||||||
|
virtual bool onApply();
|
||||||
|
|
||||||
|
private slots:
|
||||||
|
virtual void onActivateObject( int );
|
||||||
|
void redisplayPreview();
|
||||||
|
void onTextChange( const QString& );
|
||||||
|
|
||||||
|
private:
|
||||||
|
SMESHGUI_ReorientFacesDlg* myDlg;
|
||||||
|
|
||||||
|
//SMESHGUI_MeshEditPreview* myVectorPreview;
|
||||||
|
SMESH_Actor* myObjectActor;
|
||||||
|
int mySelectionMode;
|
||||||
|
|
||||||
|
SMESH::SMESH_IDSource_var myObject;
|
||||||
|
};
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief Dialog to reorient faces acoording to vector
|
||||||
|
*/
|
||||||
|
|
||||||
|
class SMESHGUI_EXPORT SMESHGUI_ReorientFacesDlg : public SMESHGUI_Dialog
|
||||||
|
{
|
||||||
|
Q_OBJECT
|
||||||
|
|
||||||
|
public:
|
||||||
|
SMESHGUI_ReorientFacesDlg();
|
||||||
|
|
||||||
|
public slots:
|
||||||
|
void constructorChange(int id);
|
||||||
|
|
||||||
|
private:
|
||||||
|
QWidget* createMainFrame( QWidget* );
|
||||||
|
|
||||||
|
QButtonGroup* myConstructorGrp;
|
||||||
|
QFrame* myFaceFrm;
|
||||||
|
QFrame* myPointFrm;
|
||||||
|
SMESHGUI_SpinBox* myX;
|
||||||
|
SMESHGUI_SpinBox* myY;
|
||||||
|
SMESHGUI_SpinBox* myZ;
|
||||||
|
//QPushButton* myIdBtn;
|
||||||
|
//QLineEdit* myId;
|
||||||
|
SMESHGUI_SpinBox* myDX;
|
||||||
|
SMESHGUI_SpinBox* myDY;
|
||||||
|
SMESHGUI_SpinBox* myDZ;
|
||||||
|
|
||||||
|
QString myHelpFileName;
|
||||||
|
|
||||||
|
friend class SMESHGUI_ReorientFacesOp;
|
||||||
|
|
||||||
|
//private slots:
|
||||||
|
//void ButtonToggled( bool );
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif // SMESHGUI_ReorientFacesDlg_H
|
Loading…
Reference in New Issue
Block a user