mirror of
				https://github.com/OpenMW/openmw.git
				synced 2025-10-26 03:56:39 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			56 lines
		
	
	
	
		
			2.5 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
			
		
		
	
	
			56 lines
		
	
	
	
		
			2.5 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
| Custom Shader Effects
 | |
| #####################
 | |
| 
 | |
| OpenMW leverages the `NiStringExtraData` node to inject special shader flags and effects.
 | |
| This node must have the prefix `omw:data` and have a valid JSON object that follows.
 | |
| 
 | |
| .. note::
 | |
| 
 | |
|     This is a new feature to inject OpenMW-specific shader effects. Only a single
 | |
|     effect is currently supported. By default, the shader effects will propogate
 | |
|     to all a node's children. Other propogation modes and effects will come with
 | |
|     future releases.
 | |
| 
 | |
| 
 | |
| 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 setting 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   |
 | |
| +--------------+--------------------------------------------------------------------------------------------------------+---------+---------+
 | |
| | falloffDepth | The units at which geometry starts to fade.                                                            | float   | 300     |
 | |
| +--------------+--------------------------------------------------------------------------------------------------------+---------+---------+
 | |
| 
 | |
| Example usage.
 | |
| 
 | |
| ::
 | |
| 
 | |
|     omw:data {
 | |
|         "shader" : {
 | |
|             "soft_effect" : {
 | |
|                 "size": 250,
 | |
|                 "falloff" : false,
 | |
|                 "falloffDepth": 5,
 | |
|             }
 | |
|         }
 | |
|     }
 |