Flow Nodes Shaders
Shaders a written in Metal.
A shader is code run for every pixel in a graphic.
data:image/s3,"s3://crabby-images/fcbde/fcbde6634fe7e37c9eaab785455d099f116f946f" alt=""
data:image/s3,"s3://crabby-images/032d9/032d9339be92851215c4b714ad3c1f5c02df824e" alt=""
Shader
fragment float4 shader() { float red = 1.0; float green = 1.0; float blue = 1.0; float alpha = 1.0; return float4(red, green, blue, alpha); }
This shader retuns 1.0
for every channel in the pixel, displaying a fully white graphic. Colors are reprsented but not limited to values between 0.0
and 1.0
.
Coordinates
fragment float4 shader() { return float4(u, v, 0.0, 1.0); }
data:image/s3,"s3://crabby-images/ca4c2/ca4c2dc24ff2100fa23087362159eb1320b16ba6" alt=""
To determin the location of the current pixel, use the normizlied uv
coodinates. This variable is pre defined and avalible in the main shader function.
Functions
float smooth(float value) { return cos(value * M_PI_F + M_PI_F) / 2.0 + 0.5; } fragment float4 shader() { return float4(smooth(u), smooth(v), 0.0, 1.0); }
data:image/s3,"s3://crabby-images/02904/0290489f9f6116a6efc0766437873a20504813eb" alt=""
Define a function by first defining what type to return, in this case a float
. Then the name and the arguments. This function smoothes out values between 0.0
and 1.0
. Note that the custom function must be above the main shader function.
Colors
data:image/s3,"s3://crabby-images/63eea/63eeaedafeb363b01634bd68a6c37f1e9a8698cb" alt=""
data:image/s3,"s3://crabby-images/2e825/2e825ca397cc41d2c7eca373e8f9a84ee941ea9e" alt=""
fragment float4 shader() { return color_1; }
data:image/s3,"s3://crabby-images/0742c/0742ca1ab22d78bed79b33c2d0c5a8a9256eb603" alt=""
Color and other type of variables can be added by creating a new in-let in the properties panel. Then wire in a node with the chosen type.
Graphics
data:image/s3,"s3://crabby-images/ace89/ace89f0abd05e99eb27fdf81f9ee14f21b1f6554" alt=""
data:image/s3,"s3://crabby-images/1e435/1e4353114a61d0795ad7b750e1d35d537774a1d7" alt=""
fragment float4 shader() { float4 color = graphic_1.sample(sampler, uv); return float4(color.r, color.g * 0.5, 0.0, 1.0); }
data:image/s3,"s3://crabby-images/ef82a/ef82a730f5fa654fc2383937453ceb8be4f2f9e7" alt=""
Graphics can be sampled to get the pixel color.
Bits
data:image/s3,"s3://crabby-images/f5755/f5755fc3c359cab8b6b5a0373658833685431851" alt=""
data:image/s3,"s3://crabby-images/2ca70/2ca70c75ce2fe60fcbe730ae2ace19ca1803e530" alt=""
The shader node has two main properties, resolution and bits. Bits is the color depth, 8bit is default and will give 256 steps of luminance per channel. 16bit and 32bit allows a lot more steps per channel, and allows colors to go below black and beyond white. This can be useful in a Displace Node.