1
0
mirror of https://gitlab.com/OpenMW/openmw.git synced 2025-01-07 12:54:00 +00:00
OpenMW/docs/source/reference/modding/custom-shader-effects.rst

55 lines
2.2 KiB
ReStructuredText

Custom Shader Effects
#####################
OpenMW leverages the `NiStringExtraData` node to inject special shader flags and effects.
This nodes must have the prefix `omw:data` and have a valid JSON object that follows.
.. note::
This is a new feature to inject OpenMW specific effects. Only a single
effect is currently supported. By default, the shader effects will propogate
to all a nodes children. Other propogation modes and effects will come with
future releases.
See below to see the currently supported effects.
Soft Effect
-----------
This effect softens the intersection of alpha-blended planes with other opaque
geometry. This effect is automatically applied to all particle systems, but can
be applied to any mesh or node. This is useful when layering many alpha-blended
planes for various effects like steam over a hotspring or low hanging fog for
dungeons.
To use this feature the :ref:`soft particles` setting must be enabled.
This settings can either be activated in the OpenMW launcher or changed in `settings.cfg`:
::
[Shaders]
soft particles = true
Variables.
+---------+--------------------------------------------------------------------------------------------------------+---------+---------+
| Name | Description | Type | Default |
+---------+--------------------------------------------------------------------------------------------------------+---------+---------+
| size | Scaling ratio. Larger values will make a softer fade effect. Larger geometry requires higher values. | integer | 45 |
+---------+--------------------------------------------------------------------------------------------------------+---------+---------+
| falloff | Fades away geometry as camera gets closer. Geometry full fades when parallel to camera. | boolean | false |
+---------+--------------------------------------------------------------------------------------------------------+---------+---------+
Example usage.
::
omw:data {
"shader" : {
"soft_effect" : {
"size": 250,
"falloff" : false,
}
}
}