X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FOBJECT%2FSMESH_ActorUtils.cxx;h=6808e145e1c668b6aecff46a237e1835cf05fd7b;hb=630691342408423638e133f1888ce3cc8fd9859f;hp=a5823c66f03ef69b34823b038bd0a72039e37131;hpb=e4737e85f0da6d3f90fd08f6be1c2825195fe16f;p=modules%2Fsmesh.git diff --git a/src/OBJECT/SMESH_ActorUtils.cxx b/src/OBJECT/SMESH_ActorUtils.cxx index a5823c66f..6808e145e 100644 --- a/src/OBJECT/SMESH_ActorUtils.cxx +++ b/src/OBJECT/SMESH_ActorUtils.cxx @@ -1,39 +1,127 @@ -// Copyright (C) 2003 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.opencascade.org/SALOME/ or email : webmaster.salome@opencascade.org - +// Copyright (C) 2007-2010 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 +// #include "SMESH_ActorUtils.h" -#include "QAD_Config.h" +#include "SUIT_Tools.h" +#include "SUIT_Session.h" +#include "SUIT_ResourceMgr.h" + #include "utilities.h" +#include +#include + #ifdef _DEBUG_ static int MYDEBUG = 1; #else static int MYDEBUG = 0; #endif -namespace SMESH{ - float GetFloat(const QString& theValue, float theDefault){ - if(theValue.isEmpty()) return theDefault; - QString aValue = QAD_CONFIG->getSetting(theValue); - if(aValue.isEmpty()) return theDefault; - return aValue.toFloat(); +namespace SMESH +{ + + vtkFloatingPointType + GetFloat( const QString& theValue, + vtkFloatingPointType theDefault ) + { + int pos = theValue.indexOf( ":" ); + vtkFloatingPointType val = theDefault; + if( pos>=0 ) + { + QString name = theValue.right( theValue.length()-pos-1 ), + sect = theValue.left( pos ); + if( !name.isEmpty() && !sect.isEmpty() ) + val = GetFloat( name, sect, theDefault ); + } + return val; + } + + vtkFloatingPointType + GetFloat( const QString& theValue, + const QString& theSection, + vtkFloatingPointType theDefault ) + { + vtkFloatingPointType val = theDefault; + SUIT_ResourceMgr* mgr = SUIT_Session::session()->resourceMgr(); + if( mgr ) + val = (vtkFloatingPointType) mgr->doubleValue( theSection, theValue, theDefault ); + + return val; + } + + void + WriteUnstructuredGrid(vtkUnstructuredGrid* theGrid, + const char* theFileName) + { + vtkUnstructuredGridWriter* aWriter = vtkUnstructuredGridWriter::New(); + aWriter->SetFileName(theFileName); + aWriter->SetInput(theGrid); + if(theGrid->GetNumberOfCells()){ + aWriter->Write(); + } + aWriter->Delete(); + } + + QColor + GetColor( const QString& theSect, + const QString& theName, + const QColor& def ) + { + QColor c = def; + SUIT_ResourceMgr* mgr = SUIT_Session::session()->resourceMgr(); + if ( mgr ) + c = mgr->colorValue( theSect, theName, def ); + return c; + } + + void + GetColor( const QString& theSect, + const QString& theName, + int& r, + int& g, + int& b, + const QColor& def ) + { + QColor c = def; + SUIT_ResourceMgr* mgr = SUIT_Session::session()->resourceMgr(); + if ( mgr ) + c = mgr->colorValue( theSect, theName, def ); + + SUIT_Tools::rgbSet( SUIT_Tools::rgbSet( c ), r, g, b ); + } + + void + GetColor( const QString& theSect, + const QString& theName, + vtkFloatingPointType& r, + vtkFloatingPointType& g, + vtkFloatingPointType& b, + const QColor& def ) + { + int ir( 0 ), ig( 0 ), ib( 0 ); + GetColor( theSect, theName, ir, ig, ib, def ); + r = ir / 255.; + g = ig / 255.; + b = ib / 255.; } }