# Shader Family: rendinst_layered
## Overview
As of writing, the `rendinst_layered` family includes four shaders:
- [`rendinst_layered`](#rendinst_layered): The foundational shader of the
family.
- [`dynamic_layered`](#dynamic_layered): A dynamic version designed for destrs.
- [`rendinst_layered_atest`](#rendinst_layered_atest): A version that
supports alpha test for detail textures.
- [`rendinst_layered_hmap_blend`](#rendinst_layered_hmap_blend): A version
that includes heightmap blending functionality.
Let's examine the parameters for each shader.
## rendinst_layered
```{seealso}
For more information, see [rendinst_layered](rendinst_layered.md) shader.
```
## dynamic_layered
This shader functions similarly to `rendinst_layered`, but it is optimized for
dynamic objects (destrs).
## rendinst_layered_atest
This version supports alpha test for one or both detail textures.
### Parameters
- `blended_atest`: 0/1 (disabled/enabled)
- `detail1_atest_weight`: Alpha test level for the first detail texture
(default: 127)
- `detail2_atest_weight`: Alpha test level for the second detail texture
(default: 127)
## rendinst_layered_lightmap
This is the standard `rendinst_layered` shader with added support for emissive
maps.
```{seealso}
For more information, see
[rendinst_layered_lightmap](rendinst_layered_lightmap.md) shader.
```
## rendinst_layered_hmap_blend
This version introduces a heightmap blend feature that allows seamless
transitions between the model and the terrain. It also supports projecting a
clipmap using top-down projection onto the model. The clipmap is blended into
the material in two layers: the first blends from the ground up to a specified
height, and the second applies a Perlin noise mask on horizontal surfaces with
positive normals, also modifiable by distance from the ground.
This shader is ideal for objects like rocks, cliffs, and debris piles that need
to blend into the terrain or hide seams with the ground.
Below are screenshots illustrating the effect:
Without heightmap blend |
With heightmap blend |
Without clipmap projection |
With clipmap projection |
### Parameters
```{note}
The `hmp_blend_height` parameter is deprecated! If you encounter it, please
remove it.
```
- `land_blend_dist`: Specifies the height (in meters) for the first layer of
clipmap blending, from the ground up. Default is 0.3 meters if not specified.
- `land_perlin_height`: Specifies the maximum height (in meters) for the
second layer of clipmap projection, which uses Perlin noise and applies to
horizontal surfaces with positive normals.
- `land_perlin_scale`: Controls the scale of the Perlin noise. A lower value
results in coarser noise. Start with a value of 0.2 for tuning.
- `land_perlin_blend`: Defines the range (in meters) over which the Perlin
noise fades from 1 to 0, starting from the `land_blend_perlin_height`
parameter. For example, if `land_blend_perlin_height` is set to 20 meters and
you want the Perlin noise to begin fading 1 meter above the ground, set
`land_blend_perlin_blend` to 19.
- `land_blend_normal_start`: The normal value at which the clipmap
projection begins. Default is 1. A value greater than 1 reduces the opacity on
perfectly horizontal surfaces.
- `land_blend_normal_end`: The normal value at which the clipmap projection
ends. Default is 0.5.
Below is an illustration showing how the Perlin noise strength gradient operates
from `land_blend_perlin_height` (upper bound) to `land_blend_perlin_blend`
(lower bound):
### Salt Sediments
The `rendinst_layered_hmap_blend` shader is often used on rocks and cliffs. It
includes a feature called Salt Sediments, which simulates effects like waterline
marks, rust, or algae growth. This effect is illustrated below:
In the example above, the following texture was used:
This texture has an alpha channel that controls transparency. It replaces the
combined albedo of the first detail texture and overlay.
```{note}
It only affects the first detail texture.
```
In the example, the effect is visible on the stone, but the orange moss (the
second detail texture) remains unchanged.
The texture is subtracted using the AlbedoAO of the overlay and stretches
infinitely downward below the water level. If this effect is unwanted, make the
bottom two lines of pixels in the texture fully transparent.
**Parameters:**
In `level.blk`, set the following:
- `saltSedimentsStart:r=-0.25`: Starting height for the sediment effect.
- `saltSedimentsEnd:r=4`: Ending height for the sediment effect.
- `saltSedimentsTile:r=15`: Horizontal tiling scale for the texture, in
meters.
- `saltSedimentsTex:t="waterline_grdnt_a_tex_d"`: Name of the projected
texture.
The shader also supports an optional command:
- `script:t="salt_sediments_opacity=1"`: Controls the multiplier for the
texture's alpha channel. You can use other values, but it's generally
unnecessary.