1 // Copyright (C) 2007-2010 CEA/DEN, EDF R&D, OPEN CASCADE
3 // Copyright (C) 2003-2007 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 // VISU OBJECT : interactive object for VISU entities implementation
24 // File: VISU_PointSpriteMapperHolder.cxx
25 // Author: Alexey PETROV
28 #include "VISU_PointSpriteMapperHolder.hxx"
29 #include "VISU_OpenGLPointSpriteMapper.hxx"
31 #include "VISU_PipeLineUtils.hxx"
32 #include "SALOME_ExtractPolyDataGeometry.h"
35 static int MYDEBUG = 0;
37 static int MYDEBUG = 0;
41 //----------------------------------------------------------------------------
42 vtkStandardNewMacro(VISU_PointSpriteMapperHolder);
45 //----------------------------------------------------------------------------
46 VISU_PointSpriteMapperHolder
47 ::VISU_PointSpriteMapperHolder()
50 MESSAGE("VISU_PointSpriteMapperHolder::VISU_PointSpriteMapperHolder - "<<this);
54 //----------------------------------------------------------------------------
55 VISU_PointSpriteMapperHolder
56 ::~VISU_PointSpriteMapperHolder()
59 MESSAGE("VISU_PointSpriteMapperHolder::~VISU_PointSpriteMapperHolder - "<<this);
63 //----------------------------------------------------------------------------
65 VISU_PointSpriteMapperHolder
66 ::ShallowCopy(VISU_MapperHolder *theMapperHolder,
69 if(VISU_PointSpriteMapperHolder* aMapperHolder = dynamic_cast<VISU_PointSpriteMapperHolder*>(theMapperHolder)){
71 SetGaussPtsIDMapper(aMapperHolder->GetGaussPtsIDMapper());
73 VISU::CopyPointSpriteDataMapper(GetPointSpriteMapper(),
74 aMapperHolder->GetPointSpriteMapper(),
76 myExtractPolyDataGeometry->SetImplicitFunction(aMapperHolder->GetImplicitFunction());
81 //----------------------------------------------------------------------------
83 VISU_PointSpriteMapperHolder
84 ::SetGaussPtsIDMapper(const VISU::PGaussPtsIDMapper& theIDMapper)
86 myGaussPtsIDMapper = theIDMapper;
87 SetPolyDataIDMapper(theIDMapper);
91 //----------------------------------------------------------------------------
92 const VISU::PGaussPtsIDMapper&
93 VISU_PointSpriteMapperHolder
94 ::GetGaussPtsIDMapper()
96 return myGaussPtsIDMapper;
100 //----------------------------------------------------------------------------
102 VISU_PointSpriteMapperHolder
105 myPointSpriteMapper = VISU_OpenGLPointSpriteMapper::New();
106 myPointSpriteMapper->Delete();
107 myPointSpriteMapper->SetColorModeToMapScalars();
108 myPointSpriteMapper->ScalarVisibilityOn();
109 SetPolyDataMapper(myPointSpriteMapper.GetPointer());
113 //----------------------------------------------------------------------------
114 VISU_OpenGLPointSpriteMapper*
115 VISU_PointSpriteMapperHolder
116 ::GetPointSpriteMapper()
119 return myPointSpriteMapper.GetPointer();
123 //----------------------------------------------------------------------------