VTK  9.3.0
vtkOpenGLCellGridRenderRequest.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
18#ifndef vtkOpenGLCellGridRenderRequest_h
19#define vtkOpenGLCellGridRenderRequest_h
20#include "vtkCellGridQuery.h"
21#include "vtkRenderingCellGridModule.h" // For export macro
22#include "vtkStringToken.h" // for ivars
23
24#include <memory> // for unique_ptr
25#include <unordered_map> // for this->State
26
27VTK_ABI_NAMESPACE_BEGIN
28class vtkActor;
30class vtkRenderer;
31class vtkWindow;
32
33class VTKRENDERINGCELLGRID_EXPORT vtkOpenGLCellGridRenderRequest : public vtkCellGridQuery
34{
35public:
38 {
39 public:
40 virtual ~StateBase() = default;
41 };
42
55 enum RenderableGeometry : unsigned char
56 {
57 VERTICES = 1,
58 EDGES = 2,
59 FACES = 4,
60 VOLUMES = 8,
61 SURFACE_WITH_EDGES = EDGES | FACES,
62 ALL = VERTICES | EDGES | FACES | VOLUMES
63 };
64
67 void PrintSelf(std::ostream& os, vtkIndent indent) override;
68
74 virtual void SetMapper(vtkOpenGLCellGridMapper* mapper);
75 vtkGetObjectMacro(Mapper, vtkOpenGLCellGridMapper);
76
82 virtual void SetActor(vtkActor* actor);
83 vtkGetObjectMacro(Actor, vtkActor);
84
90 virtual void SetRenderer(vtkRenderer* renderer);
91 vtkGetObjectMacro(Renderer, vtkRenderer);
92
98 virtual void SetWindow(vtkWindow* window);
99 vtkGetObjectMacro(Window, vtkWindow);
100
108 vtkGetMacro(ShapesToDraw, char);
109 vtkSetClampMacro(ShapesToDraw, char, 1, 9);
110
112 void Initialize() override;
114 void Finalize() override;
115
124 vtkGetMacro(IsReleasingResources, bool);
125 vtkSetMacro(IsReleasingResources, bool);
126
131 template <typename StateType>
132 StateType* GetState(vtkStringToken cellType)
133 {
134 auto it = this->State.find(cellType);
135 if (it == this->State.end())
136 {
137 it = this->State.insert(std::make_pair(cellType, std::unique_ptr<StateBase>(new StateType)))
138 .first;
139 }
140 return static_cast<StateType*>(it->second.get());
141 }
142
143protected:
146
147 vtkOpenGLCellGridMapper* Mapper{ nullptr };
148 vtkActor* Actor{ nullptr };
149 vtkRenderer* Renderer{ nullptr };
150 vtkWindow* Window{ nullptr };
151 bool IsReleasingResources{ false };
152 char ShapesToDraw{ RenderableGeometry::ALL };
153 std::unordered_map<vtkStringToken, std::unique_ptr<StateBase>> State;
154
155private:
157 void operator=(const vtkOpenGLCellGridRenderRequest&) = delete;
158};
159
160VTK_ABI_NAMESPACE_END
161#endif // vtkOpenGLCellGridRenderRequest_h
represents an object (geometry & properties) in a rendered scene
Definition vtkActor.h:41
Perform an operation on cells in a vtkCellMetadata instance.
a simple class to control print indentation
Definition vtkIndent.h:29
CellGrid mapper using OpenGL to render exotic finite element fields and cells.
An empty base class that responders should inherit to store state using GetState<Subclass>().
State used by vtkOpenGLCellGridMapper during rendering.
StateType * GetState(vtkStringToken cellType)
Return a state object of the given type.
static vtkOpenGLCellGridRenderRequest * New()
void PrintSelf(std::ostream &os, vtkIndent indent) override
virtual void SetWindow(vtkWindow *window)
Set/get a window (used when IsReleasingResources is true).
RenderableGeometry
An enumeration of which shapes to render.
virtual void SetMapper(vtkOpenGLCellGridMapper *mapper)
Set/get the mapper which owns this request (so responders can inspect its configuration).
virtual void SetRenderer(vtkRenderer *renderer)
Set/get the renderer responders should use to draw cells.
std::unordered_map< vtkStringToken, std::unique_ptr< StateBase > > State
void Initialize() override
This is invoked before processing any cell types during a render.
virtual void SetActor(vtkActor *actor)
Set/get the actor which responders should use to draw cells.
~vtkOpenGLCellGridRenderRequest() override
void Finalize() override
This is invoked after processing all cell types during a render.
abstract specification for renderers
Definition vtkRenderer.h:59
Represent a string by its integer hash.
window superclass for vtkRenderWindow
Definition vtkWindow.h:25