MaterialX 1.39.2
Loading...
Searching...
No Matches
ShaderNode.h
Go to the documentation of this file.
1//
2// Copyright Contributors to the MaterialX Project
3// SPDX-License-Identifier: Apache-2.0
4//
5
6#ifndef MATERIALX_SHADERNODE_H
7#define MATERIALX_SHADERNODE_H
8
11
13
17
18#include <MaterialXCore/Node.h>
19
20MATERIALX_NAMESPACE_BEGIN
21
22class ShaderNode;
23class ShaderPort;
24class ShaderInput;
25class ShaderOutput;
26class ShaderGraph;
27
29using ShaderPortPtr = shared_ptr<class ShaderPort>;
31using ShaderInputPtr = shared_ptr<class ShaderInput>;
33using ShaderOutputPtr = shared_ptr<class ShaderOutput>;
35using ShaderNodePtr = shared_ptr<class ShaderNode>;
37using ShaderInputVec = vector<ShaderInput*>;
38
40struct MX_GENSHADER_API ShaderMetadata
41{
42 string name;
43 TypeDesc type;
44 ValuePtr value;
45 ShaderMetadata(const string& n, TypeDesc t, ValuePtr v = nullptr) :
46 name(n),
47 type(t),
48 value(v)
49 {
50 }
51};
52using ShaderMetadataVec = vector<ShaderMetadata>;
53using ShaderMetadataVecPtr = shared_ptr<ShaderMetadataVec>;
54
58class MX_GENSHADER_API ShaderMetadataRegistry : public GenUserData
59{
60 public:
61 static const string USER_DATA_NAME;
62
66 void addMetadata(const string& name, TypeDesc type, ValuePtr value = nullptr)
67 {
68 if (_entryIndex.count(name) == 0)
69 {
70 _entryIndex[name] = _entries.size();
71 _entries.emplace_back(name, type, value);
72 }
73 }
74
77 const ShaderMetadata* findMetadata(const string& name) const
78 {
79 auto it = _entryIndex.find(name);
80 return it != _entryIndex.end() ? &_entries[it->second] : nullptr;
81 }
82
85 ShaderMetadata* findMetadata(const string& name)
86 {
87 auto it = _entryIndex.find(name);
88 return it != _entryIndex.end() ? &_entries[it->second] : nullptr;
89 }
90
92 const ShaderMetadataVec& getAllMetadata() const
93 {
94 return _entries;
95 }
96
98 void clear()
99 {
100 _entryIndex.clear();
101 _entries.clear();
102 }
103
104 protected:
105 vector<ShaderMetadata> _entries;
106 std::unordered_map<string, size_t> _entryIndex;
107};
108
109using ShaderMetadataRegistryPtr = shared_ptr<ShaderMetadataRegistry>;
110
112class MX_GENSHADER_API ShaderPortFlag
113{
114 public:
115 static const uint32_t UNIFORM = 1u << 0;
116 static const uint32_t EMITTED = 1u << 1;
117 static const uint32_t BIND_INPUT = 1u << 2;
118};
119
122class MX_GENSHADER_API ShaderPort : public std::enable_shared_from_this<ShaderPort>
123{
124 public:
126 ShaderPort(ShaderNode* node, TypeDesc type, const string& name, ValuePtr value = nullptr);
127
130 {
131 return shared_from_this();
132 }
133
135 ShaderNode* getNode() { return _node; }
136
138 const ShaderNode* getNode() const { return _node; }
139
141 void setType(TypeDesc type) { _type = type; }
142
144 TypeDesc getType() const { return _type; }
145
147 void setName(const string& name) { _name = name; }
148
150 const string& getName() const { return _name; }
151
153 string getFullName() const;
154
156 void setVariable(const string& name) { _variable = name; }
157
159 const string& getVariable() const { return _variable; }
160
162 void setSemantic(const string& semantic) { _semantic = semantic; }
163
165 const string& getSemantic() const { return _semantic; }
166
168 void setValue(ValuePtr value) { _value = value; }
169
171 ValuePtr getValue() const { return _value; }
172
174 string getValueString() const;
175
177 void setColorSpace(const string& colorspace) { _colorspace = colorspace; }
178
180 const string& getColorSpace() const { return _colorspace; }
181
183 void setUnit(const string& unit) { _unit = unit; }
184
186 const string& getUnit() const { return _unit; }
187
190 void setGeomProp(const string& geomprop) { _geomprop = geomprop; }
191
193 const string& getGeomProp() const { return _geomprop; }
194
196 void setPath(const string& path) { _path = path; }
197
199 const string& getPath() const { return _path; }
200
202 void setFlags(uint32_t flags) { _flags = flags; }
203
205 uint32_t getFlags() const { return _flags; }
206
208 void setFlag(uint32_t flag, bool value)
209 {
210 _flags = value ? (_flags | flag) : (_flags & ~flag);
211 }
212
214 bool getFlag(uint32_t flag) const
215 {
216 return ((_flags & flag) != 0);
217 }
218
220 void setUniform() { _flags |= ShaderPortFlag::UNIFORM; }
221
223 bool isUniform() const { return (_flags & ShaderPortFlag::UNIFORM) != 0; }
224
226 void setEmitted() { _flags |= ShaderPortFlag::EMITTED; }
227
229 bool isEmitted() const { return (_flags & ShaderPortFlag::EMITTED) != 0; }
230
232 void setBindInput() { _flags |= ShaderPortFlag::BIND_INPUT; }
233
235 bool isBindInput() const { return (_flags & ShaderPortFlag::BIND_INPUT) != 0; }
236
238 void setMetadata(ShaderMetadataVecPtr metadata) { _metadata = metadata; }
239
241 ShaderMetadataVecPtr getMetadata() { return _metadata; }
242
244 const ShaderMetadataVecPtr& getMetadata() const { return _metadata; }
245
246 protected:
247 ShaderNode* _node;
248 TypeDesc _type;
249 string _name;
250 string _path;
251 string _semantic;
252 string _variable;
253 ValuePtr _value;
254 string _unit;
255 string _colorspace;
256 string _geomprop;
257 ShaderMetadataVecPtr _metadata;
258 uint32_t _flags;
259};
260
263class MX_GENSHADER_API ShaderInput : public ShaderPort
264{
265 public:
266 ShaderInput(ShaderNode* node, TypeDesc type, const string& name);
267
270 ShaderOutput* getConnection() { return _connection; }
271
274 const ShaderOutput* getConnection() const { return _connection; }
275
277 void makeConnection(ShaderOutput* src);
278
281
285
286 protected:
287 ShaderOutput* _connection;
288 string _channels;
289 friend class ShaderOutput;
290};
291
294class MX_GENSHADER_API ShaderOutput : public ShaderPort
295{
296 public:
297 ShaderOutput(ShaderNode* node, TypeDesc type, const string& name);
298
301 const ShaderInputVec& getConnections() const { return _connections; }
302
304 void makeConnection(ShaderInput* dst);
305
307 void breakConnection(ShaderInput* dst);
308
311
312 protected:
313 ShaderInputVec _connections;
314 friend class ShaderInput;
315};
316
319class MX_GENSHADER_API ShaderNode
320{
321 public:
322 virtual ~ShaderNode() { }
323
326 {
327 public:
328 // Node classes
329 static const uint32_t TEXTURE = 1 << 0;
330 static const uint32_t CLOSURE = 1 << 1;
331 static const uint32_t SHADER = 1 << 2;
332 static const uint32_t MATERIAL = 1 << 3;
333 // Specific texture node types
334 static const uint32_t FILETEXTURE = 1 << 4;
335 static const uint32_t CONDITIONAL = 1 << 5;
336 static const uint32_t CONSTANT = 1 << 6;
337 // Specific closure types
338 static const uint32_t BSDF = 1 << 7;
339 static const uint32_t BSDF_R = 1 << 8;
340 static const uint32_t BSDF_T = 1 << 9;
341 static const uint32_t EDF = 1 << 10;
342 static const uint32_t VDF = 1 << 11;
343 static const uint32_t LAYER = 1 << 12;
344 // Specific shader types
345 static const uint32_t SURFACE = 1 << 13;
346 static const uint32_t VOLUME = 1 << 14;
347 static const uint32_t LIGHT = 1 << 15;
348 static const uint32_t UNLIT = 1 << 16;
349 // Types based on nodegroup
350 static const uint32_t SAMPLE2D = 1 << 17;
351 static const uint32_t SAMPLE3D = 1 << 18;
352 static const uint32_t GEOMETRIC = 1 << 19;
353 static const uint32_t DOT = 1 << 20;
354 };
355
356 static const ShaderNodePtr NONE;
357
358 static const string CONSTANT;
359 static const string DOT;
360 static const string IMAGE;
361 static const string SURFACESHADER;
362 static const string SCATTER_MODE;
363 static const string BSDF_R;
364 static const string BSDF_T;
365 static const string TRANSFORM_POINT;
366 static const string TRANSFORM_VECTOR;
367 static const string TRANSFORM_NORMAL;
368 static const string TEXTURE2D_GROUPNAME;
369 static const string TEXTURE3D_GROUPNAME;
370 static const string PROCEDURAL2D_GROUPNAME;
371 static const string PROCEDURAL3D_GROUPNAME;
372 static const string GEOMETRIC_GROUPNAME;
373
374 public:
376 ShaderNode(const ShaderGraph* parent, const string& name);
377
379 static ShaderNodePtr create(const ShaderGraph* parent, const string& name, const NodeDef& nodeDef,
380 GenContext& context);
381
383 static ShaderNodePtr create(const ShaderGraph* parent, const string& name, ShaderNodeImplPtr impl,
384 unsigned int classification = Classification::TEXTURE);
385
387 virtual bool isAGraph() const { return false; }
388
392 const ShaderGraph* getParent() const
393 {
394 return _parent;
395 }
396
399 void setClassification(uint32_t c)
400 {
401 _classification = c;
402 }
403
405 uint32_t getClassification() const
406 {
407 return _classification;
408 }
409
411 void addClassification(uint32_t c)
412 {
413 _classification |= c;
414 }
415
417 bool hasClassification(uint32_t c) const
418 {
419 return (_classification & c) == c;
420 }
421
423 const string& getName() const
424 {
425 return _name;
426 }
427
430 {
431 return *_impl;
432 }
433
436 void initialize(const Node& node, const NodeDef& nodeDef, GenContext& context);
437
439 ShaderInput* addInput(const string& name, TypeDesc type);
440 ShaderOutput* addOutput(const string& name, TypeDesc type);
441
443 size_t numInputs() const { return _inputOrder.size(); }
444 size_t numOutputs() const { return _outputOrder.size(); }
445
447 ShaderInput* getInput(size_t index) { return _inputOrder[index]; }
448 ShaderOutput* getOutput(size_t index = 0) { return _outputOrder[index]; }
449 const ShaderInput* getInput(size_t index) const { return _inputOrder[index]; }
450 const ShaderOutput* getOutput(size_t index = 0) const { return _outputOrder[index]; }
451
453 ShaderInput* getInput(const string& name);
454 ShaderOutput* getOutput(const string& name);
455 const ShaderInput* getInput(const string& name) const;
456 const ShaderOutput* getOutput(const string& name) const;
457
459 const vector<ShaderInput*>& getInputs() const { return _inputOrder; }
460 const vector<ShaderOutput*>& getOutputs() const { return _outputOrder; }
461
463 void setMetadata(ShaderMetadataVecPtr metadata) { _metadata = metadata; }
464
466 ShaderMetadataVecPtr getMetadata() { return _metadata; }
467
469 const ShaderMetadataVecPtr& getMetadata() const { return _metadata; }
470
474 bool isEditable(const ShaderInput& input) const
475 {
476 return (!_impl || _impl->isEditable(input));
477 }
478
482 bool isEditable(const ShaderGraphInputSocket& input) const
483 {
484 return (!_impl || _impl->isEditable(input));
485 }
486
487 protected:
489 void createMetadata(const NodeDef& nodeDef, GenContext& context);
490
491 const ShaderGraph* _parent;
492 string _name;
493 uint32_t _classification;
494
495 std::unordered_map<string, ShaderInputPtr> _inputMap;
496 vector<ShaderInput*> _inputOrder;
497
498 std::unordered_map<string, ShaderOutputPtr> _outputMap;
499 vector<ShaderOutput*> _outputOrder;
500
501 ShaderNodeImplPtr _impl;
502 ShaderMetadataVecPtr _metadata;
503
504 friend class ShaderGraph;
505};
506
507MATERIALX_NAMESPACE_END
508
509#endif
User data base class for shader generation.
Macros for declaring imported and exported symbols.
shared_ptr< ShaderNodeImpl > ShaderNodeImplPtr
Shared pointer to a ShaderNodeImpl.
Definition Library.h:40
Node element subclasses.
ShaderOutput ShaderGraphInputSocket
An internal input socket in a shader graph, used for connecting internal nodes to the outside.
Definition ShaderGraph.h:32
shared_ptr< class ShaderPort > ShaderPortPtr
Shared pointer to a ShaderPort.
Definition ShaderNode.h:29
shared_ptr< class ShaderOutput > ShaderOutputPtr
Shared pointer to a ShaderOutput.
Definition ShaderNode.h:33
shared_ptr< class ShaderNode > ShaderNodePtr
Shared pointer to a ShaderNode.
Definition ShaderNode.h:35
vector< ShaderInput * > ShaderInputVec
A vector of ShaderInput pointers.
Definition ShaderNode.h:37
shared_ptr< class ShaderInput > ShaderInputPtr
Shared pointer to a ShaderInput.
Definition ShaderNode.h:31
Base class for shader node implementations.
Type descriptor for a MaterialX data type.
shared_ptr< Value > ValuePtr
A shared pointer to a Value.
Definition Value.h:30
A context class for shader generation.
Definition GenContext.h:31
A node definition element within a Document.
Definition Definition.h:82
A node element within a NodeGraph or Document.
Definition Node.h:53
Class representing a graph (DAG) for shader generation.
Definition ShaderGraph.h:44
An input on a ShaderNode.
Definition ShaderNode.h:264
void breakConnection()
Break the connection to this input.
void makeConnection(ShaderOutput *src)
Make a connection from the given source output to this input.
const ShaderOutput * getConnection() const
Return a connection to an upstream node output, or nullptr if not connected.
Definition ShaderNode.h:274
ShaderOutput * getConnection()
Return a connection to an upstream node output, or nullptr if not connected.
Definition ShaderNode.h:270
ShaderNode * getConnectedSibling() const
Return the sibling node connected upstream, or nullptr if there is no sibling upstream.
A registry for metadata that will be exported to the generated shader if found on nodes and inputs du...
Definition ShaderNode.h:59
void addMetadata(const string &name, TypeDesc type, ValuePtr value=nullptr)
Add a new metadata entry to the registry.
Definition ShaderNode.h:66
const ShaderMetadataVec & getAllMetadata() const
Return all entries in the registry.
Definition ShaderNode.h:92
ShaderMetadata * findMetadata(const string &name)
Return the metadata registered for the given name, or nullptr if no such entry is found.
Definition ShaderNode.h:85
void clear()
Clear all entries in the registry.
Definition ShaderNode.h:98
const ShaderMetadata * findMetadata(const string &name) const
Return the metadata registered for the given name, or nullptr if no such entry is found.
Definition ShaderNode.h:77
Flags for classifying nodes into different categories.
Definition ShaderNode.h:326
static const uint32_t EDF
A transmission BSDF node.
Definition ShaderNode.h:341
static const uint32_t CONDITIONAL
A file texture node.
Definition ShaderNode.h:335
static const uint32_t SAMPLE3D
Can be sampled in 2D (uv space)
Definition ShaderNode.h:351
static const uint32_t VOLUME
A surface shader node.
Definition ShaderNode.h:346
static const uint32_t GEOMETRIC
Can be sampled in 3D (position)
Definition ShaderNode.h:352
static const uint32_t CONSTANT
A conditional node.
Definition ShaderNode.h:336
static const uint32_t SHADER
Any node that represents light integration.
Definition ShaderNode.h:331
static const uint32_t FILETEXTURE
Any node that outputs a material.
Definition ShaderNode.h:334
static const uint32_t DOT
Geometric input.
Definition ShaderNode.h:353
static const uint32_t BSDF
A constant node.
Definition ShaderNode.h:338
static const uint32_t SURFACE
A node for vertical layering of other closure nodes.
Definition ShaderNode.h:345
static const uint32_t LIGHT
A volume shader node.
Definition ShaderNode.h:347
static const uint32_t VDF
A EDF node.
Definition ShaderNode.h:342
static const uint32_t SAMPLE2D
An unlit surface shader node.
Definition ShaderNode.h:350
static const uint32_t LAYER
A VDF node.
Definition ShaderNode.h:343
static const uint32_t MATERIAL
Any node that outputs a shader.
Definition ShaderNode.h:332
static const uint32_t BSDF_R
A BSDF node.
Definition ShaderNode.h:339
static const uint32_t BSDF_T
A reflection BSDF node.
Definition ShaderNode.h:340
static const uint32_t CLOSURE
Any node that outputs floats, colors, vectors, etc.
Definition ShaderNode.h:330
static const uint32_t UNLIT
A light shader node.
Definition ShaderNode.h:348
Class representing a node in the shader generation DAG.
Definition ShaderNode.h:320
ShaderInput * getInput(const string &name)
Get inputs/outputs by name.
bool isEditable(const ShaderInput &input) const
Returns true if an input is editable by users.
Definition ShaderNode.h:474
ShaderInput * getInput(size_t index)
Get inputs/outputs by index.
Definition ShaderNode.h:447
const ShaderGraph * getParent() const
Return the parent graph that owns this node.
Definition ShaderNode.h:392
const vector< ShaderInput * > & getInputs() const
Get vector of inputs/outputs.
Definition ShaderNode.h:459
const string & getName() const
Return the name of this node.
Definition ShaderNode.h:423
ShaderInput * addInput(const string &name, TypeDesc type)
Add inputs/outputs.
void setMetadata(ShaderMetadataVecPtr metadata)
Set the metadata vector.
Definition ShaderNode.h:463
static ShaderNodePtr create(const ShaderGraph *parent, const string &name, const NodeDef &nodeDef, GenContext &context)
Create a new node from a nodedef.
bool hasClassification(uint32_t c) const
Return true if this node matches the given classification.
Definition ShaderNode.h:417
void addClassification(uint32_t c)
Add classification bits to this node.
Definition ShaderNode.h:411
const ShaderMetadataVecPtr & getMetadata() const
Get the metadata vector.
Definition ShaderNode.h:469
void initialize(const Node &node, const NodeDef &nodeDef, GenContext &context)
Initialize this shader node with all required data from the given node and nodedef.
ShaderMetadataVecPtr getMetadata()
Get the metadata vector.
Definition ShaderNode.h:466
virtual bool isAGraph() const
Return true if this node is a graph.
Definition ShaderNode.h:387
static ShaderNodePtr create(const ShaderGraph *parent, const string &name, ShaderNodeImplPtr impl, unsigned int classification=Classification::TEXTURE)
Create a new node from a node implementation.
uint32_t getClassification() const
Get classification bits set for this node.
Definition ShaderNode.h:405
void setClassification(uint32_t c)
Set classification bits for this node, replacing any previous set bits.
Definition ShaderNode.h:399
void createMetadata(const NodeDef &nodeDef, GenContext &context)
Create metadata from the nodedef according to registered metadata.
const ShaderNodeImpl & getImplementation() const
Return the implementation used for this node.
Definition ShaderNode.h:429
ShaderNode(const ShaderGraph *parent, const string &name)
Constructor.
bool isEditable(const ShaderGraphInputSocket &input) const
Returns true if a graph input is accessible by users.
Definition ShaderNode.h:482
size_t numInputs() const
Get number of inputs/outputs.
Definition ShaderNode.h:443
Class handling the shader generation implementation for a node.
Definition ShaderNodeImpl.h:32
An output on a ShaderNode.
Definition ShaderNode.h:295
void makeConnection(ShaderInput *dst)
Make a connection from this output to the given input.
void breakConnection(ShaderInput *dst)
Break a connection from this output to the given input.
void breakConnections()
Break all connections from this output.
const ShaderInputVec & getConnections() const
Return a set of connections to downstream node inputs, empty if not connected.
Definition ShaderNode.h:301
Flags set on shader ports.
Definition ShaderNode.h:113
An input or output port on a ShaderNode.
Definition ShaderNode.h:123
ShaderNode * getNode()
Return the node this port belongs to.
Definition ShaderNode.h:135
ValuePtr getValue() const
Return the value set on this port.
Definition ShaderNode.h:171
void setFlag(uint32_t flag, bool value)
Set the on|off state of a given flag.
Definition ShaderNode.h:208
bool isBindInput() const
Return the emitted state of this port.
Definition ShaderNode.h:235
void setUnit(const string &unit)
Set a unit type for the value on this port.
Definition ShaderNode.h:183
void setPath(const string &path)
Set the path to this port.
Definition ShaderNode.h:196
void setType(TypeDesc type)
Set the data type for this port.
Definition ShaderNode.h:141
const string & getColorSpace() const
Return the source color space for the value on this port.
Definition ShaderNode.h:180
const string & getName() const
Return the name of this port.
Definition ShaderNode.h:150
void setColorSpace(const string &colorspace)
Set a source color space for the value on this port.
Definition ShaderNode.h:177
string getFullName() const
Return the name of this port.
void setMetadata(ShaderMetadataVecPtr metadata)
Set the metadata vector.
Definition ShaderNode.h:238
const string & getGeomProp() const
Get geomprop name.
Definition ShaderNode.h:193
void setFlags(uint32_t flags)
Set flags on this port.
Definition ShaderNode.h:202
ShaderPortPtr getSelf()
Return a shared pointer instance of this object.
Definition ShaderNode.h:129
void setName(const string &name)
Set the name of this port.
Definition ShaderNode.h:147
const ShaderMetadataVecPtr & getMetadata() const
Get the metadata vector.
Definition ShaderNode.h:244
const ShaderNode * getNode() const
Return the node this port belongs to.
Definition ShaderNode.h:138
TypeDesc getType() const
Return the data type for this port.
Definition ShaderNode.h:144
bool isEmitted() const
Return the emitted state of this port.
Definition ShaderNode.h:229
void setGeomProp(const string &geomprop)
Set geomprop name if the input has a default geomprop to be assigned when it is unconnected.
Definition ShaderNode.h:190
ShaderMetadataVecPtr getMetadata()
Get the metadata vector.
Definition ShaderNode.h:241
void setBindInput()
Set the bind input state on this port to true.
Definition ShaderNode.h:232
const string & getUnit() const
Return the unit type for the value on this port.
Definition ShaderNode.h:186
void setUniform()
Set the uniform flag this port to true.
Definition ShaderNode.h:220
const string & getVariable() const
Return the variable name of this port.
Definition ShaderNode.h:159
void setSemantic(const string &semantic)
Set the variable semantic of this port.
Definition ShaderNode.h:162
string getValueString() const
Return the value set on this port as a string, or an empty string if there is no value.
bool getFlag(uint32_t flag) const
Return the on|off state of a given flag.
Definition ShaderNode.h:214
ShaderPort(ShaderNode *node, TypeDesc type, const string &name, ValuePtr value=nullptr)
Constructor.
void setEmitted()
Set the emitted state on this port to true.
Definition ShaderNode.h:226
bool isUniform() const
Return the uniform flag on this port.
Definition ShaderNode.h:223
void setValue(ValuePtr value)
Set a value on this port.
Definition ShaderNode.h:168
void setVariable(const string &name)
Set the variable name of this port.
Definition ShaderNode.h:156
const string & getPath() const
Return the path to this port.
Definition ShaderNode.h:199
const string & getSemantic() const
Return the variable semantic of this port.
Definition ShaderNode.h:165
uint32_t getFlags() const
Return flags set on this port.
Definition ShaderNode.h:205
A type descriptor for MaterialX data types.
Definition TypeDesc.h:36
Metadata to be exported to generated shader.
Definition ShaderNode.h:41