VTK
vtkOpenGLGlyph3DHelper.h
Go to the documentation of this file.
1 /*=========================================================================
2 
3  Program: Visualization Toolkit
4 
5  Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
6  All rights reserved.
7  See Copyright.txt or http://www.kitware.com/Copyright.htm for details.
8 
9  This software is distributed WITHOUT ANY WARRANTY; without even
10  the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
11  PURPOSE. See the above copyright notice for more information.
12 
13 =========================================================================*/
21 #ifndef vtkOpenGLGlyph3DHelper_h
22 #define vtkOpenGLGlyph3DHelper_h
23 
24 #include "vtkNew.h" // For vtkNew
25 #include "vtkOpenGLBufferObject.h" // For vtkOpenGLBufferObject
26 #include "vtkOpenGLHelper.h" // For vtkOpenGLHelper
27 #include "vtkOpenGLInstanceCulling.h" // For vtkOpenGLInstanceCulling
29 #include "vtkRenderingOpenGL2Module.h" // For export macro
30 
31 class vtkBitArray;
32 
33 class VTKRENDERINGOPENGL2_EXPORT vtkOpenGLGlyph3DHelper : public vtkOpenGLPolyDataMapper
34 {
35 public:
36  static vtkOpenGLGlyph3DHelper* New();
38  void PrintSelf(ostream& os, vtkIndent indent) override;
39 
44  void GlyphRender(vtkRenderer* ren, vtkActor* actor, vtkIdType numPts,
45  std::vector<unsigned char> &colors, std::vector<float> &matrices,
46  std::vector<float> &normalMatrices, std::vector<vtkIdType> &pickIds,
47  vtkMTimeType pointMTime, bool culling);
48 
49  void SetLODs(std::vector<std::pair<float, float> >& lods);
50 
51  void SetLODColoring(bool val);
52 
58  void ReleaseGraphicsResources(vtkWindow *window) override;
59 
60 protected:
62  ~vtkOpenGLGlyph3DHelper() override = default;
63 
64  // special opengl 32 version that uses instances
65  void GlyphRenderInstances(vtkRenderer* ren, vtkActor* actor, vtkIdType numPts,
66  std::vector<unsigned char> &colors, std::vector<float> &matrices,
67  std::vector<float> &normalMatrices,
68  vtkMTimeType pointMTime, bool culling);
69 
73  void GetShaderTemplate(
74  std::map<vtkShader::Type, vtkShader *> shaders,
75  vtkRenderer *ren, vtkActor *act) override;
76 
78 
82  std::map<vtkShader::Type, vtkShader *> shaders,
83  vtkRenderer *ren, vtkActor *act) override;
84  void ReplaceShaderColor(
85  std::map<vtkShader::Type, vtkShader *> shaders,
86  vtkRenderer *ren, vtkActor *act) override;
88  std::map<vtkShader::Type, vtkShader *> shaders,
89  vtkRenderer *ren, vtkActor *act) override;
90  void ReplaceShaderClip(
91  std::map<vtkShader::Type, vtkShader *> shaders,
92  vtkRenderer *ren, vtkActor *act) override;
94  std::map<vtkShader::Type, vtkShader *> shaders,
95  vtkRenderer *ren, vtkActor *act) override;
97 
102  vtkOpenGLHelper &cellBO, vtkRenderer *ren, vtkActor *act) override;
103 
104  void BuildCullingShaders(vtkRenderer* ren, vtkActor* actor, vtkIdType numPts, bool withNormals);
105 
107 
113 
114  std::vector<std::pair<float, float> > LODs;
116 
117 private:
119  void operator=(const vtkOpenGLGlyph3DHelper&) = delete;
120 };
121 
122 #endif
vtkX3D::vector
Definition: vtkX3D.h:237
vtkOpenGLGlyph3DHelper
PolyDataMapper using OpenGL to render.
Definition: vtkOpenGLGlyph3DHelper.h:33
vtkIdType
int vtkIdType
Definition: vtkType.h:347
vtkOpenGLInstanceCulling.h
vtkTimeStamp
record modification and/or execution time
Definition: vtkTimeStamp.h:35
vtkOpenGLHelper.h
vtkOpenGLPolyDataMapper::New
static vtkOpenGLPolyDataMapper * New()
vtkOpenGLPolyDataMapper::ReplaceShaderPositionVC
virtual void ReplaceShaderPositionVC(std::map< vtkShader::Type, vtkShader * > shaders, vtkRenderer *ren, vtkActor *act)
vtkOpenGLPolyDataMapper::GetShaderTemplate
virtual void GetShaderTemplate(std::map< vtkShader::Type, vtkShader * > shaders, vtkRenderer *ren, vtkActor *act)
Create the basic shaders before replacement.
vtkWindow
window superclass for vtkRenderWindow
Definition: vtkWindow.h:37
vtkOpenGLPolyDataMapper::ReplaceShaderClip
virtual void ReplaceShaderClip(std::map< vtkShader::Type, vtkShader * > shaders, vtkRenderer *ren, vtkActor *act)
vtkOpenGLPolyDataMapper::ReplaceShaderPicking
virtual void ReplaceShaderPicking(std::map< vtkShader::Type, vtkShader * > shaders, vtkRenderer *ren, vtkActor *act)
vtkOpenGLHelper
Definition: vtkOpenGLHelper.h:30
vtkActor
represents an object (geometry & properties) in a rendered scene
Definition: vtkActor.h:51
vtkIndent
a simple class to control print indentation
Definition: vtkIndent.h:39
vtkOpenGLGlyph3DHelper::MatrixBuffer
vtkNew< vtkOpenGLBufferObject > MatrixBuffer
Definition: vtkOpenGLGlyph3DHelper.h:109
vtkOpenGLGlyph3DHelper::InstanceBuffersLoadTime
vtkTimeStamp InstanceBuffersLoadTime
Definition: vtkOpenGLGlyph3DHelper.h:112
vtkOpenGLGlyph3DHelper::ColorBuffer
vtkNew< vtkOpenGLBufferObject > ColorBuffer
Definition: vtkOpenGLGlyph3DHelper.h:110
vtkOpenGLPolyDataMapper::ReleaseGraphicsResources
void ReleaseGraphicsResources(vtkWindow *) override
Release any graphics resources that are being consumed by this mapper.
vtkNew< vtkOpenGLBufferObject >
vtkOpenGLGlyph3DHelper::InstanceCulling
vtkNew< vtkOpenGLInstanceCulling > InstanceCulling
Definition: vtkOpenGLGlyph3DHelper.h:115
vtkOpenGLGlyph3DHelper::LODs
std::vector< std::pair< float, float > > LODs
Definition: vtkOpenGLGlyph3DHelper.h:114
vtkOpenGLPolyDataMapper::ReplaceShaderNormal
virtual void ReplaceShaderNormal(std::map< vtkShader::Type, vtkShader * > shaders, vtkRenderer *ren, vtkActor *act)
vtkOpenGLGlyph3DHelper::UsingInstancing
bool UsingInstancing
Definition: vtkOpenGLGlyph3DHelper.h:106
vtkNew.h
vtkOpenGLPolyDataMapper::PrintSelf
void PrintSelf(ostream &os, vtkIndent indent) override
Methods invoked by print to print information about the object including superclasses.
vtkOpenGLBufferObject.h
vtkRenderer
abstract specification for renderers
Definition: vtkRenderer.h:63
vtkOpenGLPolyDataMapper::SetMapperShaderParameters
virtual void SetMapperShaderParameters(vtkOpenGLHelper &cellBO, vtkRenderer *ren, vtkActor *act)
Set the shader parameters related to the mapper/input data, called by UpdateShader.
vtkBitArray
dynamic, self-adjusting array of bits
Definition: vtkBitArray.h:36
vtkOpenGLPolyDataMapper::ReplaceShaderColor
virtual void ReplaceShaderColor(std::map< vtkShader::Type, vtkShader * > shaders, vtkRenderer *ren, vtkActor *act)
vtkOpenGLGlyph3DHelper::NormalMatrixBuffer
vtkNew< vtkOpenGLBufferObject > NormalMatrixBuffer
Definition: vtkOpenGLGlyph3DHelper.h:108
vtkOpenGLGlyph3DHelper::InstanceBuffersBuildTime
vtkTimeStamp InstanceBuffersBuildTime
Definition: vtkOpenGLGlyph3DHelper.h:111
vtkOpenGLPolyDataMapper.h
vtkOpenGLPolyDataMapper
PolyDataMapper using OpenGL to render.
Definition: vtkOpenGLPolyDataMapper.h:53
vtkMTimeType
vtkTypeUInt32 vtkMTimeType
Definition: vtkType.h:302