.. _global-constants:

****************
Global constants
****************

DSHL supports some built-in global constants, which you can grab in the preshader :ref:`preshader` and then use in ``hlsl`` blocks.

List of constants:

- ``globtm`` -- ``float4x4`` world-view-projection matrix
- ``projtm`` -- ``float4x4`` projection matrix
- ``viewprojtm`` -- ``float4x4`` view-projection matrix
- ``local_view_x, local_view_y, local_view_z, local_view_pos`` -- 1..4 columns of inverse view matrix, in ``float3`` format
- ``world_local_x, world_local_y, world_local_z, world_local_pos`` -- 1..4 columns of world transform matrix, in ``float3`` format

Usage example:

.. code-block:: c

  shader example_shader
  {
    // grabbing global constants via preshader
    (vs)
    {
      viewprojtm@f44 = viewprojtm;
      world_local_x@f3 = world_local_x;
      world_local_y@f3 = world_local_y;
      world_local_z@f3 = world_local_z;
      world_local_pos@f3 = world_local_pos;
    }

    hlsl(vs)
    {
      float4 example_vs(float4 pos: POSITION0)
      {
        // using global constants in hlsl
        float3 worldPos = float3(pos.x * world_local_x + pos.y * world_local_y + pos.z * world_local_z + world_local_pos);
        return mulPointTm(worldPos, viewprojtm);
      }
    }

  }

.. warning::
  Matrix constants ``globtm, projtm, viewprojtm`` are only available for ``(vs)`` preshader.