-
Notifications
You must be signed in to change notification settings - Fork 59
/
render_delegate.h
executable file
·351 lines (335 loc) · 14.1 KB
/
render_delegate.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
// Copyright 2019 Luma Pictures
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
//
// Modifications Copyright 2019 Autodesk, Inc.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
/// @file render_delegate.h
///
/// Render Delegate class for Hydra.
#pragma once
#include <pxr/pxr.h>
#include "api.h"
#include <pxr/imaging/hd/light.h>
#include <pxr/imaging/hd/renderDelegate.h>
#include <pxr/imaging/hd/renderThread.h>
#include <pxr/imaging/hd/resourceRegistry.h>
#include "hdarnold.h"
#include "render_param.h"
#include <ai.h>
PXR_NAMESPACE_OPEN_SCOPE
/// Main class point for the Arnold Render Delegate.
class HdArnoldRenderDelegate final : public HdRenderDelegate {
public:
HDARNOLD_API
HdArnoldRenderDelegate(); ///< Constructor for the Render Delegate.
HDARNOLD_API
~HdArnoldRenderDelegate() override; ///< Destuctor for the Render Delegate.
/// Returns an instance of HdArnoldRenderParam.
///
/// @return Pointer to an instance of HdArnoldRenderParam.
HDARNOLD_API
HdRenderParam* GetRenderParam() const override;
/// Returns the list of RPrim type names that the Render Delegate supports.
///
/// This list contains renderable primitive types, like meshes, curves,
/// volumes and so on.
///
/// @return VtArray holding the name of the supported RPrim types.
HDARNOLD_API
const TfTokenVector& GetSupportedRprimTypes() const override;
/// Returns the list of SPrim type names that the Render Delegate supports.
///
/// This list contains state primitive types, like cameras, materials and
/// lights.
///
/// @return VtArray holding the name of the supported SPrim types.
HDARNOLD_API
const TfTokenVector& GetSupportedSprimTypes() const override;
/// Returns the list of BPrim type names that the Render Delegate supports.
///
/// This list contains buffer primitive types, like render buffers,
/// openvdb assets and so on.
///
/// @return VtArray holding the name of the supported BPrim types.
HDARNOLD_API
const TfTokenVector& GetSupportedBprimTypes() const override;
/// Sets the Render Setting for the given key.
///
/// @param key Name of the Render Setting to set.
/// @param value Value of the Render Setting.
HDARNOLD_API
void SetRenderSetting(const TfToken& key, const VtValue& value) override;
/// Gets the Render Setting for the given key.
///
/// @param key Name of the Render Setting to get.
/// @return Value of the Render Setting.
HDARNOLD_API
VtValue GetRenderSetting(const TfToken& _key) const override;
/// Gets the list of Render Setting descriptors.
///
/// @return std::vector holding HdRenderSettingDescriptor for all the
/// possible Render Settings.
HDARNOLD_API
HdRenderSettingDescriptorList GetRenderSettingDescriptors() const override;
/// Returns an open-format dictionary of render statistics
///
/// @return VtDictionary holding the render stats.
HDARNOLD_API
VtDictionary GetRenderStats() const override;
/// Gets the Resource Registry.
///
/// @return Pointer to the shared HdResourceRegistry.
HDARNOLD_API
HdResourceRegistrySharedPtr GetResourceRegistry() const override;
/// Creates a new Render Pass.
///
/// @param index Pointer to HdRenderIndex.
/// @param collection RPrim collection to bind to the newly created Render
/// Pass.
/// @return A shared pointer to the new Render Pass or nullptr on error.
HDARNOLD_API
HdRenderPassSharedPtr CreateRenderPass(HdRenderIndex* index, HdRprimCollection const& collection) override;
#if PXR_VERSION >= 2102
/// Request to create a new instancer.
///
/// @param id The unique identifier of this instancer.
/// @return A pointer to the new instancer or nullptr on error.
HdInstancer* CreateInstancer(HdSceneDelegate* delegate, SdfPath const& id) override;
#else
/// Creates a new Point Instancer.
///
/// @param delegate Pointer to the Scene Delegate.
/// @param id Path to the Point Instancer.
/// @param instancerId Path to the parent Point Instancer.
/// @return Pointer to a new Point Instancer or nullptr on error.
HDARNOLD_API
HdInstancer* CreateInstancer(HdSceneDelegate* delegate, SdfPath const& id, SdfPath const& instancerId) override;
#endif
/// Destroys a Point Instancer.
///
/// @param instancer Pointer to an instance of HdInstancer.
HDARNOLD_API
void DestroyInstancer(HdInstancer* instancer) override;
#if PXR_VERSION >= 2102
/// Creates a new RPrim.
///
/// @param typeId Type name of the primitive.
/// @param rprimId Path to the primitive.
/// @return Pointer to the newly created RPrim or nullptr on error.
HDARNOLD_API
HdRprim* CreateRprim(TfToken const& typeId, SdfPath const& rprimId) override;
#else
/// Creates a new RPrim.
///
/// @param typeId Type name of the primitive.
/// @param rprimId Path to the primitive.
/// @param instancerId Path to the parent Point Instancer.
/// @return Pointer to the newly created RPrim or nullptr on error.
HDARNOLD_API
HdRprim* CreateRprim(TfToken const& typeId, SdfPath const& rprimId, SdfPath const& instancerId) override;
#endif
/// Destroys an RPrim.
///
/// @param rPrim Pointer to an RPrim.
HDARNOLD_API
void DestroyRprim(HdRprim* rPrim) override;
/// Creates a new SPrim.
///
/// @param typeId Type of the SPrim to create.
/// @param sprimId Path to the primitive.
/// @return Pointer to a new SPrim or nullptr on error.
HDARNOLD_API
HdSprim* CreateSprim(TfToken const& typeId, SdfPath const& sprimId) override;
/// Creates a fallback SPrim.
///
/// @param typeId Type of the fallback SPrim to create.
/// @return Pointer to a fallback SPrim or nullptr on error.
HDARNOLD_API
HdSprim* CreateFallbackSprim(TfToken const& typeId) override;
/// Destroys an SPrim.
///
/// @param sPrim Pointer to an SPrim.
HDARNOLD_API
void DestroySprim(HdSprim* sPrim) override;
/// Creates a new BPrim.
///
/// @param typeId Type of the new BPrim to create.
/// @param bprimId Path to the primitive.
/// @return Pointer to the newly created BPrim or nullptr on error.
HDARNOLD_API
HdBprim* CreateBprim(TfToken const& typeId, SdfPath const& bprimId) override;
/// Creates a fallback BPrim.
///
/// @param typeId Type of the fallback Bprim to create.
/// @return Pointer to the fallback BPrim or nullptr on error.
HDARNOLD_API
HdBprim* CreateFallbackBprim(TfToken const& typeId) override;
/// Destroys a BPrim.
///
/// @param bPrim Pointer to the BPrim.
HDARNOLD_API
void DestroyBprim(HdBprim* bPrim) override;
/// Commits resources to the Render Delegate.
///
/// This is a callback for a Render Delegate to move, update memory for
/// resources.
///
/// @param tracker Pointer to the Change Tracker.
HDARNOLD_API
void CommitResources(HdChangeTracker* tracker) override;
/// Returns a token to indicate wich material binding should be used.
///
/// The function currently returns "full", to indicate production renders,
/// not the default "preview" value.
///
/// @return Name of the preferred material binding.
HDARNOLD_API
TfToken GetMaterialBindingPurpose() const override;
/// Returns a token to indicate which material network should be preferred.
///
/// The function currently returns "arnold", to indicate using
/// outputs:arnold:surface over outputs:surface (and displacement/volume)
/// if avialable.
///
/// @return Name of the preferred material network.
HDARNOLD_API
TfToken GetMaterialNetworkSelector() const override;
/// Suffixes Node names with the Render Delegate's paths.
///
/// @param name Name of the Node.
/// @return The Node's name suffixed by the Render Delegate's path.
HDARNOLD_API
AtString GetLocalNodeName(const AtString& name) const;
/// Gets the active Arnold Universe.
///
/// @return Pointer to the Arnold Universe used by the Render Delegate.
HDARNOLD_API
AtUniverse* GetUniverse() const;
/// Gets the Arnold Options node.
///
/// @return Pointer to the Arnold Options Node.
HDARNOLD_API
AtNode* GetOptions() const;
/// Gets the fallback Arnold Shader.
///
/// The fallback shader is a "utility" shader, with "shade_mode" of "flat",
/// "color_mode" of "color" and a "user_data_rgba" is connected to "color",
/// which reads the "color" attribute with the default value of
/// AtRGBA(1.0f, 1.0f, 1.0f, 1.0).
///
/// @return Pointer to the fallback Arnold Shader.
HDARNOLD_API
AtNode* GetFallbackShader() const;
/// Gets fallback Arnold Volume shader.
///
/// The fallback shader is just an instances of standard_volume.
///
/// @return Pointer to the fallback Arnold Volume Shader.
HDARNOLD_API
AtNode* GetFallbackVolumeShader() const;
/// Gets the default settings for supported aovs.
HDARNOLD_API
HdAovDescriptor GetDefaultAovDescriptor(const TfToken& name) const override;
/// Registers a light in a light linking collection.
///
/// @param name Name of the collection.
/// @param light Pointer to the Hydra Light object.
/// @param isShadow If the clection is for shadow or light linking.
HDARNOLD_API
void RegisterLightLinking(const TfToken& name, HdLight* light, bool isShadow = false);
/// Deregisters a light in a light linking collection.
///
/// @param name Name of the collection.
/// @param light Pointer to the Hydra Light object.
/// @param isShadow If the clection is for shadow or light linking.
HDARNOLD_API
void DeregisterLightLinking(const TfToken& name, HdLight* light, bool isShadow = false);
/// Apply light linking to a shape.
///
/// @param shape Pointer to the Arnold Shape.
/// @param categories List of categories the shape belongs to.
HDARNOLD_API
void ApplyLightLinking(AtNode* shape, const VtArray<TfToken>& categories);
/// Tells whether or not the current convergence iteration should be skipped.
///
/// This function can be used to skip calling the render function in HdRenderPass, so a sync step will be enforced
/// before the next iteration.
///
/// @param renderIndex Pointer to the Hydra Render Index.
/// @param shutterOpen Shutter Open value of the active camera.
/// @param shutterClose Shutter Close value of the active camera.
/// @return True if the iteration should be skipped.
HDARNOLD_API
bool ShouldSkipIteration(HdRenderIndex* renderIndex, float shutterOpen, float shutterClose);
/// Advertise whether this delegate supports pausing and resuming of
/// background render threads. Default implementation returns false.
///
/// @return True if pause/restart is supported.
HDARNOLD_API
bool IsPauseSupported() const override;
/// Pause all of this delegate's background rendering threads. Default
/// implementation does nothing.
///
/// @return True if successful.
HDARNOLD_API
bool Pause() override;
/// Resume all of this delegate's background rendering threads previously
/// paused by a call to Pause. Default implementation does nothing.
///
/// @return True if successful.
HDARNOLD_API
bool Resume() override;
private:
HdArnoldRenderDelegate(const HdArnoldRenderDelegate&) = delete;
HdArnoldRenderDelegate& operator=(const HdArnoldRenderDelegate&) = delete;
void _SetRenderSetting(const TfToken& _key, const VtValue& value);
/// Mutex for the shared Resource Registry.
static std::mutex _mutexResourceRegistry;
/// Atomic counter for the shared Resource Registry.
static std::atomic_int _counterResourceRegistry;
/// Pointer to the shared Resource Registry.
static HdResourceRegistrySharedPtr _resourceRegistry;
using LightLinkingMap = std::unordered_map<TfToken, std::vector<HdLight*>, TfToken::HashFunctor>;
std::mutex _lightLinkingMutex; ///< Mutex to lock all light linking operations.
LightLinkingMap _lightLinks; ///< Light Link categories.
LightLinkingMap _shadowLinks; ///< Shadow Link categories.
std::atomic<bool> _lightLinkingChanged; ///< Whether or not Light Linking have changed.
/// Pointer to an instance of HdArnoldRenderParam.
///
/// This is shared with all the primitives, so they can control the flow of
/// rendering.
std::unique_ptr<HdArnoldRenderParam> _renderParam;
SdfPath _id; ///< Path of the Render Delegate.
AtUniverse* _universe; ///< Universe used by the Render Delegate.
AtNode* _options; ///< Pointer to the Arnold Options Node.
AtNode* _fallbackShader; ///< Pointer to the fallback Arnold Shader.
AtNode* _fallbackVolumeShader; ///< Pointer to the fallback Arnold Volume Shader.
std::string _logFile;
int _verbosityLogFlags = AI_LOG_WARNINGS | AI_LOG_ERRORS;
float _shutterOpen = 0.0f; ///< Saved Shutter Open value of the active camera.
float _shutterClose = 0.0f; ///< Saved Shutter Close value of the active camera.
bool _ignoreVerbosityLogFlags = false;
};
PXR_NAMESPACE_CLOSE_SCOPE