X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FOBJECT%2FSMESH_ActorUtils.cxx;h=9ce8b05672ae932002c0182a3d2da8b77a264c17;hb=refs%2Ftags%2FdistribGeom_06Mar13;hp=36e40e6797c1f80099959964e9e1cb9fd03d6461;hpb=1758d524e70758cc1aacc20c2a3394208d7ff93d;p=modules%2Fsmesh.git diff --git a/src/OBJECT/SMESH_ActorUtils.cxx b/src/OBJECT/SMESH_ActorUtils.cxx index 36e40e679..9ce8b0567 100644 --- a/src/OBJECT/SMESH_ActorUtils.cxx +++ b/src/OBJECT/SMESH_ActorUtils.cxx @@ -1,23 +1,23 @@ -// Copyright (C) 2007-2010 CEA/DEN, EDF R&D, OPEN CASCADE +// Copyright (C) 2007-2012 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 +// 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 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. +// 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 +// 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 +// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com // #include "SMESH_ActorUtils.h" @@ -26,6 +26,7 @@ #include "SUIT_Tools.h" #include "SUIT_Session.h" #include "SUIT_ResourceMgr.h" +#include // To fix some redefinition #include "SalomeApp_Application.h" #ifndef DISABLE_PLOT2DVIEWER @@ -34,28 +35,32 @@ #include #endif +#include + #include "utilities.h" #include +#include #include #include +#include -#ifdef _DEBUG_ -static int MYDEBUG = 1; -#else -static int MYDEBUG = 0; -#endif +//#ifdef _DEBUG_ +//static int MYDEBUG = 1; +//#else +//static int MYDEBUG = 0; +//#endif namespace SMESH { - vtkFloatingPointType + double GetFloat( const QString& theValue, - vtkFloatingPointType theDefault ) + double theDefault ) { int pos = theValue.indexOf( ":" ); - vtkFloatingPointType val = theDefault; + double val = theDefault; if( pos>=0 ) { QString name = theValue.right( theValue.length()-pos-1 ), @@ -66,15 +71,15 @@ namespace SMESH return val; } - vtkFloatingPointType + double GetFloat( const QString& theValue, const QString& theSection, - vtkFloatingPointType theDefault ) + double theDefault ) { - vtkFloatingPointType val = theDefault; + double val = theDefault; SUIT_ResourceMgr* mgr = SUIT_Session::session()->resourceMgr(); if( mgr ) - val = (vtkFloatingPointType) mgr->doubleValue( theSection, theValue, theDefault ); + val = (double) mgr->doubleValue( theSection, theValue, theDefault ); return val; } @@ -85,7 +90,7 @@ namespace SMESH { vtkXMLUnstructuredGridWriter* aWriter = vtkXMLUnstructuredGridWriter::New(); aWriter->SetFileName(theFileName); - aWriter->SetInput(theGrid); + aWriter->SetInputData(theGrid); aWriter->SetDataModeToAscii(); if(theGrid->GetNumberOfCells()){ aWriter->Write(); @@ -124,9 +129,9 @@ namespace SMESH void GetColor( const QString& theSect, const QString& theName, - vtkFloatingPointType& r, - vtkFloatingPointType& g, - vtkFloatingPointType& b, + double& r, + double& g, + double& b, const QColor& def ) { int ir( 0 ), ig( 0 ), ib( 0 ); @@ -136,6 +141,39 @@ namespace SMESH b = ib / 255.; } + + void + GetColor( const QString& theSect, + const QString& theName, + QColor& color, + int& delta, + QString def) + { + + SUIT_ResourceMgr* mgr = SUIT_Session::session()->resourceMgr(); + if ( mgr ) { + QString str = mgr->stringValue( theSect, theName, def ); + Qtx::stringToBiColor(str,color,delta); + } + } + + std::map GetEntitiesFromObject(SMESH_VisualObj *theObject) { + std::map entities; + entities.insert(std::pair(SMDSAbs_0DElement, + theObject ? theObject->GetNbEntities(SMDSAbs_0DElement) : 0)); + entities.insert(std::pair(SMDSAbs_Ball, + theObject ? theObject->GetNbEntities(SMDSAbs_Ball) : 0)); + entities.insert(std::pair(SMDSAbs_Edge, + theObject ? theObject->GetNbEntities(SMDSAbs_Edge) : 0)); + entities.insert(std::pair(SMDSAbs_Face, + theObject ? theObject->GetNbEntities(SMDSAbs_Face) : 0)); + entities.insert(std::pair(SMDSAbs_Volume, + theObject ? theObject->GetNbEntities(SMDSAbs_Volume) : 0)); + return entities; + } + + + #ifndef DISABLE_PLOT2DVIEWER //======================================================================= /** @@ -153,9 +191,9 @@ namespace SMESH if(theActor->GetPlot2Histogram()) if(aType == UpdateIn2dViewer) - aHistogram = theActor->UpdatePlot2Histogram(); + aHistogram = theActor->UpdatePlot2Histogram(); else - aHistogram = theActor->GetPlot2Histogram(); + aHistogram = theActor->GetPlot2Histogram(); else return; @@ -167,14 +205,14 @@ namespace SMESH SUIT_ViewManager* aViewManager; foreach( aViewManager, aViewManagerList ) { if (Plot2d_ViewManager* aManager = dynamic_cast(aViewManager)) { - if (SPlot2d_Viewer* aViewer = dynamic_cast(aManager->getViewModel())) { - if (Plot2d_ViewFrame* aViewFrame = aViewer->getActiveViewFrame()) { - if(aType == UpdateIn2dViewer ) - aViewFrame->displayObject(aHistogram, true); - else if (aType == RemoveFrom2dViewer) - aViewFrame->eraseObject(aHistogram, true); - } - } + if (SPlot2d_Viewer* aViewer = dynamic_cast(aManager->getViewModel())) { + if (Plot2d_ViewFrame* aViewFrame = aViewer->getActiveViewFrame()) { + if(aType == UpdateIn2dViewer ) + aViewFrame->displayObject(aHistogram, true); + else if (aType == RemoveFrom2dViewer) + aViewFrame->eraseObject(aHistogram, true); + } + } } } }