00001 // Copyright (C) 2007-2011 CEA/DEN, EDF R&D, OPEN CASCADE 00002 // 00003 // Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN, 00004 // CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS 00005 // 00006 // This library is free software; you can redistribute it and/or 00007 // modify it under the terms of the GNU Lesser General Public 00008 // License as published by the Free Software Foundation; either 00009 // version 2.1 of the License. 00010 // 00011 // This library is distributed in the hope that it will be useful, 00012 // but WITHOUT ANY WARRANTY; without even the implied warranty of 00013 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 00014 // Lesser General Public License for more details. 00015 // 00016 // You should have received a copy of the GNU Lesser General Public 00017 // License along with this library; if not, write to the Free Software 00018 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA 00019 // 00020 // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com 00021 // 00022 00023 // SMESH SMESH : idl implementation based on 'SMESH' unit's calsses 00024 // File : StdMeshers_LayerDistribution.hxx 00025 // Author : Edward AGAPOV 00026 // Module : SMESH 00027 // 00028 #ifndef _SMESH_LayerDistribution_HXX_ 00029 #define _SMESH_LayerDistribution_HXX_ 00030 00031 #include "SMESH_StdMeshers.hxx" 00032 00033 #include "SMESH_Hypothesis.hxx" 00034 #include "Utils_SALOME_Exception.hxx" 00035 00036 #include <string> 00037 00038 class SMESH_Gen; 00039 00040 // ========================================================= 00041 // ========================================================= 00047 // ========================================================= 00048 // ========================================================= 00049 00050 class STDMESHERS_EXPORT StdMeshers_LayerDistribution: public SMESH_Hypothesis 00051 { 00052 public: 00053 // Constructor 00054 StdMeshers_LayerDistribution( int hypId, int studyId, SMESH_Gen * gen ); 00055 // Destructor 00056 virtual ~StdMeshers_LayerDistribution(); 00057 00062 void SetLayerDistribution(SMESH_Hypothesis* hyp1D) 00063 throw ( SALOME_Exception ); 00064 00069 SMESH_Hypothesis* GetLayerDistribution() const { return myHyp; } 00070 00071 virtual std::ostream & SaveTo(std::ostream & save); 00072 virtual std::istream & LoadFrom(std::istream & load); 00073 friend std::ostream & operator <<(std::ostream & save, StdMeshers_LayerDistribution & hyp); 00074 friend std::istream & operator >>(std::istream & load, StdMeshers_LayerDistribution & hyp); 00075 00084 virtual bool SetParametersByMesh(const SMESH_Mesh* theMesh, const TopoDS_Shape& theShape); 00085 00090 virtual bool SetParametersByDefaults(const TDefaults& dflts, const SMESH_Mesh* theMesh=0); 00091 00092 protected: 00093 SMESH_Hypothesis* myHyp; 00094 std::string mySavedHyp; 00095 }; 00096 00097 #endif 00098