// Copyright (C) 2007-2010 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.h" #include "SMESHGUI_ConvToQuadDlg.h" #include "SMESHGUI_Utils.h" #include "SMDSAbs_ElementType.hxx" #include "SMESH_TypeFilter.hxx" // 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->ShowWarning( false ); 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 anObjEntry = myDlg->selectedObject( 0 ); _PTR(SObject) pObj = studyDS()->FindObjectID( anObjEntry.toLatin1().data() ); if ( !pObj ) return; SMESH::SMESH_IDSource_var idSource = SMESH::SObjectToInterface( pObj ); myDlg->setButtonEnabled( true, QtxDialog::OK | QtxDialog::Apply ); if( idSource->_is_nil() ) { myDlg->SetEnabledControls( false ); myDlg->setButtonEnabled( false, QtxDialog::OK | QtxDialog::Apply ); return; } MeshType meshType = ConsistMesh( idSource ); if( meshType == SMESHGUI_ConvToQuadOp::Quadratic ) { myDlg->SetEnabledRB( 0, false ); } else if( meshType == SMESHGUI_ConvToQuadOp::Linear ) { myDlg->SetEnabledRB( 1, false ); } else { myDlg->SetEnabledControls( true ); } // show warning on non-conformal result mesh if ( ! idSource->_is_nil() ) { SMESH::SMESH_subMesh_var subMesh = SMESH::SObjectToInterface( pObj ); bool toShow = false; if ( !subMesh->_is_nil() ) { SMESH::SMESH_Mesh_var mesh = idSource->GetMesh(); idSource = SMESH::SMESH_IDSource::_narrow( mesh ); MeshType fullMeshType = ConsistMesh( idSource ); toShow = ( fullMeshType != Comp ); } myDlg->ShowWarning( toShow ); } } 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( MESHorSUBMESH ); 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 anObjEntry = myDlg->selectedObject( 0 ); _PTR(SObject) pObj = studyDS()->FindObjectID( anObjEntry.toLatin1().data() ); if ( !pObj ) { dlg()->show(); SUIT_MessageBox::warning( myDlg, tr( "SMESH_WRN_WARNING" ), tr("MESH_IS_NOT_SELECTED") ); return false; } SMESH::SMESH_Mesh_var mesh; SMESH::SMESH_IDSource_var idSource = SMESH::SObjectToInterface( pObj ); if( !CORBA::is_nil(idSource) ) mesh = idSource->GetMesh(); 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(); aResult = true; SMESH::SMESH_Mesh_var sourceMesh = SMESH::SObjectToInterface( pObj ); if( !myDlg->CurrentRB() ) { bool aParam = true; if( myDlg->IsEnabledCheck() ) aParam = myDlg->IsMediumNdsOnGeom(); if ( sourceMesh->_is_nil() ) aEditor->ConvertToQuadraticObject( aParam, idSource ); else aEditor->ConvertToQuadratic( aParam ); } else { if ( sourceMesh->_is_nil() ) aEditor->ConvertFromQuadraticObject( idSource ); else aEditor->ConvertFromQuadratic(); } } catch ( const SALOME::SALOME_Exception& S_ex ) { SalomeApp_Tools::QtCatchCorbaException( S_ex ); aResult = false; } catch ( ... ) { aResult = false; } if( aResult ) { SMESHGUI::Modified(); 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_IDSource_var& idSource) const { SMESH::long_array_var nbElemOfType = idSource->GetMeshInfo(); bool hasQuad = ( nbElemOfType[SMDSEntity_Quad_Edge ] || nbElemOfType[SMDSEntity_Quad_Triangle ] || nbElemOfType[SMDSEntity_Quad_Quadrangle] || nbElemOfType[SMDSEntity_Quad_Tetra ] || nbElemOfType[SMDSEntity_Quad_Hexa ] || nbElemOfType[SMDSEntity_Quad_Pyramid ] || nbElemOfType[SMDSEntity_Quad_Penta ] ); bool hasLin = ( nbElemOfType[SMDSEntity_Edge ] || nbElemOfType[SMDSEntity_Triangle ] || nbElemOfType[SMDSEntity_Quadrangle] || nbElemOfType[SMDSEntity_Tetra ] || nbElemOfType[SMDSEntity_Hexa ] || nbElemOfType[SMDSEntity_Pyramid ] || nbElemOfType[SMDSEntity_Penta ] ); if ( hasQuad && hasLin ) return Comp; return hasQuad ? Quadratic : Linear; } void SMESHGUI_ConvToQuadOp::ConnectRadioButtons( int id ) { QString anObjEntry = myDlg->selectedObject( 0 ); _PTR(SObject) pObj = studyDS()->FindObjectID( anObjEntry.toLatin1().data() ); if ( !pObj ) return; SMESH::SMESH_IDSource_var idSource = SMESH::SObjectToInterface( pObj ); SMESH::SMESH_Mesh_var mesh = idSource->GetMesh(); bool hasGeom = mesh->HasShapeToMesh(); if( id || !hasGeom ) myDlg->SetEnabledCheck( false ); else myDlg->SetEnabledCheck( true ); }