Skip to content

Canvas Shader Coding

grondag edited this page Jul 22, 2020 · 5 revisions

To ensure maximum compatibility for multiple mods accessing the shader pipeline, Canvas implements an API (defined by FREX) and requires some conventions to be followed.

Mod Shaders

Mod authors can create vertex shaders, fragment shaders or both. When only one is present, an appropriate "default" shader is used.

Mod shaders do not contain a main method, and should not include attribute or uniform declarations. (Those are handled by Canvas.)

Instead, mod shaders implement one or more of the following methods:

void frx_startFragment(inout frx_FragmentData fragData)

void frx_startVertex(inout frx_VertexData data)

void frx_endVertex(inout frx_VertexData data)

The data structures and their usage within these methods are defined here:

FREX Shader API and Library

Canvas bundles several libraries that enable interaction with the world or player from within shaders. These are located here and include comments explaining usage.

Canvas also include some general library routines that have no dependency on game state. Those are located here.

Most GLSL public methods and declarations begin with a frx_ or FRX_ prefix to distinguish them and prevent name conflicts with mods or OpenGl itself.

Including Libraries

Canvas includes a crude preprocessor that can include shader sources files via an #include directive. It supports nesting and arbitrary namespaces paths. See canvas source files for examples of usage.

When the shader is compiled all included source is compounded into a single source file that is sent to the graphics driver. OpenGL is typically good about removing dead code, but it is advisable to keep libraries small and only include what you need.

Canvas Internals

All source located in /assets/canvas/shaders/internal is non-public API and should not be referenced outside of Canvas code. No effort will be made to support such usage nor to prevent breakage if it happens. Future versions of Canvas may detect and warn against such usage to prevent inadvertent dependencies.

Other Restrictions

  • Canvas will define the GLSL version as 120 to ensure compatibility. Later versions are unsupported and conflicting declarations will fail.
  • No extensions should activated or depended on except GL_EXT_gpu_shader4
Clone this wiki locally