From 356b0f81d37708340f5e8fb1c2dfa7e31a3089b3 Mon Sep 17 00:00:00 2001 From: eap Date: Fri, 29 Jun 2012 13:54:55 +0000 Subject: [PATCH] 0021542: EDF 1699 SMESH: Reorient a group of faces + SMESHGUI_ReorientFacesDlg.h \ --- src/SMESHGUI/Makefile.am | 9 +- src/SMESHGUI/SMESHGUI.cxx | 42 +- src/SMESHGUI/SMESHGUI_ReorientFacesDlg.cxx | 852 +++++++++++++++++++++ src/SMESHGUI/SMESHGUI_ReorientFacesDlg.h | 118 +++ 4 files changed, 990 insertions(+), 31 deletions(-) create mode 100644 src/SMESHGUI/SMESHGUI_ReorientFacesDlg.cxx create mode 100644 src/SMESHGUI/SMESHGUI_ReorientFacesDlg.h diff --git a/src/SMESHGUI/Makefile.am b/src/SMESHGUI/Makefile.am index 28537546a..15925385f 100644 --- a/src/SMESHGUI/Makefile.am +++ b/src/SMESHGUI/Makefile.am @@ -95,7 +95,8 @@ salomeinclude_HEADERS = \ SMESHGUI_MeshOrderOp.h \ SMESHGUI_FileValidator.h \ SMESHGUI_CopyMeshDlg.h \ - SMESHGUI_PreviewDlg.h \ + SMESHGUI_PreviewDlg.h \ + SMESHGUI_ReorientFacesDlg.h \ SMESH_SMESHGUI.hxx # Libraries targets @@ -171,7 +172,8 @@ dist_libSMESH_la_SOURCES = \ SMESHGUI_MeshOrderOp.cxx \ SMESHGUI_CopyMeshDlg.cxx \ SMESHGUI_FileValidator.cxx \ - SMESHGUI_PreviewDlg.cxx + SMESHGUI_PreviewDlg.cxx \ + SMESHGUI_ReorientFacesDlg.cxx MOC_FILES = \ SMESHGUI_moc.cxx \ @@ -230,7 +232,8 @@ MOC_FILES = \ SMESHGUI_MeshOrderDlg_moc.cxx \ SMESHGUI_CopyMeshDlg_moc.cxx \ SMESHGUI_MeshOrderOp_moc.cxx \ - SMESHGUI_PreviewDlg_moc.cxx + SMESHGUI_PreviewDlg_moc.cxx \ + SMESHGUI_ReorientFacesDlg_moc.cxx nodist_libSMESH_la_SOURCES= \ $(MOC_FILES) diff --git a/src/SMESHGUI/SMESHGUI.cxx b/src/SMESHGUI/SMESHGUI.cxx index b681a1499..7d9950a8e 100644 --- a/src/SMESHGUI/SMESHGUI.cxx +++ b/src/SMESHGUI/SMESHGUI.cxx @@ -76,6 +76,7 @@ #include "SMESHGUI_TransparencyDlg.h" #include "SMESHGUI_DuplicateNodesDlg.h" #include "SMESHGUI_CopyMeshDlg.h" +#include "SMESHGUI_ReorientFacesDlg.h" #include "SMESHGUI_Utils.h" #include "SMESHGUI_MeshUtils.h" @@ -2327,16 +2328,10 @@ bool SMESHGUI::OnGUIEvent( int theCommandID ) break; } - case 701: // COMPUTE MESH - case 711: // PRECOMPUTE MESH - case 712: // EVALUATE MESH - case 713: // MESH ORDER - { - if (checkLock(aStudy)) break; - startOperation( theCommandID ); - } - break; - + case 701: // COMPUTE MESH + case 711: // PRECOMPUTE MESH + case 712: // EVALUATE MESH + case 713: // MESH ORDER case 702: // Create mesh case 703: // Create sub-mesh case 704: // Edit mesh/sub-mesh @@ -2481,26 +2476,11 @@ bool SMESHGUI::OnGUIEvent( int theCommandID ) break; } 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 420: // Reorient faces + case 806: // CREATE GEO GROUP { - startOperation( 418 ); - break; - } - case 806: // CREATE GEO GROUP - { - startOperation( 806 ); + startOperation( theCommandID ); break; } case 801: // CREATE GROUP @@ -3558,6 +3538,7 @@ void SMESHGUI::initialize( CAM_Application* app ) createSMESHAction( 417, "CONV_TO_QUAD", "ICON_CONV_TO_QUAD" ); createSMESHAction( 418, "2D_FROM_3D", "ICON_2D_FROM_3D" ); createSMESHAction( 419, "SPLIT_TO_TETRA", "ICON_SPLIT_TO_TETRA" ); + createSMESHAction( 420, "REORIENT_2D", "ICON_REORIENT_2D" ); createSMESHAction( 200, "RESET" ); createSMESHAction( 201, "SCALAR_BAR_PROP" ); createSMESHAction( 2021, "SAVE_DISTRIBUTION" ); @@ -3748,6 +3729,7 @@ void SMESHGUI::initialize( CAM_Application* app ) createMenu( 407, modifyId, -1 ); createMenu( 408, modifyId, -1 ); createMenu( 409, modifyId, -1 ); + createMenu( 420, modifyId, -1 ); createMenu( 410, modifyId, -1 ); createMenu( 411, modifyId, -1 ); createMenu( 419, modifyId, -1 ); @@ -3869,6 +3851,7 @@ void SMESHGUI::initialize( CAM_Application* app ) createTool( 407, modifyTb ); createTool( 408, modifyTb ); createTool( 409, modifyTb ); + createTool( 420, modifyTb ); createTool( 410, modifyTb ); createTool( 411, 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 op = new SMESHGUI_Make2DFrom3DOp(); break; + case 420: // Reorient faces + op = new SMESHGUI_ReorientFacesOp(); + break; case 701: // Compute mesh op = new SMESHGUI_ComputeOp(); break; diff --git a/src/SMESHGUI/SMESHGUI_ReorientFacesDlg.cxx b/src/SMESHGUI/SMESHGUI_ReorientFacesDlg.cxx new file mode 100644 index 000000000..cc5db9fe2 --- /dev/null +++ b/src/SMESHGUI/SMESHGUI_ReorientFacesDlg.cxx @@ -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 +#include +#include +#include +#include +#include + +// SALOME GEOM includes +#include + +// SALOME GUI includes +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +// SALOME KERNEL includes +#include + +// OCCT includes +#include +#include +#include +#include +#include + +// Qt includes +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +// VTK includes +#include + +// IDL includes +#include +#include CORBA_SERVER_HEADER(SMESH_Mesh) +#include CORBA_SERVER_HEADER(SMESH_MeshEditor) + +// std +#include + +#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( 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 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 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(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::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); +// } + +} diff --git a/src/SMESHGUI/SMESHGUI_ReorientFacesDlg.h b/src/SMESHGUI/SMESHGUI_ReorientFacesDlg.h new file mode 100644 index 000000000..aaea78340 --- /dev/null +++ b/src/SMESHGUI/SMESHGUI_ReorientFacesDlg.h @@ -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 -- 2.39.2