1 // VISU OBJECT : interactive object for VISU entities implementation
3 // Copyright (C) 2003 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
4 // CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
6 // This library is free software; you can redistribute it and/or
7 // modify it under the terms of the GNU Lesser General Public
8 // License as published by the Free Software Foundation; either
9 // version 2.1 of the License.
11 // This library is distributed in the hope that it will be useful,
12 // but WITHOUT ANY WARRANTY; without even the implied warranty of
13 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 // Lesser General Public License for more details.
16 // You should have received a copy of the GNU Lesser General Public
17 // License along with this library; if not, write to the Free Software
18 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
20 // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
23 // File : VISU_PrsObject_i.hxx
24 // Author : Alexey PETROV
27 #ifndef VISU_ScalarMap_i_HeaderFile
28 #define VISU_ScalarMap_i_HeaderFile
30 #include "VISU_ColoredPrs3d_i.hh"
35 class VISU_ScalarMapPL;
39 //============================================================================
40 class VISU_I_EXPORT ScalarMap_i : public virtual POA_VISU::ScalarMap,
41 public virtual ColoredPrs3d_i
43 static int myNbPresent;
44 ScalarMap_i(const ScalarMap_i&);
47 //----------------------------------------------------------------------------
48 typedef ColoredPrs3d_i TSuperClass;
49 typedef VISU::ScalarMap TInterface;
52 ScalarMap_i(EPublishInStudyMode thePublishInStudyModep);
61 return VISU::TSCALARMAP;
64 //----------------------------------------------------------------------------
65 //! Gets memory size actually used by the presentation (Mb).
70 //----------------------------------------------------------------------------
77 SetScaling(VISU::Scaling theScaling);
79 //----------------------------------------------------------------------------
80 //! Sets initial source geometry
85 //! Add geometry of mesh as group. \retval the id of added group.
88 AddMeshOnGroup(const char* theGroupName);
90 //! Removes all geometries.
95 //----------------------------------------------------------------------------
103 //! Redefines VISU_ColoredPrs3d_i::DoSetInput
106 DoSetInput(bool theIsInitilizePipe, bool theReInit);
108 //! Redefines VISU_ColoredPrs3d_i::CreatePipeLine
111 CreatePipeLine(VISU_PipeLine* thePipeLine);
113 //! Redefines VISU_ColoredPrs3d_i::CheckIsPossible
120 Checks staticaly, whether it is possible to create presentation
121 with the given basic parameters or not.
125 IsPossible(Result_i* theResult,
126 const std::string& theMeshName,
127 VISU::Entity theEntity,
128 const std::string& theFieldName,
129 CORBA::Long theTimeStampNumber,
130 bool theIsMemoryCheck);
132 //! Redefines VISU_ColoredPrs3d_i::Create
135 Create(const std::string& theMeshName,
136 VISU::Entity theEntity,
137 const std::string& theFieldName,
138 CORBA::Long theTimeStampNumber);
142 ToStream(std::ostringstream& theStr);
144 static const std::string myComment;
163 Restore(SALOMEDS::SObject_ptr theSObject,
164 const Storable::TRestoringMap& theMap);
168 SetMapScale(double theMapScale = 1.0);
172 SameAs(const Prs3d_i* theOrigin);
180 CreateActor(bool toSupressShrinking);
184 UpdateActor(VISU_Actor* theActor);
187 VISU_ScalarMapPL* myScalarMapPL;