// Copyright (C) 2007-2013 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_Utils.cxx // Author : Open CASCADE S.A.S. // SMESH includes // #include "SMESHGUI_Utils.h" #include "SMESHGUI.h" #include "SMESHGUI_Selection.h" #include "SMESH_Type.h" #include #include // SALOME GUI includes #include #include #include #include #include #include #include #include #include // OCC includes #include #include #include CORBA_SERVER_HEADER(SMESH_Group) namespace SMESH { SUIT_Desktop* GetDesktop(const CAM_Module* theModule) { return theModule->application()->desktop(); } LightApp_SelectionMgr* GetSelectionMgr(const SalomeApp_Module* theModule) { return theModule->getApp()->selectionMgr(); } SUIT_ResourceMgr* GetResourceMgr( const SalomeApp_Module* ) { return SUIT_Session::session()->resourceMgr(); } _PTR(Study) GetCStudy(const SalomeApp_Study* theStudy) { return theStudy->studyDS(); } CORBA::Object_var DataOwnerToObject(const LightApp_DataOwnerPtr& theOwner) { CORBA::Object_var anObj; if(theOwner){ const Handle(SALOME_InteractiveObject)& anIO = theOwner->IO(); if(!anIO.IsNull()){ if(anIO->hasEntry()){ _PTR(Study) aStudy = GetActiveStudyDocument(); _PTR(SObject) aSObj = aStudy->FindObjectID(anIO->getEntry()); anObj = SObjectToObject(aSObj,aStudy); } } } return anObj; } SUIT_Study* GetActiveStudy() { SUIT_Application* app = SUIT_Session::session()->activeApplication(); if (app) return app->activeStudy(); else return NULL; } SUIT_ViewWindow* GetActiveWindow() { SalomeApp_Application* app = dynamic_cast (SUIT_Session::session()->activeApplication()); if (app && app->desktop() ) return app->desktop()->activeWindow(); else return NULL; } _PTR(Study) GetActiveStudyDocument() { SalomeApp_Study* aStudy = dynamic_cast(GetActiveStudy()); if (aStudy) return aStudy->studyDS(); else return _PTR(Study)(); } _PTR(SObject) FindSObject (CORBA::Object_ptr theObject) { SalomeApp_Application* app = dynamic_cast (SUIT_Session::session()->activeApplication()); if (app && !CORBA::is_nil(theObject)) { if(_PTR(Study) aStudy = GetActiveStudyDocument()){ CORBA::String_var anIOR = app->orb()->object_to_string(theObject); if (strcmp(anIOR.in(), "") != 0) return aStudy->FindObjectIOR(anIOR.in()); } } return _PTR(SObject)(); } void SetName (_PTR(SObject) theSObject, const QString& theName) { _PTR(Study) aStudy = GetActiveStudyDocument(); if (aStudy->GetProperties()->IsLocked()) return; SMESHGUI::GetSMESHGen()->SetName(theSObject->GetIOR().c_str(), theName.toLatin1().data()); } void SetValue (_PTR(SObject) theSObject, const QString& theValue) { _PTR(Study) aStudy = GetActiveStudyDocument(); if (aStudy->GetProperties()->IsLocked()) return; _PTR(StudyBuilder) aBuilder = aStudy->NewBuilder(); _PTR(GenericAttribute) anAttr = aBuilder->FindOrCreateAttribute(theSObject, "AttributeComment"); _PTR(AttributeComment) aComment = anAttr; if (aComment) aComment->SetValue(theValue.toLatin1().data()); } void setFileName (_PTR(SObject) theSObject, const QString& theValue) { _PTR(Study) aStudy = GetActiveStudyDocument(); if (aStudy->GetProperties()->IsLocked()) return; _PTR(StudyBuilder) aBuilder = aStudy->NewBuilder(); _PTR(GenericAttribute) anAttr = aBuilder->FindOrCreateAttribute(theSObject, "AttributeExternalFileDef"); _PTR(AttributeExternalFileDef) aFileName = anAttr; if (aFileName) aFileName->SetValue(theValue.toLatin1().data()); } void setFileType (_PTR(SObject) theSObject, const QString& theValue) { _PTR(Study) aStudy = GetActiveStudyDocument(); if (aStudy->GetProperties()->IsLocked()) return; _PTR(StudyBuilder) aBuilder = aStudy->NewBuilder(); _PTR(GenericAttribute) anAttr = aBuilder->FindOrCreateAttribute(theSObject, "AttributeFileType"); _PTR(AttributeFileType) aFileType = anAttr; if (aFileType) aFileType->SetValue(theValue.toLatin1().data()); } CORBA::Object_var SObjectToObject (_PTR(SObject) theSObject, _PTR(Study) theStudy) { SalomeApp_Application* app = dynamic_cast (SUIT_Session::session()->activeApplication()); if (theSObject) { _PTR(GenericAttribute) anAttr; if (theSObject->FindAttribute(anAttr, "AttributeIOR")) { _PTR(AttributeIOR) anIOR = anAttr; CORBA::String_var aVal = anIOR->Value().c_str(); // string_to_object() DOC: If the input string is not valid ... // a CORBA::SystemException is thrown. if ( aVal && strlen( aVal ) > 0 ) return app->orb()->string_to_object(aVal); } } return CORBA::Object::_nil(); } CORBA::Object_var SObjectToObject (_PTR(SObject) theSObject) { _PTR(Study) aStudy = GetActiveStudyDocument(); return SObjectToObject(theSObject,aStudy); } _PTR(SObject) ObjectToSObject( CORBA::Object_ptr theObject ) { _PTR(SObject) res; SalomeApp_Application* app = dynamic_cast (SUIT_Session::session()->activeApplication()); if ( app ) { QString IOR = app->orb()->object_to_string( theObject ); SalomeApp_Study* study = dynamic_cast( app->activeStudy() ); if ( study && !IOR.isEmpty() ) res = study->studyDS()->FindObjectIOR( IOR.toLatin1().constData() ); } return res; } CORBA::Object_var IObjectToObject (const Handle(SALOME_InteractiveObject)& theIO) { if (!theIO.IsNull()) { if (theIO->hasEntry()) { _PTR(Study) aStudy = GetActiveStudyDocument(); _PTR(SObject) anObj = aStudy->FindObjectID(theIO->getEntry()); return SObjectToObject(anObj,aStudy); } } return CORBA::Object::_nil(); } CORBA::Object_var IORToObject (const QString& theIOR) { SalomeApp_Application* app = dynamic_cast (SUIT_Session::session()->activeApplication()); return app->orb()->string_to_object(theIOR.toLatin1().data()); } int GetNameOfSelectedIObjects(LightApp_SelectionMgr* theMgr, QString& theName) { if (!theMgr) return 0; SALOME_ListIO selected; theMgr->selectedObjects(selected); int aNbSel = selected.Extent(); if (aNbSel == 1) { Handle(SALOME_InteractiveObject) anIObject = selected.First(); theName = QString( anIObject->getName() ).trimmed(); } else { theName = QObject::tr("SMESH_OBJECTS_SELECTED").arg(aNbSel); } return aNbSel; } _PTR(SObject) GetMeshOrSubmesh (_PTR(SObject) theSObject) { GEOM::GEOM_Object_var aShape = SObjectToInterface(theSObject); if (!aShape->_is_nil()){ //It s a shape return theSObject->GetFather(); } _PTR(SObject) aSObject; if (theSObject->ReferencedObject(aSObject)) { aSObject = theSObject->GetFather(); return aSObject->GetFather(); } return theSObject->GetFather(); } void ModifiedMesh (_PTR(SObject) theSObject, bool theIsNotModif, bool isEmptyMesh) { _PTR(Study) aStudy = GetActiveStudyDocument(); if (aStudy->GetProperties()->IsLocked()) return; _PTR(StudyBuilder) aBuilder = aStudy->NewBuilder(); _PTR(GenericAttribute) anAttr = aBuilder->FindOrCreateAttribute(theSObject,"AttributePixMap"); _PTR(AttributePixMap) aPixmap = anAttr; std::string pmName; if (theIsNotModif) pmName = "ICON_SMESH_TREE_MESH"; else if ( isEmptyMesh ) pmName = "ICON_SMESH_TREE_MESH_WARN"; else pmName = "ICON_SMESH_TREE_MESH_PARTIAL"; aPixmap->SetPixMap( pmName ); _PTR(ChildIterator) anIter = aStudy->NewChildIterator(theSObject); for (int i = 1; anIter->More(); anIter->Next(), i++) { _PTR(SObject) aSObj = anIter->Value(); if (i >= 4) { _PTR(ChildIterator) anIter1 = aStudy->NewChildIterator(aSObj); for ( ; anIter1->More(); anIter1->Next()) { _PTR(SObject) aSObj1 = anIter1->Value(); anAttr = aBuilder->FindOrCreateAttribute(aSObj1, "AttributePixMap"); aPixmap = anAttr; std::string entry = aSObj1->GetID(); int objType = SMESHGUI_Selection::type( entry.c_str(), aStudy ); SMESH::SMESH_IDSource_var idSrc = SObjectToInterface( aSObj1 ); if ( !idSrc->_is_nil() ) { SMESH::SMESH_GroupOnFilter_var gof = SObjectToInterface( aSObj1 ); const bool isGroupOnFilter = !gof->_is_nil(); bool isEmpty = false; if ( !isGroupOnFilter ) // GetTypes() can be very long on isGroupOnFilter! { SMESH::array_of_ElementType_var elemTypes = idSrc->GetTypes(); isEmpty = ( elemTypes->length() == 0 ); } if ( isEmpty ) aPixmap->SetPixMap("ICON_SMESH_TREE_MESH_WARN"); else if ( objType != GROUP ) aPixmap->SetPixMap( "ICON_SMESH_TREE_MESH" ); else if ( isGroupOnFilter ) aPixmap->SetPixMap( "ICON_SMESH_TREE_GROUP_ON_FILTER" ); else aPixmap->SetPixMap( "ICON_SMESH_TREE_GROUP" ); } else { if ( !theIsNotModif ) aPixmap->SetPixMap( pmName ); else if ( objType == GROUP ) aPixmap->SetPixMap( "ICON_SMESH_TREE_GROUP" ); else aPixmap->SetPixMap( "ICON_SMESH_TREE_MESH" ); } } } } } void ShowHelpFile (const QString& theHelpFileName) { LightApp_Application* app = (LightApp_Application*)(SUIT_Session::session()->activeApplication()); if (app) { SMESHGUI* gui = SMESHGUI::GetSMESHGUI(); app->onHelpContextModule(gui ? app->moduleName(gui->moduleName()) : QString(""), theHelpFileName); } else { SUIT_MessageBox::warning(0, QObject::tr("WRN_WARNING"), QObject::tr("EXTERNAL_BROWSER_CANNOT_SHOW_PAGE"). arg(app->resourceMgr()->stringValue("ExternalBrowser", "application")). arg(theHelpFileName)); } } //======================================================================= /** Return normale to a given face */ //======================================================================= gp_XYZ getNormale( const SMDS_MeshFace* theFace ) { gp_XYZ n; int aNbNode = theFace->NbNodes(); TColgp_Array1OfXYZ anArrOfXYZ(1,4); SMDS_ElemIteratorPtr aNodeItr = theFace->nodesIterator(); int i = 1; for ( ; aNodeItr->more() && i <= 4; i++ ) { SMDS_MeshNode* aNode = (SMDS_MeshNode*)aNodeItr->next(); anArrOfXYZ.SetValue(i, gp_XYZ( aNode->X(), aNode->Y(), aNode->Z() ) ); } gp_XYZ q1 = anArrOfXYZ.Value(2) - anArrOfXYZ.Value(1); gp_XYZ q2 = anArrOfXYZ.Value(3) - anArrOfXYZ.Value(1); n = q1 ^ q2; if ( aNbNode > 3 ) { gp_XYZ q3 = anArrOfXYZ.Value(4) - anArrOfXYZ.Value(1); n += q2 ^ q3; } double len = n.Modulus(); if ( len > 0 ) n /= len; return n; } } // end of namespace SMESH