X-Git-Url: http://git.salome-platform.org/gitweb/?p=modules%2Fsmesh.git;a=blobdiff_plain;f=src%2FSMESHGUI%2FSMESHGUI_Utils.cxx;h=1bfe56991fa011b6ed67c5574ffc9600a8d71836;hp=383b02c5c68d58be3b196eac08b7aa162bb17d63;hb=62c4337c5becb0add8bff676b465f70cc5f4e513;hpb=4ff5bd61540272713e48de1eee75625028c32155 diff --git a/src/SMESHGUI/SMESHGUI_Utils.cxx b/src/SMESHGUI/SMESHGUI_Utils.cxx index 383b02c5c..1bfe56991 100644 --- a/src/SMESHGUI/SMESHGUI_Utils.cxx +++ b/src/SMESHGUI/SMESHGUI_Utils.cxx @@ -1,4 +1,6 @@ -// Copyright (C) 2003 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN, +// 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 @@ -15,35 +17,32 @@ // 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.opencascade.org/SALOME/ or email : webmaster.salome@opencascade.org - - -#include - +// 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 "OB_Browser.h" - -#include "SUIT_Desktop.h" -#include "SUIT_Application.h" -#include "SUIT_Session.h" - -#include "LightApp_SelectionMgr.h" -#include "SalomeApp_Application.h" -#include "SalomeApp_Module.h" -#include "SalomeApp_Study.h" - -#include "SALOME_ListIO.hxx" +#include "SMESHGUI.h" -#include "SALOMEconfig.h" -#include CORBA_CLIENT_HEADER(GEOM_Gen) +// SALOME GUI includes +#include +#include +#include +#include -#include "utilities.h" +#include +#include +#include +#include -//using namespace std; - -namespace SMESH{ +#include +namespace SMESH +{ SUIT_Desktop* GetDesktop(const CAM_Module* theModule) { @@ -85,7 +84,6 @@ namespace SMESH{ return anObj; } - SUIT_Study* GetActiveStudy() { SUIT_Application* app = SUIT_Session::session()->activeApplication(); @@ -128,7 +126,7 @@ namespace SMESH{ return _PTR(SObject)(); } - void SetName (_PTR(SObject) theSObject, const char* theName) + void SetName (_PTR(SObject) theSObject, const QString& theName) { _PTR(Study) aStudy = GetActiveStudyDocument(); if (aStudy->GetProperties()->IsLocked()) @@ -138,10 +136,10 @@ namespace SMESH{ aBuilder->FindOrCreateAttribute(theSObject, "AttributeName"); _PTR(AttributeName) aName = anAttr; if (aName) - aName->SetValue(theName); + aName->SetValue(theName.toLatin1().data()); } - void SetValue (_PTR(SObject) theSObject, const char* theValue) + void SetValue (_PTR(SObject) theSObject, const QString& theValue) { _PTR(Study) aStudy = GetActiveStudyDocument(); if (aStudy->GetProperties()->IsLocked()) @@ -151,10 +149,10 @@ namespace SMESH{ aBuilder->FindOrCreateAttribute(theSObject, "AttributeComment"); _PTR(AttributeComment) aComment = anAttr; if (aComment) - aComment->SetValue(theValue); + aComment->SetValue(theValue.toLatin1().data()); } - void setFileName (_PTR(SObject) theSObject, const char* theValue) + void setFileName (_PTR(SObject) theSObject, const QString& theValue) { _PTR(Study) aStudy = GetActiveStudyDocument(); if (aStudy->GetProperties()->IsLocked()) @@ -164,10 +162,10 @@ namespace SMESH{ aBuilder->FindOrCreateAttribute(theSObject, "AttributeExternalFileDef"); _PTR(AttributeExternalFileDef) aFileName = anAttr; if (aFileName) - aFileName->SetValue(theValue); + aFileName->SetValue(theValue.toLatin1().data()); } - void setFileType (_PTR(SObject) theSObject, const char* theValue) + void setFileType (_PTR(SObject) theSObject, const QString& theValue) { _PTR(Study) aStudy = GetActiveStudyDocument(); if (aStudy->GetProperties()->IsLocked()) @@ -177,7 +175,7 @@ namespace SMESH{ aBuilder->FindOrCreateAttribute(theSObject, "AttributeFileType"); _PTR(AttributeFileType) aFileType = anAttr; if (aFileType) - aFileType->SetValue(theValue); + aFileType->SetValue(theValue.toLatin1().data()); } CORBA::Object_var SObjectToObject (_PTR(SObject) theSObject, @@ -214,11 +212,11 @@ namespace SMESH{ return CORBA::Object::_nil(); } - CORBA::Object_var IORToObject (const char* theIOR) + CORBA::Object_var IORToObject (const QString& theIOR) { SalomeApp_Application* app = dynamic_cast (SUIT_Session::session()->activeApplication()); - return app->orb()->string_to_object(theIOR); + return app->orb()->string_to_object(theIOR.toLatin1().data()); } int GetNameOfSelectedIObjects(LightApp_SelectionMgr* theMgr, QString& theName) @@ -252,7 +250,7 @@ namespace SMESH{ return theSObject->GetFather(); } - void ModifiedMesh (_PTR(SObject) theSObject, bool theIsRight) + void ModifiedMesh (_PTR(SObject) theSObject, bool theIsNotModif, bool isEmptyMesh) { _PTR(Study) aStudy = GetActiveStudyDocument(); if (aStudy->GetProperties()->IsLocked()) @@ -262,10 +260,12 @@ namespace SMESH{ _PTR(GenericAttribute) anAttr = aBuilder->FindOrCreateAttribute(theSObject,"AttributePixMap"); _PTR(AttributePixMap) aPixmap = anAttr; - if (theIsRight) { + if (theIsNotModif) { aPixmap->SetPixMap("ICON_SMESH_TREE_MESH"); - } else { + } else if ( isEmptyMesh ) { aPixmap->SetPixMap("ICON_SMESH_TREE_MESH_WARN"); + } else { + aPixmap->SetPixMap("ICON_SMESH_TREE_MESH_PARTIAL"); } _PTR(ChildIterator) anIter = aStudy->NewChildIterator(theSObject); @@ -273,26 +273,36 @@ namespace SMESH{ _PTR(SObject) aSObj = anIter->Value(); if (i >= 4) { _PTR(ChildIterator) anIter1 = aStudy->NewChildIterator(aSObj); - for (; anIter1->More(); anIter1->Next()) { + for ( ; anIter1->More(); anIter1->Next()) { _PTR(SObject) aSObj1 = anIter1->Value(); anAttr = aBuilder->FindOrCreateAttribute(aSObj1, "AttributePixMap"); aPixmap = anAttr; - if (theIsRight) { - aPixmap->SetPixMap("ICON_SMESH_TREE_MESH"); - } else { - aPixmap->SetPixMap("ICON_SMESH_TREE_MESH_WARN"); - } + if (theIsNotModif) { + aPixmap->SetPixMap("ICON_SMESH_TREE_MESH"); + } else if ( isEmptyMesh ) { + aPixmap->SetPixMap("ICON_SMESH_TREE_MESH_WARN"); + } else { + aPixmap->SetPixMap("ICON_SMESH_TREE_MESH_PARTIAL"); + } } } } } -// void UpdateObjBrowser (bool) -// { -// //SMESHGUI::activeStudy()->updateObjBrowser(true); -// //SalomeApp_Application* anApp = dynamic_cast -// // (SUIT_Session::session()->activeApplication()); -// //if (anApp) anApp->objectBrowser()->updateTree(); -// SMESHGUI::GetSMESHGUI()->updateObjBrowser(); -// } -} + 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)); + } + } +} // end of namespace SMESH