class MaterialBuffer

This is a chunk of memory that will get bound to all shaders at a particular register slot. StereoKit uses this to provide engine values to the shader, and you can also use this to drive graphical shader systems of your own!

For example, if your application has a custom lighting system, fog, wind, or some other system that multiple shaders might need to refer to, this is the perfect tool to use.

The type ‘T’ for this buffer must be a struct that uses the [StructLayout(LayoutKind.Sequential)] attribute for proper copying. It should also match the layout of your equivalent cbuffer in the shader file. Note that shaders often have specific byte alignment requirements! Example:


struct BufferData {
Vec3  windDirection;
float windStrength


cbuffer BufferData : register(b3) {
float3 windDirection;
float  windStrength;

Instance Methods

MaterialBuffer Create a new global MaterialBuffer bound to the register slot id. All shaders will have access to the data provided via this instance’s Set.
Set This will upload your data to the GPU for shaders to use.

Found an issue with these docs, or have some additional questions? Create an Issue on Github!