1 // Copyright (C) 2011-2020 CEA/DEN, EDF R&D
3 // This library is free software; you can redistribute it and/or
4 // modify it under the terms of the GNU Lesser General Public
5 // License as published by the Free Software Foundation; either
6 // version 2.1 of the License, or (at your option) any later version.
8 // This library is distributed in the hope that it will be useful,
9 // but WITHOUT ANY WARRANTY; without even the implied warranty of
10 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
11 // Lesser General Public License for more details.
13 // You should have received a copy of the GNU Lesser General Public
14 // License along with this library; if not, write to the Free Software
15 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
17 // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
20 // SMESH SMESHGUI : GUI for the adaptation in the SMESH component
21 // File : SMESHGUI_AdaptDlg.cxx
22 // Author : Gerald NICOLAS, EDF
26 #include "SMESHGUI_AdaptDlg.h"
28 // SALOME GUI includes
29 #include <SUIT_Desktop.h>
30 #include <SUIT_ResourceMgr.h>
31 #include <SUIT_Session.h>
32 #include <SalomeApp_Application.h>
33 #include <SalomeApp_Study.h>
36 // #include "MonCreateCase.h"
38 // SALOME KERNEL includes
39 #include "utilities.h"
40 #include <SALOME_LifeCycleCORBA.hxx>
42 //=================================================================================
43 // function : SMESHGUI_AdaptDlg()
45 //=================================================================================
46 SMESHGUI_AdaptDlg::SMESHGUI_AdaptDlg( SMESHGUI* theModule,
48 SMESH::SMESH_Mesh_ptr theMesh )
49 : mySMESHGUI( theModule )
51 action( theCommandID ) ;
54 //=================================================================================
55 // function : ~SMESHGUI_AdaptDlg()
56 // purpose : Destroys the object and frees any allocated resources
57 //=================================================================================
58 SMESHGUI_AdaptDlg::~SMESHGUI_AdaptDlg()
63 * \brief Pilote les actions d'adaption de maillage
65 * \return bool OK/notOK
67 void SMESHGUI_AdaptDlg::action (int theCommandID)
68 //=======================================================================
70 std::cout << "SMESHGUI_AdaptDlg::action avec theCommandID : " << theCommandID << std::endl;
73 // recupPreferences();
76 bool ok = OnGUIEvent (theCommandID) ;
77 if ( ! ok ) INFOS("Erreur");
83 // * \brief Gets the preferences for the adaptation
87 // * Pour chaque valeur, le defaut est la valeur definie dans ADAPT_Gen
88 // * . Si la recuperation dans config/salome s'est bien passee a la creation de ADAPT_Gen
89 // * ces valeurs sont les valeurs definies.
90 // * . Si cela ne s'est pas bien passe, ce sont les valeurs par defaut de ADAPT_Gen
92 // void SMESHGUI_AdaptDlg::recupPreferences()
94 // INFOS("Début de recupPreferences")
98 // SalomeApp_Application* app = dynamic_cast< SalomeApp_Application* >( SUIT_Session::session()->activeApplication() );
99 // SALOME_LifeCycleCORBA* ls = new SALOME_LifeCycleCORBA(app->namingService());
100 // Engines::EngineComponent_var comp = ls->FindOrLoad_Component("FactoryServer", "SMESH");
101 // ADAPT::ADAPT_Gen_var adaptGen = ADAPT::ADAPT_Gen::_narrow(comp);
102 // if (!CORBA::is_nil(adaptGen))
103 // adaptGen->UpdateStudy();
105 // SUIT_ResourceMgr* resMgr = mySMESHGUI->getApp()->resourceMgr();
110 // _LanguageShort = resMgr->stringValue("language", "language", "en" );
111 // INFOS ("Enregistrement de LanguageShort = " << _LanguageShort.toStdString().c_str() );
112 // // adaptGen->SetLanguageShort(_LanguageShort.toStdString().c_str());
114 // // B.2. Les publications avec HOMARD
115 // bool publish_mesh ;
117 // publish_mesh = resMgr->booleanValue("HOMARD", "homard_publish_mesh_in", false );
118 // if ( publish_mesh ) { _PublisMeshIN = 1 ; }
119 // else { _PublisMeshIN = 0 ; }
121 // publish_mesh = resMgr->booleanValue("HOMARD", "homard_publish_mesh_out", false );
122 // if ( publish_mesh ) { _PublisMeshOUT = 1 ; }
123 // else { _PublisMeshOUT = 0 ; }
125 // INFOS ("Enregistrement de PublisMeshIN = " << _PublisMeshIN<<", PublisMeshOUT = "<< _PublisMeshOUT);
126 // // adaptGen->SetPublisMesh(_PublisMeshIN, _PublisMeshOUT);
128 // // B.3. Les maximum pour YACS avec HOMARD
130 // _YACSMaxIter = resMgr->integerValue("HOMARD", "homard_yacs_max_iter", 0 );
131 // _YACSMaxNode = resMgr->integerValue("HOMARD", "homard_yacs_max_node", 0 );
132 // _YACSMaxElem = resMgr->integerValue("HOMARD", "homard_yacs_max_elem", 0 );
134 // INFOS ("Enregistrement de YACSMaxIter = " << _YACSMaxIter<<", YACSMaxNode = "<< _YACSMaxNode<<", YACSMaxElem = "<< _YACSMaxElem);
135 // // adaptGen->SetYACSMaximum(_YACSMaxIter, _YACSMaxNode, _YACSMaxElem);
137 // // B.4. La convergence pour YACS avec HOMARD
139 // QString QString_v = resMgr->stringValue ( "HOMARD", "homard_yacs_type_test", "None" );
140 // if ( ( QString_v == "VTest > VRef" ) || ( QString_v == "VTest > VRef" ) ) { _YACSTypeTest = 1 ; }
141 // else if ( ( QString_v == "VTest < VRef" ) || ( QString_v == "VTest < VRef" ) ) { _YACSTypeTest = 2 ; }
142 // else { _YACSTypeTest = 0 ; }
144 // INFOS ("Enregistrement de YACSTypeTest = " << _YACSTypeTest);
145 // // adaptGen->SetYACSConvergenceType(_YACSTypeTest);
150 * \brief Launches the GUI for the adaptation
151 * \param theCommandID - the integer that references the operation
152 * \return bool OK/notOK
154 bool SMESHGUI_AdaptDlg::OnGUIEvent (int theCommandID)
156 std::cout << "OnGUIEvent avec theCommandID : " << theCommandID << std::endl;
158 SalomeApp_Application* app = dynamic_cast< SalomeApp_Application* >( SUIT_Session::session()->activeApplication() );
159 if ( !app ) return false;
161 SalomeApp_Study* aStudy = dynamic_cast<SalomeApp_Study*> ( app->activeStudy() );
164 INFOS ( "FAILED to cast active study to SalomeApp_Study" );
168 SUIT_Desktop* parent = SUIT_Session::session()->activeApplication()->desktop();
170 SALOME_LifeCycleCORBA* ls = new SALOME_LifeCycleCORBA(app->namingService());
171 Engines::EngineComponent_var comp = ls->FindOrLoad_Component("FactoryServer", "SMESH");
172 // ADAPT::ADAPT_Gen_var adaptGen = ADAPT::ADAPT_Gen::_narrow(comp);
173 // if (!CORBA::is_nil(adaptGen))
174 // adaptGen->UpdateStudy();
176 mySMESHGUI->getApp()->updateObjectBrowser();
178 // B. Choix selon les commandes
180 SCRUTE(theCommandID);
181 switch (theCommandID)
183 case 8000: // Raffinement uniforme
185 INFOS("Raffinement uniforme");
189 case 8011: // Création d'un Cas
191 INFOS("Création d'un Cas");
192 // MonCreateCase *aDlg = new MonCreateCase( true,
193 // ADAPT::ADAPT_Gen::_duplicate(adaptGen) ) ;
197 case 8012: // Création d'un cas en poursuite d'une itération
199 INFOS("Création d'un cas en poursuite d'une itération");
203 case 8013: // Création d'une itération
205 INFOS("Création d'une itération" );
209 case 8014: // Calcule une itération
211 INFOS("Calcule une itération" );
215 case 8015: // Calcule une itération et publication
217 INFOS("Calcule une itération et publication");
221 case 8020: // Adaptation avec MG-Adpat
223 INFOS("Interface avec MG-Adapt" );
229 mySMESHGUI->getApp()->updateObjectBrowser();