Rasagar/Library/PackageCache/com.unity.terrain-tools/Shaders/NoiseHeightTool.shader
2024-08-26 23:07:20 +03:00

92 lines
2.6 KiB
Plaintext

Shader "Hidden/TerrainTools/NoiseHeightTool"
{
Properties { _MainTex ("Texture", any) = "" {} }
SubShader
{
ZTest Always Cull OFF ZWrite Off
HLSLINCLUDE
#include "UnityCG.cginc"
#include "Packages/com.unity.terrain-tools/Shaders/TerrainTools.hlsl"
sampler2D _MainTex;
float4 _MainTex_TexelSize; // 1/width, 1/height, width, height
float2 _WorldHeightRemap;
sampler2D _NoiseTex;
float4 _NoiseTex_TexelSize;
sampler2D _BrushTex;
float4 _BrushParams; // x = strength, y = , z = , w = brushSize
sampler2D _FilterTex;
// _BrushParams macros
#define BRUSH_STRENGTH ( _BrushParams[0] )
#define BRUSH_SIZE ( _BrushParams[2] )
#define INV_BRUSH_SIZE ( _BrushParams[3] )
struct appdata_t
{
float4 vertex : POSITION;
float2 pcUV : TEXCOORD0;
};
struct v2f
{
float4 vertex : SV_POSITION;
float2 pcUV : TEXCOORD0;
};
v2f vert( appdata_t v )
{
v2f o;
o.vertex = UnityObjectToClipPos( v.vertex );
o.pcUV = v.pcUV;
return o;
}
ENDHLSL
Pass
{
Name "Apply Noise to Heightmap"
HLSLPROGRAM
#pragma vertex vert
#pragma fragment frag
float4 frag( v2f i ) : SV_Target
{
// get current height value
float h = UnpackHeightmap( tex2D( _MainTex, i.pcUV ) );
float2 brushUV = PaintContextUVToBrushUV( i.pcUV );
// out of bounds multiplier
float oob = all( saturate( brushUV ) == brushUV ) ? 1 : 0;
// get brush mask value
float b = oob * UnpackHeightmap( tex2D( _BrushTex, brushUV ) ) * UnpackHeightmap(tex2D(_FilterTex, i.pcUV));
// need to adjust uvs due to "scaling" from brush rotation
float2 pcUVRescale = float2( length( _PCUVToBrushUVScales.xy ), length( _PCUVToBrushUVScales.zw ) );
// get noise mask value
float2 noiseUV = ( i.pcUV - ( .5 ).xx ) * pcUVRescale + ( .5 ).xx + ( .5 ).xx * _NoiseTex_TexelSize.xy;
float n = UnpackHeightmap( tex2D( _NoiseTex, noiseUV ) );
// TODO(wyatt): remap noise values to match _WorldHeightRemap
return PackHeightmap( clamp( h + BRUSH_STRENGTH * b * n, 0, 0.5 ) );
}
ENDHLSL
}
}
}