1 // SMESH SMESHGUI : GUI for SMESH component
3 // Copyright (C) 2003 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
4 // CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
6 // This library is free software; you can redistribute it and/or
7 // modify it under the terms of the GNU Lesser General Public
8 // License as published by the Free Software Foundation; either
9 // version 2.1 of the License.
11 // This library is distributed in the hope that it will be useful,
12 // but WITHOUT ANY WARRANTY; without even the implied warranty of
13 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 // Lesser General Public License for more details.
16 // You should have received a copy of the GNU Lesser General Public
17 // License along with this library; if not, write to the Free Software
18 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
20 // See http://www.opencascade.org/SALOME/ or email : webmaster.salome@opencascade.org
24 // File : SMESH_Swig.cxx
25 // Author : Nicolas REJNERI
30 #include "SMESHGUI_Swig.hxx"
32 #include "Utils_ORB_INIT.hxx"
33 #include "Utils_SINGLETON.hxx"
36 #include "QAD_Application.h"
37 #include "QAD_Desktop.h"
38 #include "QAD_ResourceMgr.h"
40 #include "utilities.h"
42 // Open CASCADE Includes
46 #include <SALOMEconfig.h>
47 #include CORBA_SERVER_HEADER(SMESH_Gen)
48 #include CORBA_SERVER_HEADER(SMESH_Mesh)
49 #include CORBA_SERVER_HEADER(SMESH_Hypothesis)
50 #include CORBA_SERVER_HEADER(GEOM_Shape)
52 static CORBA::ORB_var _orb;
54 static char* ObjectToString (CORBA::Object_ptr obj)
56 return _orb->object_to_string(obj);
59 static CORBA::Object_ptr StringToObject (const char* ior)
61 return _orb->string_to_object(ior);
64 SMESH_Swig::SMESH_Swig()
66 MESSAGE("Constructeur");
70 void SMESH_Swig::Init(int studyID)
73 Engines::Component_var comp = QAD_Application::getDesktop()->getEngine("FactoryServer", "SMESH");
74 SMESH::SMESH_Gen_var CompMesh = SMESH::SMESH_Gen::_narrow(comp);
76 QAD_ResourceMgr* resMgr = QAD_Desktop::createResourceManager();
79 if (!resMgr->loadResources( "SMESH", msg ))
83 CORBA::Object_var obj = QAD_Application::getDesktop()->getNameService()->Resolve("/myStudyManager");
84 SALOMEDS::StudyManager_var myStudyMgr = SALOMEDS::StudyManager::_narrow(obj);
85 myStudy = myStudyMgr->GetStudyByID(studyID);
86 myStudyBuilder = myStudy->NewBuilder();
87 SALOMEDS::GenericAttribute_var anAttr;
88 SALOMEDS::AttributeName_var aName;
89 SALOMEDS::AttributePixMap_var aPixmap;
91 SALOMEDS::SComponent_var father = myStudy->FindComponent("MESH");
93 if (father->_is_nil()) {
94 father = myStudyBuilder->NewComponent("MESH");
95 anAttr = myStudyBuilder->FindOrCreateAttribute(father, "AttributeName");
96 aName = SALOMEDS::AttributeName::_narrow(anAttr);
97 //NRI aName->SetValue(QObject::tr("SMESH_MEN_COMPONENT"));
98 aName->SetValue( QAD_Application::getDesktop()->getComponentUserName( "SMESH" ) );
99 anAttr = myStudyBuilder->FindOrCreateAttribute(father, "AttributePixMap");
100 aPixmap = SALOMEDS::AttributePixMap::_narrow(anAttr);
101 aPixmap->SetPixMap( "ICON_OBJBROWSER_SMESH" );
103 myStudyBuilder->DefineComponentInstance(father, CompMesh );
104 mySComponentMesh = SALOMEDS::SComponent::_narrow( father );
107 Tag_HypothesisRoot = 1;
108 Tag_AlgorithmsRoot = 2;
111 Tag_RefOnAppliedHypothesis = 2;
112 Tag_RefOnAppliedAlgorithms = 3;
114 Tag_SubMeshOnVertex = 4;
115 Tag_SubMeshOnEdge = 5;
116 Tag_SubMeshOnFace = 6;
117 Tag_SubMeshOnSolid = 7;
118 Tag_SubMeshOnCompound = 8;
121 SMESH_Swig::~SMESH_Swig()
123 MESSAGE("Destructeur");
127 const char* SMESH_Swig::AddNewMesh(const char* IOR)
129 MESSAGE("AddNewMesh");
130 //Find or Create Hypothesis root
131 SALOMEDS::GenericAttribute_var anAttr;
132 SALOMEDS::AttributeName_var aName;
133 SALOMEDS::AttributeIOR_var anIOR;
134 SALOMEDS::AttributeSelectable_var aSelAttr;
135 SALOMEDS::AttributePixMap_var aPixmap;
137 SALOMEDS::SObject_var HypothesisRoot;
138 if (!mySComponentMesh->FindSubObject (Tag_HypothesisRoot, HypothesisRoot)) {
139 HypothesisRoot = myStudyBuilder->NewObjectToTag (mySComponentMesh, Tag_HypothesisRoot);
140 anAttr = myStudyBuilder->FindOrCreateAttribute(HypothesisRoot, "AttributeName");
141 aName = SALOMEDS::AttributeName::_narrow(anAttr);
142 aName->SetValue(QObject::tr("SMESH_MEN_HYPOTHESIS"));
143 anAttr = myStudyBuilder->FindOrCreateAttribute(HypothesisRoot, "AttributePixMap");
144 aPixmap = SALOMEDS::AttributePixMap::_narrow(anAttr);
145 aPixmap->SetPixMap( "ICON_SMESH_TREE_HYPO" );
146 anAttr = myStudyBuilder->FindOrCreateAttribute(HypothesisRoot, "AttributeSelectable");
147 aSelAttr = SALOMEDS::AttributeSelectable::_narrow(anAttr);
148 aSelAttr->SetSelectable(false);
151 SALOMEDS::SObject_var AlgorithmsRoot;
152 if (!mySComponentMesh->FindSubObject (Tag_AlgorithmsRoot, AlgorithmsRoot)) {
153 AlgorithmsRoot = myStudyBuilder->NewObjectToTag (mySComponentMesh, Tag_AlgorithmsRoot);
154 anAttr = myStudyBuilder->FindOrCreateAttribute(AlgorithmsRoot, "AttributeName");
155 aName = SALOMEDS::AttributeName::_narrow(anAttr);
156 aName->SetValue(QObject::tr("SMESH_MEN_ALGORITHMS"));
157 anAttr = myStudyBuilder->FindOrCreateAttribute(AlgorithmsRoot, "AttributePixMap");
158 aPixmap = SALOMEDS::AttributePixMap::_narrow(anAttr);
159 aPixmap->SetPixMap( "ICON_SMESH_TREE_ALGO" );
160 anAttr = myStudyBuilder->FindOrCreateAttribute(AlgorithmsRoot, "AttributeSelectable");
161 aSelAttr = SALOMEDS::AttributeSelectable::_narrow(anAttr);
162 aSelAttr->SetSelectable(false);
166 SALOMEDS::SObject_var newMesh = myStudyBuilder->NewObject(mySComponentMesh);
167 anAttr = myStudyBuilder->FindOrCreateAttribute(newMesh, "AttributePixMap");
168 aPixmap = SALOMEDS::AttributePixMap::_narrow(anAttr);
169 aPixmap->SetPixMap( "ICON_SMESH_TREE_MESH" );
170 anAttr = myStudyBuilder->FindOrCreateAttribute(newMesh, "AttributeIOR");
171 anIOR = SALOMEDS::AttributeIOR::_narrow(anAttr);
172 anIOR->SetValue(IOR);
173 return SALOMEDS::SObject::_narrow( newMesh )->GetID();
176 const char* SMESH_Swig::AddNewHypothesis(const char* IOR)
178 MESSAGE("AddNewHypothesis");
179 //Find or Create Hypothesis root
180 SALOMEDS::SObject_var HypothesisRoot;
181 SALOMEDS::GenericAttribute_var anAttr;
182 SALOMEDS::AttributeName_var aName;
183 SALOMEDS::AttributeIOR_var anIOR;
184 SALOMEDS::AttributeSelectable_var aSelAttr;
185 SALOMEDS::AttributePixMap_var aPixmap;
187 if (!mySComponentMesh->FindSubObject (Tag_HypothesisRoot, HypothesisRoot)) {
188 HypothesisRoot = myStudyBuilder->NewObjectToTag (mySComponentMesh, Tag_HypothesisRoot);
189 anAttr = myStudyBuilder->FindOrCreateAttribute(HypothesisRoot, "AttributeName");
190 aName = SALOMEDS::AttributeName::_narrow(anAttr);
191 aName->SetValue(QObject::tr("SMESH_MEN_HYPOTHESIS"));
192 anAttr = myStudyBuilder->FindOrCreateAttribute(HypothesisRoot, "AttributeSelectable");
193 aSelAttr = SALOMEDS::AttributeSelectable::_narrow(anAttr);
194 aSelAttr->SetSelectable(false);
195 anAttr = myStudyBuilder->FindOrCreateAttribute(HypothesisRoot, "AttributePixMap");
196 aPixmap = SALOMEDS::AttributePixMap::_narrow(anAttr);
197 aPixmap->SetPixMap( "ICON_SMESH_TREE_HYPO" );
199 // Add New Hypothesis
200 SALOMEDS::SObject_var newHypo = myStudyBuilder->NewObject(HypothesisRoot);
201 anAttr = myStudyBuilder->FindOrCreateAttribute(newHypo, "AttributePixMap");
202 aPixmap = SALOMEDS::AttributePixMap::_narrow(anAttr);
203 SMESH::SMESH_Hypothesis_var H = SMESH::SMESH_Hypothesis::_narrow( StringToObject(IOR) );
204 QString aType = H->GetName();
205 aPixmap->SetPixMap( "ICON_SMESH_TREE_HYPO_" + aType );
206 // if ( aType.compare("LocalLength") == 0 )
207 // aPixmap->SetPixMap( "ICON_SMESH_TREE_HYPO_LENGTH" );
208 // else if ( aType.compare("NumberOfSegments") == 0 )
209 // aPixmap->SetPixMap( "ICON_SMESH_TREE_HYPO_SEGMENT" );
210 // else if ( aType.compare("MaxElementArea") == 0 )
211 // aPixmap->SetPixMap( "ICON_SMESH_TREE_HYPO_AREA" );
212 // else if ( aType.compare("MaxElementVolume") == 0 )
213 // aPixmap->SetPixMap( "ICON_SMESH_TREE_HYPO_VOLUME" );
214 anAttr = myStudyBuilder->FindOrCreateAttribute(newHypo, "AttributeIOR");
215 anIOR = SALOMEDS::AttributeIOR::_narrow(anAttr);
216 anIOR->SetValue(IOR);
217 return SALOMEDS::SObject::_narrow(newHypo)->GetID();
220 const char* SMESH_Swig::AddNewAlgorithms(const char* IOR)
222 MESSAGE("AddNewAlgorithms");
223 //Find or Create Algorithms root
224 SALOMEDS::SObject_var AlgorithmsRoot;
225 SALOMEDS::GenericAttribute_var anAttr;
226 SALOMEDS::AttributeName_var aName;
227 SALOMEDS::AttributeIOR_var anIOR;
228 SALOMEDS::AttributeSelectable_var aSelAttr;
229 SALOMEDS::AttributePixMap_var aPixmap;
231 if (!mySComponentMesh->FindSubObject (Tag_AlgorithmsRoot, AlgorithmsRoot)) {
232 AlgorithmsRoot = myStudyBuilder->NewObjectToTag (mySComponentMesh, Tag_AlgorithmsRoot);
233 anAttr = myStudyBuilder->FindOrCreateAttribute(AlgorithmsRoot, "AttributeName");
234 aName = SALOMEDS::AttributeName::_narrow(anAttr);
235 aName->SetValue(QObject::tr("SMESH_MEN_ALGORITHMS"));
236 anAttr = myStudyBuilder->FindOrCreateAttribute(AlgorithmsRoot, "AttributeSelectable");
237 aSelAttr = SALOMEDS::AttributeSelectable::_narrow(anAttr);
238 aSelAttr->SetSelectable(false);
239 anAttr = myStudyBuilder->FindOrCreateAttribute(AlgorithmsRoot, "AttributePixMap");
240 aPixmap = SALOMEDS::AttributePixMap::_narrow(anAttr);
241 aPixmap->SetPixMap( "ICON_SMESH_TREE_ALGO" );
243 // Add New Algorithms
244 SALOMEDS::SObject_var newHypo = myStudyBuilder->NewObject(AlgorithmsRoot);
245 anAttr = myStudyBuilder->FindOrCreateAttribute(newHypo, "AttributePixMap");
246 aPixmap = SALOMEDS::AttributePixMap::_narrow(anAttr);
247 SMESH::SMESH_Hypothesis_var H = SMESH::SMESH_Hypothesis::_narrow( StringToObject(IOR) );
248 QString aType = H->GetName();
249 aPixmap->SetPixMap( "ICON_SMESH_TREE_ALGO_" + aType );
250 // if ( aType.compare("Regular_1D") == 0 )
251 // aPixmap->SetPixMap( "ICON_SMESH_TREE_ALGO_REGULAR" );
252 // else if ( aType.compare("MEFISTO_2D") == 0 )
253 // aPixmap->SetPixMap( "ICON_SMESH_TREE_ALGO_MEFISTO" );
254 // else if ( aType.compare("Quadrangle_2D") == 0 )
255 // aPixmap->SetPixMap( "ICON_SMESH_TREE_ALGO_QUAD" );
256 // else if ( aType.compare("Hexa_3D") == 0 )
257 // aPixmap->SetPixMap( "ICON_SMESH_TREE_ALGO_HEXA" );
258 anAttr = myStudyBuilder->FindOrCreateAttribute(newHypo, "AttributeIOR");
259 anIOR = SALOMEDS::AttributeIOR::_narrow(anAttr);
260 anIOR->SetValue(IOR);
261 return SALOMEDS::SObject::_narrow(newHypo)->GetID();
264 void SMESH_Swig::SetShape(const char* ShapeEntry, const char* MeshEntry)
266 SALOMEDS::SObject_var SO_MorSM = myStudy->FindObjectID( MeshEntry );
267 SALOMEDS::SObject_var SO_GeomShape = myStudy->FindObjectID( ShapeEntry );
269 if ( !SO_MorSM->_is_nil() && !SO_GeomShape->_is_nil() ) {
270 SALOMEDS::SObject_var SO = myStudyBuilder->NewObjectToTag (SO_MorSM, Tag_RefOnShape);
271 myStudyBuilder->Addreference (SO,SO_GeomShape);
275 void SMESH_Swig::SetHypothesis(const char* Mesh_Or_SubMesh_Entry, const char* Hypothesis_Entry)
277 SALOMEDS::SObject_var SO_MorSM = myStudy->FindObjectID( Mesh_Or_SubMesh_Entry );
278 SALOMEDS::SObject_var SO_Hypothesis = myStudy->FindObjectID( Hypothesis_Entry );
279 SALOMEDS::GenericAttribute_var anAttr;
280 SALOMEDS::AttributeName_var aName;
281 SALOMEDS::AttributeSelectable_var aSelAttr;
282 SALOMEDS::AttributePixMap_var aPixmap;
284 if ( !SO_MorSM->_is_nil() && !SO_Hypothesis->_is_nil() ) {
286 //Find or Create Applied Hypothesis root
287 SALOMEDS::SObject_var AHR;
288 if (!SO_MorSM->FindSubObject (Tag_RefOnAppliedHypothesis, AHR)) {
289 AHR = myStudyBuilder->NewObjectToTag (SO_MorSM, Tag_RefOnAppliedHypothesis);
290 anAttr = myStudyBuilder->FindOrCreateAttribute(AHR, "AttributeName");
291 aName = SALOMEDS::AttributeName::_narrow(anAttr);
292 aName->SetValue(QObject::tr("SMESH_MEN_APPLIED_HYPOTHESIS"));
293 anAttr = myStudyBuilder->FindOrCreateAttribute(AHR, "AttributeSelectable");
294 aSelAttr = SALOMEDS::AttributeSelectable::_narrow(anAttr);
295 aSelAttr->SetSelectable(false);
296 anAttr = myStudyBuilder->FindOrCreateAttribute(AHR, "AttributePixMap");
297 aPixmap = SALOMEDS::AttributePixMap::_narrow(anAttr);
298 aPixmap->SetPixMap( "ICON_SMESH_TREE_HYPO" );
300 SALOMEDS::SObject_var SO = myStudyBuilder->NewObject(AHR);
301 myStudyBuilder->Addreference (SO,SO_Hypothesis);
304 void SMESH_Swig::SetAlgorithms(const char* Mesh_Or_SubMesh_Entry, const char* Algorithms_Entry)
306 SALOMEDS::SObject_var SO_MorSM = myStudy->FindObjectID( Mesh_Or_SubMesh_Entry );
307 SALOMEDS::SObject_var SO_Algorithms = myStudy->FindObjectID( Algorithms_Entry );
308 SALOMEDS::GenericAttribute_var anAttr;
309 SALOMEDS::AttributeName_var aName;
310 SALOMEDS::AttributeSelectable_var aSelAttr;
311 SALOMEDS::AttributePixMap_var aPixmap;
313 if ( !SO_MorSM->_is_nil() && !SO_Algorithms->_is_nil() ) {
314 //Find or Create Applied Algorithms root
315 SALOMEDS::SObject_var AHR;
316 if (!SO_MorSM->FindSubObject (Tag_RefOnAppliedAlgorithms, AHR)) {
317 AHR = myStudyBuilder->NewObjectToTag (SO_MorSM, Tag_RefOnAppliedAlgorithms);
318 anAttr = myStudyBuilder->FindOrCreateAttribute(AHR, "AttributeName");
319 aName = SALOMEDS::AttributeName::_narrow(anAttr);
320 aName->SetValue(QObject::tr("SMESH_MEN_APPLIED_ALGORIHTMS"));
321 anAttr = myStudyBuilder->FindOrCreateAttribute(AHR, "AttributeSelectable");
322 aSelAttr = SALOMEDS::AttributeSelectable::_narrow(anAttr);
323 aSelAttr->SetSelectable(false);
324 anAttr = myStudyBuilder->FindOrCreateAttribute(AHR, "AttributePixMap");
325 aPixmap = SALOMEDS::AttributePixMap::_narrow(anAttr);
326 aPixmap->SetPixMap( "ICON_SMESH_TREE_ALGO" );
328 SALOMEDS::SObject_var SO = myStudyBuilder->NewObject(AHR);
329 myStudyBuilder->Addreference (SO,SO_Algorithms);
333 void SMESH_Swig::UnSetHypothesis(const char* Applied_Hypothesis_Entry )
335 SALOMEDS::SObject_var SO_Applied_Hypothesis = myStudy->FindObjectID( Applied_Hypothesis_Entry );
336 if ( !SO_Applied_Hypothesis->_is_nil() )
337 myStudyBuilder->RemoveObject(SO_Applied_Hypothesis);
341 const char* SMESH_Swig::AddSubMesh(const char* SO_Mesh_Entry, const char* SM_IOR, int ST)
343 SALOMEDS::SObject_var SO_Mesh = myStudy->FindObjectID( SO_Mesh_Entry );
344 if ( !SO_Mesh->_is_nil() ) {
347 Standard_CString Name;
349 if (ST == TopAbs_SOLID) {Tag_Shape = Tag_SubMeshOnSolid; Name = strdup(QObject::tr("SMESH_MEN_SubMeshesOnSolid"));}
350 else if (ST == TopAbs_FACE) {Tag_Shape = Tag_SubMeshOnFace; Name = strdup(QObject::tr("SMESH_MEN_SubMeshesOnFace"));}
351 else if (ST == TopAbs_EDGE) {Tag_Shape = Tag_SubMeshOnEdge; Name = strdup(QObject::tr("SMESH_MEN_SubMeshesOnEdge"));}
352 else if (ST == TopAbs_VERTEX){Tag_Shape = Tag_SubMeshOnVertex; Name = strdup(QObject::tr("SMESH_MEN_SubMeshesOnVertex"));}
354 Tag_Shape = Tag_SubMeshOnCompound; Name = strdup(QObject::tr("SMESH_MEN_SubMeshesOnCompound"));
356 SALOMEDS::SObject_var SubmeshesRoot;
357 SALOMEDS::GenericAttribute_var anAttr;
358 SALOMEDS::AttributeName_var aName;
359 SALOMEDS::AttributeIOR_var anIOR;
360 SALOMEDS::AttributeSelectable_var aSelAttr;
361 if (!SO_Mesh->FindSubObject (Tag_Shape,SubmeshesRoot )) {
362 SubmeshesRoot = myStudyBuilder->NewObjectToTag (SO_Mesh, Tag_Shape);
363 anAttr = myStudyBuilder->FindOrCreateAttribute(SubmeshesRoot, "AttributeName");
364 aName = SALOMEDS::AttributeName::_narrow(anAttr);
365 aName->SetValue(Name);
366 anAttr = myStudyBuilder->FindOrCreateAttribute(SubmeshesRoot, "AttributeSelectable");
367 aSelAttr = SALOMEDS::AttributeSelectable::_narrow(anAttr);
368 aSelAttr->SetSelectable(false);
370 SALOMEDS::SObject_var SO = myStudyBuilder->NewObject (SubmeshesRoot);
371 anAttr = myStudyBuilder->FindOrCreateAttribute(SO, "AttributeIOR");
372 anIOR = SALOMEDS::AttributeIOR::_narrow(anAttr);
373 anIOR->SetValue(SM_IOR);
374 return SALOMEDS::SObject::_narrow( SO )->GetID();
379 const char* SMESH_Swig::AddSubMeshOnShape(const char* Mesh_Entry, const char* GeomShape_Entry,
380 const char* SM_IOR, int ST)
382 SALOMEDS::SObject_var SO_GeomShape = myStudy->FindObjectID( GeomShape_Entry );
383 if ( !SO_GeomShape->_is_nil() ) {
384 const char * SM_Entry = AddSubMesh (Mesh_Entry,SM_IOR,ST);
385 SALOMEDS::SObject_var SO_SM = myStudy->FindObjectID( SM_Entry );
386 if ( !SO_SM->_is_nil() ) {
387 SetShape (GeomShape_Entry, SM_Entry);
388 return SALOMEDS::SObject::_narrow( SO_SM )->GetID();
394 void SMESH_Swig::CreateAndDisplayActor( const char* Mesh_Entry )
396 // SMESH_Actor* Mesh = smeshGUI->ReadScript(aM);
399 void SMESH_Swig::SetName(const char* Entry, const char* Name)
401 SALOMEDS::SObject_var SO = myStudy->FindObjectID( Entry );
402 SALOMEDS::GenericAttribute_var anAttr;
403 SALOMEDS::AttributeName_var aName;
404 if ( !SO->_is_nil() ) {
405 anAttr = myStudyBuilder->FindOrCreateAttribute(SO, "AttributeName");
406 aName = SALOMEDS::AttributeName::_narrow(anAttr);
407 aName->SetValue(Name);
412 void SMESH_Swig::setOrb()
415 ORB_INIT &init = *SINGLETON_<ORB_INIT>::Instance();
416 ASSERT(SINGLETON_<ORB_INIT>::IsAlreadyExisting());
417 _orb = init( 0 , 0 );
419 INFOS("internal error : orb not found");
422 ASSERT(! CORBA::is_nil(_orb));