VTK  9.4.20250208
vtkOpenGLGlyph3DMapper.h
Go to the documentation of this file.
1// SPDX-FileCopyrightText: Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
2// SPDX-License-Identifier: BSD-3-Clause
16#ifndef vtkOpenGLGlyph3DMapper_h
17#define vtkOpenGLGlyph3DMapper_h
18
19#include "vtkGlyph3DMapper.h"
20
21#include "vtkColor.h" // for ivar
22#include "vtkDataObjectTree.h" // for arg
23#include "vtkNew.h" // For vtkNew
24#include "vtkRenderingOpenGL2Module.h" // For export macro
25#include "vtkVector.h" // for ivar
26#include "vtkWrappingHints.h" // For VTK_MARSHALAUTO
27
28#include <stack> // for ivar
29
30VTK_ABI_NAMESPACE_BEGIN
32class vtkBitArray;
33
34class VTKRENDERINGOPENGL2_EXPORT VTK_MARSHALAUTO vtkOpenGLGlyph3DMapper : public vtkGlyph3DMapper
35{
36public:
39 void PrintSelf(ostream& os, vtkIndent indent) override;
40
45 void Render(vtkRenderer* ren, vtkActor* a) override;
46
52 void ReleaseGraphicsResources(vtkWindow* window) override;
53
55
60
64 void SetNumberOfLOD(vtkIdType nb) override;
65
75 vtkIdType index, float distance, float targetReduction) override;
77
78protected:
81
86
92
94
101 vtkRenderer* renderer, vtkActor* actor, vtkDataObject* dobjTree, unsigned int& flatIndex);
102
104
105 class vtkOpenGLGlyph3DMapperEntry;
106 class vtkOpenGLGlyph3DMapperSubArray;
107 class vtkOpenGLGlyph3DMapperArray;
108 vtkOpenGLGlyph3DMapperArray* GlyphValues; // array of value for datasets
109
113 virtual void RebuildStructures(vtkOpenGLGlyph3DMapperSubArray* subarray, vtkIdType numPts,
114 vtkActor* actor, vtkDataSet* dataset, vtkBitArray* maskArray);
115
116 vtkMTimeType BlockMTime; // Last time BlockAttributes was modified.
117
118private:
120 void operator=(const vtkOpenGLGlyph3DMapper&) = delete;
121
122 struct RenderBlockState
123 {
124 std::stack<double> Opacity;
125 std::stack<bool> Visibility;
126 std::stack<bool> Pickability;
127 std::stack<vtkColor3d> Color;
128 };
129 RenderBlockState BlockState;
130};
131
132VTK_ABI_NAMESPACE_END
133#endif
represents an object (geometry & properties) in a rendered scene
Definition vtkActor.h:151
dynamic, self-adjusting array of bits
Definition vtkBitArray.h:29
general representation of visualization data
abstract class to specify dataset behavior
Definition vtkDataSet.h:165
vtkGlyph3D on the GPU.
a simple class to control print indentation
Definition vtkIndent.h:108
abstract class specifies interface to map data to graphics primitives
Definition vtkMapper.h:98
PolyDataMapper using OpenGL to render.
vtkOpenGLGlyph3D on the GPU.
vtkIdType GetMaxNumberOfLOD() override
Get the maximum number of LOD.
void Render(vtkRenderer *ren, vtkActor *a) override
Method initiates the mapping process.
void PrintSelf(ostream &os, vtkIndent indent) override
Methods invoked by print to print information about the object including superclasses.
void SetLODDistanceAndTargetReduction(vtkIdType index, float distance, float targetReduction) override
Configure LODs.
~vtkOpenGLGlyph3DMapper() override
virtual void Render(vtkRenderer *, vtkActor *, vtkDataSet *)
Render setup.
void RenderChildren(vtkRenderer *renderer, vtkActor *actor, vtkDataObject *dobjTree, unsigned int &flatIndex)
Renders children of the given dobjTree recursively.
void CopyInformationToSubMapper(vtkOpenGLGlyph3DHelper *)
Send mapper ivars to sub-mapper.
void SetNumberOfLOD(vtkIdType nb) override
Set the number of LOD.
virtual void RebuildStructures(vtkOpenGLGlyph3DMapperSubArray *subarray, vtkIdType numPts, vtkActor *actor, vtkDataSet *dataset, vtkBitArray *maskArray)
Build data structures associated with.
static vtkOpenGLGlyph3DMapper * New()
vtkOpenGLGlyph3DMapperArray * GlyphValues
void ReleaseGraphicsResources(vtkWindow *window) override
Release any graphics resources that are being consumed by this mapper.
abstract specification for renderers
window superclass for vtkRenderWindow
Definition vtkWindow.h:48
int vtkIdType
Definition vtkType.h:315
vtkTypeUInt32 vtkMTimeType
Definition vtkType.h:270
#define VTK_MARSHALAUTO