Data Types
Description
There are a number of Data Types in Shader Graph. Each Port on a Node has an associated Data Type that defines what edges can be connected to it. The Data Types have colors for usability, these colors are applied to ports and edges of that Data Type.
Some Data Types have associated Property Types for exposing these values to the Inspector for Materials that use the shader.
Data Types
Name | Color | Description |
---|---|---|
Vector 1 | Light Blue | A Vector 1 or scalar value |
Vector 2 | Green | A Vector 2 value |
Vector 3 | Yellow | A Vector 3 value |
Vector 4 | Pink | A Vector 4 value |
Dynamic Vector | Light Blue | See Dynamic Data Types below |
Matrix 2 | Blue | A Matrix 2x2 value |
Matrix 3 | Blue | A Matrix 3x3 value |
Matrix 4 | Blue | A Matrix 4x4 value |
Dynamic Matrix | Blue | See Dynamic Data Types below |
Dynamic | Blue | See Dynamic Data Types below |
Boolean | Purple | A Boolean value. Defined as a float in the generated shader |
Texture 2D | Red | A Texture 2D asset |
Texture 2D Array | Red | A Texture 2D Array asset |
Texture 3D | Red | A Texture 3D asset |
Cubemap | Red | A Cubemap asset |
Gradient | Grey | A Gradient value. Defined as a struct in the generated shader |
SamplerState | Grey | A state used for sampling a texture |
Promoting/Truncating
All Vector types can be promoted or truncated to match any Vector type Port. This behaviour occurs only when the Port in question is not of type Dynamic Vector. When truncating, excess channels are simply removed. When promoting, the extra required channels are filled by default values. These values values are (0, 0, 0, 1).
Dynamic Data Types
Some Data Types are dynamic. This means a port using these Data Types can change their underlying Concrete Data Type based on what Data Type is connected to it. By default, Nodes using dynamic Data Types can only have one Concrete Data Type, meaning that once a connected edge has applied its Data Type to that port, all other Dynamic Data Type slots of that Node will apply the same Data Type.
One notable exception to this is the Multiply Node which allows both Dynamic Matrix and Vector types.
Dynamic Vector
The Dynamic Vector type allows connected edges of any Vector type. All connected edges are automatically truncated to the type with the lowest dimension, unless the lowest dimension is 1, in which case the Vector 1 is promoted.
Dynamic Matrix
The Dynamic Matrix type allows connected edges of any Matrix type. All connected edges are automatically truncated to the type with the lowest dimension.
Dynamic
The Dynamic type is a special case. Nodes that support it must define how it is validated. In the case of the Multiply Node, it allows connections of any Vector or Matrix type, ensuring the correct multiplication is applied depending on the mix of Data Types.