// Copyright (C) 2007-2008 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 // // SMESH SMESHGUI : GUI for SMESH component // File : SMESHGUI_ConvToQuadOp.cxx // Author : Open CASCADE S.A.S. // SMESH includes // #include "SMESHGUI_ConvToQuadOp.h" #include "SMESHGUI_ConvToQuadDlg.h" #include "SMESHGUI_Utils.h" #include // SALOME GUI includes #include #include #include #include // IDL includes #include #include CORBA_SERVER_HEADER(SMESH_MeshEditor) //================================================================================ /*! * \brief Constructor * * Initialize operation */ //================================================================================ SMESHGUI_ConvToQuadOp::SMESHGUI_ConvToQuadOp() : SMESHGUI_SelectionOp(), myDlg( 0 ) { } //================================================================================ /*! * \brief Destructor */ //================================================================================ SMESHGUI_ConvToQuadOp::~SMESHGUI_ConvToQuadOp() { if ( myDlg ) delete myDlg; } //================================================================================ /*! * \brief Gets dialog of this operation * \retval LightApp_Dialog* - pointer to dialog of this operation */ //================================================================================ LightApp_Dialog* SMESHGUI_ConvToQuadOp::dlg() const { return myDlg; } //================================================================================ /*! * \brief Creates dialog if necessary and shows it * * Virtual method redefined from base class called when operation is started creates * dialog if necessary and shows it, activates selection */ //================================================================================ void SMESHGUI_ConvToQuadOp::startOperation() { if( !myDlg ) { myDlg = new SMESHGUI_ConvToQuadDlg( ); } connect( myDlg, SIGNAL( onClicked( int ) ), SLOT( ConnectRadioButtons( int ) ) ); myHelpFileName = "convert_to_from_quadratic_mesh_page.html"; SMESHGUI_SelectionOp::startOperation(); myDlg->SetMediumNdsOnGeom( false ); myDlg->activateObject( 0 ); myDlg->show(); selectionDone(); } //================================================================================ /*! * \brief Updates dialog's look and feel * * Virtual method redefined from the base class updates dialog's look and feel */ //================================================================================ void SMESHGUI_ConvToQuadOp::selectionDone() { if ( !dlg()->isVisible() ) return; SMESHGUI_SelectionOp::selectionDone(); try { QString anMeshEntry = myDlg->selectedObject( 0 ); _PTR(SObject) pMesh = studyDS()->FindObjectID( anMeshEntry.toLatin1().data() ); if ( !pMesh ) return; SMESH::SMESH_Mesh_var mesh = SMESH::SObjectToInterface( pMesh ); if( mesh->_is_nil() ) { myDlg->SetEnabledControls( false ); } else if( ConsistMesh( mesh ) == SMESHGUI_ConvToQuadOp::Quadratic ) { myDlg->SetEnabledRB( 0, false ); } else if( ConsistMesh( mesh ) == SMESHGUI_ConvToQuadOp::Linear ) { myDlg->SetEnabledRB( 1, false ); } else { myDlg->SetEnabledControls( true ); } } catch ( const SALOME::SALOME_Exception& S_ex ) { SalomeApp_Tools::QtCatchCorbaException( S_ex ); } catch ( ... ) { } } //================================================================================ /*! * \brief Creates selection filter * \param theId - identifier of current selection widget * \retval SUIT_SelectionFilter* - pointer to the created filter or null * * Creates selection filter in accordance with identifier of current selection widget */ //================================================================================ SUIT_SelectionFilter* SMESHGUI_ConvToQuadOp::createFilter( const int theId ) const { if ( theId == 0 ) return new SMESH_TypeFilter( MESH ); else return 0; } //================================================================================ /*! * \brief Edits mesh * * Virtual slot redefined from the base class called when "Apply" button is clicked */ //================================================================================ bool SMESHGUI_ConvToQuadOp::onApply() { SUIT_OverrideCursor aWaitCursor; QString aMess; QString anMeshEntry = myDlg->selectedObject( 0 ); _PTR(SObject) pMesh = studyDS()->FindObjectID( anMeshEntry.toLatin1().data() ); if ( !pMesh ) { dlg()->show(); SUIT_MessageBox::warning( myDlg, tr( "SMESH_WRN_WARNING" ), tr("MESH_IS_NOT_SELECTED") ); return false; } SMESH::SMESH_Mesh_var mesh = SMESH::SObjectToInterface( pMesh ); if( CORBA::is_nil(mesh) ) { SUIT_MessageBox::warning( myDlg, tr( "SMESH_WRN_WARNING" ), tr("REF_IS_NULL") ); return false; } bool aResult = false; try { SMESH::SMESH_MeshEditor_var aEditor = mesh->GetMeshEditor(); if( !myDlg->CurrentRB() ) { bool aParam = true; if( myDlg->IsEnabledCheck() ) aParam = myDlg->IsMediumNdsOnGeom(); aEditor->ConvertToQuadratic( aParam ); aResult = true; } else { aResult = aEditor->ConvertFromQuadratic(); } } catch ( const SALOME::SALOME_Exception& S_ex ) { SalomeApp_Tools::QtCatchCorbaException( S_ex ); aResult = false; } catch ( ... ) { aResult = false; } if( aResult ) { update( UF_ObjBrowser | UF_Model | UF_Viewer ); selectionDone(); } return aResult; } //================================================================================ /*! ConsistMesh * Determines, what elements this mesh contains. */ //================================================================================ SMESHGUI_ConvToQuadOp::MeshType SMESHGUI_ConvToQuadOp::ConsistMesh( const SMESH::SMESH_Mesh_var& mesh) const { int nbAllElem = 0, nbQEdges =0, nbQFaces =0, nbQVolum = 0; int nbEdges = 0, nbFaces = 0, nbVolum = 0; nbAllElem = (int)mesh->NbElements(); nbQEdges = (int)mesh->NbEdgesOfOrder(SMESH::ORDER_QUADRATIC); nbQFaces = (int)mesh->NbFacesOfOrder(SMESH::ORDER_QUADRATIC); nbQVolum = (int)mesh->NbVolumesOfOrder(SMESH::ORDER_QUADRATIC); nbEdges = (int)mesh->NbEdgesOfOrder(SMESH::ORDER_LINEAR); nbFaces = (int)mesh->NbFacesOfOrder(SMESH::ORDER_LINEAR); nbVolum = (int)mesh->NbVolumesOfOrder(SMESH::ORDER_LINEAR); if( nbAllElem == (nbQEdges+nbQFaces+nbQVolum) ) return SMESHGUI_ConvToQuadOp::Quadratic; else if ( nbAllElem == (nbEdges+nbFaces+nbVolum) ) return SMESHGUI_ConvToQuadOp::Linear; else return SMESHGUI_ConvToQuadOp::Comp; } void SMESHGUI_ConvToQuadOp::ConnectRadioButtons( int id ) { QString anMeshEntry = myDlg->selectedObject( 0 ); _PTR(SObject) pMesh = studyDS()->FindObjectID( anMeshEntry.toLatin1().data() ); if ( !pMesh ) return; SMESH::SMESH_Mesh_var mesh = SMESH::SObjectToInterface( pMesh ); GEOM::GEOM_Object_var mainGeom; mainGeom = mesh->GetShapeToMesh(); if( id || mainGeom->_is_nil() ) myDlg->SetEnabledCheck( false ); else myDlg->SetEnabledCheck( true ); }