0021542: EDF 1699 SMESH: Reorient a group of faces

+	SMESHGUI_ReorientFacesDlg.h \
This commit is contained in:
eap 2012-06-29 13:54:55 +00:00
parent e42414f211
commit 356b0f81d3
4 changed files with 990 additions and 31 deletions

View File

@ -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)

View File

@ -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;

View 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);
// }
}

View 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