Ocean
Loading...
Searching...
No Matches
TrianglesManagerRenderer.h
Go to the documentation of this file.
1/*
2 * Copyright (c) Meta Platforms, Inc. and affiliates.
3 *
4 * This source code is licensed under the MIT license found in the
5 * LICENSE file in the root directory of this source tree.
6 */
7
8#ifndef META_OCEAN_TRACKING_MAPTEXTURING_TRIANGLES_MANAGER_RENDERER_H
9#define META_OCEAN_TRACKING_MAPTEXTURING_TRIANGLES_MANAGER_RENDERER_H
10
12
13#include "ocean/base/Accessor.h"
14#include "ocean/base/Frame.h"
15
17
25
26namespace Ocean
27{
28
29namespace Tracking
30{
31
32namespace MapTexturing
33{
34
35/**
36 * This class implements a manager for active, textured, retired, and deleted triangles.
37 * The manager holds the states of the individual triangles in an own framebuffer.
38 * @ingroup trackingmaptexturing
39 */
40class OCEAN_TRACKING_MAPTEXTURING_EXPORT TrianglesManagerRenderer
41{
42 public:
43
44 /**
45 * Destructs this renderer and releases all resources.
46 */
48
49 /**
50 * Initializes the manager.
51 * @param engine The rendering engine to be used
52 * @param framebufferWidth The width of the framebuffer, in pixel, with range [1, infinity)
53 * @param framebufferHeight The height of the framebuffer, in pixel, with range [1, infinity)
54 * @return True, if succeeded
55 */
56 bool initialize(const Rendering::Engine& engine, unsigned int framebufferWidth, unsigned int framebufferHeight);
57
58 /**
59 * Updates the manager with ids of new triangles.
60 * @param newTriangleIds The ids of all new triangles
61 * @param stateFrame Optional resulting frame holding the states of all triangles, nullptr if not of interest
62 * @return True, if succeeded
63 */
64 bool updateNewTriangles(const Indices32& newTriangleIds, Frame* stateFrame = nullptr);
65
66 /**
67 * Updates the manager with ids of recently textured triangles.
68 * @param triangleIdFramebuffer The framebuffer holding all triangles recently textured, must be valid
69 * @param stateFrame Optional resulting frame holding the states of all triangles, nullptr if not of interest
70 * @return True, if succeeded
71 */
72 bool updateTexturedTriangles(const Rendering::TextureFramebufferRef& triangleIdFramebuffer, Frame* stateFrame = nullptr);
73
74 /**
75 * Updates the manager with ids of recently textured triangles.
76 * @param texturedTriangleIds The ids of all textured triangles
77 * @param stateFrame Optional resulting frame holding the states of all triangles, nullptr if not of interest
78 * @return True, if succeeded
79 */
80 bool updateTexturedTriangles(const Indices32& texturedTriangleIds, Frame* stateFrame = nullptr);
81
82 /**
83 * Updates the manager with ids of retired triangles.
84 * @param retiredTriangleIds The ids of all retired triangles
85 * @param stateFrame Optional resulting frame holding the states of all triangles, nullptr if not of interest
86 * @return True, if succeeded
87 */
88 bool updateRetiredTriangles(const Indices32& retiredTriangleIds, Frame* stateFrame = nullptr);
89
90 /**
91 * Updates the manager with ids of deleted triangles.
92 * @param deletedTriangleIds The ids of all deleted triangles
93 * @param stateFrame Optional resulting frame holding the states of all triangles, nullptr if not of interest
94 * @return True, if succeeded
95 */
96 bool updateDeletedTriangles(const Indices32& deletedTriangleIds, Frame* stateFrame = nullptr);
97
98 /**
99 * Returns the states of all triangles this manager.
100 * @param numberTriangles The number of triangles for which the states will be returned, with range [0, infinity)
101 * @return The states of the individual triangles, valid until the manager's data will be modified
102 */
103 ConstArrayAccessor<uint8_t> triangleStates(const unsigned int numberTriangles);
104
105 /**
106 * Returns the current texture framebuffer of this renderer.
107 * @return The renderer's texture framebuffer
108 */
109 inline const Rendering::TextureFramebufferRef& textureFramebuffer() const;
110
111 /**
112 * Explicitly releases this renderer and releases all resources.
113 */
114 void release();
115
116 /**
117 * Returns whether this renderer has been initialized successfully.
118 * @return True, if succeeded
119 */
120 inline bool isValid() const;
121
122 protected:
123
124 /**
125 * Sets the color value (the state) of several triangles.
126 * @param triangleIds The ids of all triangles for which the state will be set
127 * @param triangleColor The color value (the state) to be set
128 * @return True, if succeeded
129 */
130 bool setTriangles(const Indices32& triangleIds, const float triangleColor);
131
132 /**
133 * Copies the active state framebuffer to the copy framebuffer.
134 * @return True, if succeeded
135 */
137
138 protected:
139
140 //// The width of the framebuffer in pixel.
141 unsigned int framebufferWidth_ = 0u;
142
143 /// The height of the framebuffer in pixel.
144 unsigned int framebufferHeight_ = 0u;
145
146 /// True, if the manager's data has been changed recently.
147 bool hasChanged_ = false;
148
149 /// The frame holding a copy of the triangle states, valid as long as 'hasChanged_ == false'
151
152 /// The shader program allowing to set triangle states.
154
155 /// The shader program allowing to set the states of textured triangles.
157
158 /// The shader program allowing to make a copy of the state framebuffer.
160
161 /// The shader program allowing to set the states of retired triangles.
163
164 /// The texture framebuffer holding the states of the individual triangles.
166
167 /// The copy of the texture framebuffer holding the states of the individual triangles.
169
170 /// The vertex set holding the vertices to be rendered.
172
173 /// The points object which will be used to render points.
175
176 /// The triangles object which will be used to render triangles.
178
179 /// The platform-specific shader part.
180 static const char* partPlatform_;
181
182 /// The vertex shader program to set triangle states.
184
185 /// The vertex shader program to render planar textured triangles.
187
188 /// The vertex shader program to render retired triangles.
190
191 /// The fragment shader program to render triangle states.
193
194 /// The fragment shader program to render active triangles.
196
197 /// The fragment shader program to render retired triangles.
199
200 /// The fragment shader program to copy the framebuffer.
202};
203
208
209}
210
211}
212
213}
214
215#endif // META_OCEAN_TRACKING_MAPTEXTURING_TRIANGLES_MANAGER_RENDERER_H
This class implements an accessor providing direct access to a constant array of elements.
Definition Accessor.h:400
This class implements Ocean's image class.
Definition Frame.h:1808
This class is the base class for all rendering engines like.
Definition Engine.h:46
This class implements a manager for active, textured, retired, and deleted triangles.
Definition TrianglesManagerRenderer.h:41
Rendering::TextureFramebufferRef copyTextureFramebuffer_
The copy of the texture framebuffer holding the states of the individual triangles.
Definition TrianglesManagerRenderer.h:168
ConstArrayAccessor< uint8_t > triangleStates(const unsigned int numberTriangles)
Returns the states of all triangles this manager.
bool updateTexturedTriangles(const Rendering::TextureFramebufferRef &triangleIdFramebuffer, Frame *stateFrame=nullptr)
Updates the manager with ids of recently textured triangles.
static const char * programFragmentShaderActiveTriangles_
The fragment shader program to render active triangles.
Definition TrianglesManagerRenderer.h:195
static const char * partPlatform_
The platform-specific shader part.
Definition TrianglesManagerRenderer.h:180
bool updateRetiredTriangles(const Indices32 &retiredTriangleIds, Frame *stateFrame=nullptr)
Updates the manager with ids of retired triangles.
Rendering::TextureFramebufferRef textureFramebuffer_
The texture framebuffer holding the states of the individual triangles.
Definition TrianglesManagerRenderer.h:165
Frame triangleStatesFrame_
The frame holding a copy of the triangle states, valid as long as 'hasChanged_ == false'.
Definition TrianglesManagerRenderer.h:150
Rendering::PointsRef points_
The points object which will be used to render points.
Definition TrianglesManagerRenderer.h:174
bool copyFramebuffer()
Copies the active state framebuffer to the copy framebuffer.
static const char * programFragmentShaderCopyFramebuffer_
The fragment shader program to copy the framebuffer.
Definition TrianglesManagerRenderer.h:201
bool isValid() const
Returns whether this renderer has been initialized successfully.
Rendering::ShaderProgramRef shaderProgramSetTriangles_
The shader program allowing to set triangle states.
Definition TrianglesManagerRenderer.h:153
Rendering::ShaderProgramRef shaderProgramCopyFramebuffer_
The shader program allowing to make a copy of the state framebuffer.
Definition TrianglesManagerRenderer.h:159
Rendering::VertexSetRef vertexSet_
The vertex set holding the vertices to be rendered.
Definition TrianglesManagerRenderer.h:171
const Rendering::TextureFramebufferRef & textureFramebuffer() const
Returns the current texture framebuffer of this renderer.
Definition TrianglesManagerRenderer.h:204
void release()
Explicitly releases this renderer and releases all resources.
Rendering::ShaderProgramRef shaderProgramRetiredTriangles_
The shader program allowing to set the states of retired triangles.
Definition TrianglesManagerRenderer.h:162
Rendering::ShaderProgramRef shaderProgramTexturedTriangles_
The shader program allowing to set the states of textured triangles.
Definition TrianglesManagerRenderer.h:156
bool updateNewTriangles(const Indices32 &newTriangleIds, Frame *stateFrame=nullptr)
Updates the manager with ids of new triangles.
static const char * programVertexShaderRetiredTriangles_
The vertex shader program to render retired triangles.
Definition TrianglesManagerRenderer.h:189
~TrianglesManagerRenderer()
Destructs this renderer and releases all resources.
bool updateDeletedTriangles(const Indices32 &deletedTriangleIds, Frame *stateFrame=nullptr)
Updates the manager with ids of deleted triangles.
static const char * programFragmentShaderRetiredTriangles_
The fragment shader program to render retired triangles.
Definition TrianglesManagerRenderer.h:198
bool initialize(const Rendering::Engine &engine, unsigned int framebufferWidth, unsigned int framebufferHeight)
Initializes the manager.
static const char * programVertexShaderPlanarTexturedTriangles_
The vertex shader program to render planar textured triangles.
Definition TrianglesManagerRenderer.h:186
bool setTriangles(const Indices32 &triangleIds, const float triangleColor)
Sets the color value (the state) of several triangles.
Rendering::TrianglesRef triangles_
The triangles object which will be used to render triangles.
Definition TrianglesManagerRenderer.h:177
static const char * programFragmentShaderSetTriangles_
The fragment shader program to render triangle states.
Definition TrianglesManagerRenderer.h:192
static const char * programVertexShaderSetTriangles_
The vertex shader program to set triangle states.
Definition TrianglesManagerRenderer.h:183
bool updateTexturedTriangles(const Indices32 &texturedTriangleIds, Frame *stateFrame=nullptr)
Updates the manager with ids of recently textured triangles.
std::vector< Index32 > Indices32
Definition of a vector holding 32 bit index values.
Definition Base.h:96
The namespace covering the entire Ocean framework.
Definition Accessor.h:15