rokojori-action-library-exa.../Packed/Island/TerrainShader.gdshader

183 lines
7.8 KiB
Plaintext

// NOTE: Shader automatically converted from Godot Engine 4.4.stable.mono's StandardMaterial3D.
shader_type spatial;
render_mode blend_mix, depth_draw_opaque, cull_back, diffuse_burley, specular_schlick_ggx;
#include "res://addons/rokojori_action_library/Runtime/Shading/Library/Math.gdshaderinc"
#include "res://addons/rokojori_action_library/Runtime/Shading/Library/Transform.gdshaderinc"
#include "res://addons/rokojori_action_library/Runtime/Shading/Library/Noise.gdshaderinc"
#include "res://addons/rokojori_action_library/Runtime/Shading/Library/Light.gdshaderinc"
#include "res://addons/rokojori_action_library/Runtime/Shading/Library/Textures.gdshaderinc"
uniform vec4 albedo : source_color;
uniform sampler2D texture_albedo : source_color, filter_linear_mipmap, repeat_enable;
uniform ivec2 albedo_texture_size;
uniform float point_size : hint_range(0.1, 128.0, 0.1);
uniform sampler2D terrain : filter_linear_mipmap, repeat_enable;
uniform sampler2D terrainNormal : filter_linear_mipmap, repeat_enable;
uniform float terrainNormalScaling: hint_range(0.5,10);
uniform vec3 terrainSize;
uniform vec3 terrainOffset;
uniform float terrainMaxHeight = 500;
varying vec2 terrainUV;
uniform float texel = 1;
uniform float texelSpread = 2;
uniform float texelVertexSpread = 2;
uniform float texelVertexSpreadCamDistance = 2000;
uniform float texelVertexSpreadCamPower = 1;
uniform float texelVertexSpreadCamAmount = 1;
uniform float texelVertexSpreadWeight = 1;
uniform float texelNormalScale = 100;
uniform float roughness : hint_range(0.0, 1.0);
uniform sampler2D texture_metallic : hint_default_white, filter_linear_mipmap, repeat_enable;
uniform vec4 metallic_texture_channel;
uniform sampler2D texture_roughness : hint_roughness_r, filter_linear_mipmap, repeat_enable;
uniform float specular : hint_range(0.0, 1.0, 0.01);
uniform float metallic : hint_range(0.0, 1.0, 0.01);
uniform sampler2D texture_normal : hint_roughness_normal, filter_linear_mipmap, repeat_enable;
uniform float normal_scale : hint_range(-16.0, 16.0);
uniform float normalMinDistance = 5;
uniform float normalMaxDistance = 100;
uniform float normalMinValue = 0.5;
uniform float normalMaxValue = 1;
uniform float rim : hint_range(0.0, 1.0, 0.01);
uniform float rim_tint : hint_range(0.0, 1.0, 0.01);
uniform sampler2D texture_rim : hint_default_white, filter_linear_mipmap, repeat_enable;
uniform sampler2D texture_detail_albedo : source_color, filter_linear_mipmap, repeat_enable;
uniform sampler2D texture_detail_normal : hint_normal, filter_linear_mipmap, repeat_enable;
uniform sampler2D texture_detail_mask : hint_default_white, filter_linear_mipmap, repeat_enable;
uniform sampler2D texture_heightmap : hint_default_black, filter_linear_mipmap, repeat_enable;
uniform float heightmap_scale : hint_range(-16.0, 16.0, 0.001);
uniform int heightmap_min_layers : hint_range(1, 64);
uniform int heightmap_max_layers : hint_range(1, 64);
uniform vec2 heightmap_flip;
varying vec3 uv1_triplanar_pos;
varying vec3 uv2_triplanar_pos;
uniform float uv1_blend_sharpness : hint_range(0.0, 150.0, 0.001);
varying vec3 uv1_power_normal;
uniform float uv2_blend_sharpness : hint_range(0.0, 150.0, 0.001);
varying vec3 uv2_power_normal;
uniform vec3 uv1_scale;
uniform vec3 uv1_offset;
uniform vec3 uv2_scale;
uniform vec3 uv2_offset;
varying float cameraDistanceFactor;
uniform float terrainUVScale = 1;
void vertex()
{
vec3 normal = NORMAL;
TANGENT = vec3(0.0, 0.0, -1.0) * abs(normal.x);
TANGENT += vec3(1.0, 0.0, 0.0) * abs(normal.y);
TANGENT += vec3(1.0, 0.0, 0.0) * abs(normal.z);
TANGENT = normalize(TANGENT);
BINORMAL = vec3(0.0, 1.0, 0.0) * abs(normal.x);
BINORMAL += vec3(0.0, 0.0, -1.0) * abs(normal.y);
BINORMAL += vec3(0.0, 1.0, 0.0) * abs(normal.z);
BINORMAL = normalize(BINORMAL);
// UV1 Triplanar: Enabled
uv1_power_normal = pow(abs(NORMAL), vec3(uv1_blend_sharpness));
uv1_triplanar_pos = VERTEX * uv1_scale + uv1_offset;
uv1_power_normal /= dot(uv1_power_normal, vec3(1.0));
uv1_triplanar_pos *= vec3(1.0, -1.0, 1.0);
// UV2 Triplanar: Enabled (with World Triplanar)
uv2_power_normal = pow(abs(mat3(MODEL_MATRIX) * NORMAL), vec3(uv2_blend_sharpness));
uv2_triplanar_pos = (MODEL_MATRIX * vec4(VERTEX, 1.0)).xyz * uv2_scale + uv2_offset;
uv2_power_normal /= dot(uv2_power_normal, vec3(1.0));
uv2_triplanar_pos *= vec3(1.0, -1.0, 1.0);
vec3 worldPosition = localToWorld( VERTEX, MODEL_MATRIX );
terrainUV = heightMapUV( worldPosition, terrainSize, terrainOffset );
//vec4 heightMapData = texture( terrain, terrainUV );
float tx = texelVertexSpread / 2048.0;
vec3 camPosWorld = ( vec4( 0, 0, 0, 1 ) * INV_VIEW_MATRIX ).xyz;
float cameraDistance = length( worldPosition - CAMERA_POSITION_WORLD );
float txCam = texelVertexSpreadCamAmount * pow( cameraDistance / texelVertexSpreadCamDistance, texelVertexSpreadCamPower );
txCam /= 2048.0;
txCam = min( txCam, 1.0/100.0 );
vec4 heightMapData = fromHeightMapSmoothed( terrain, terrainUV, vec2( tx + txCam ), texelVertexSpreadWeight );
UV = terrainUV * terrainUVScale;
worldPosition.y += heightMapData.r * terrainMaxHeight;
cameraDistanceFactor = mapClamped( cameraDistance, normalMinDistance, normalMaxDistance, normalMinValue, normalMaxValue );
// (dx, dy, dz)
VERTEX.y += heightMapData.r * terrainMaxHeight;
}
vec4 triplanar_texture(sampler2D p_sampler, vec3 p_weights, vec3 p_triplanar_pos) {
vec4 samp = vec4(0.0);
samp += texture(p_sampler, p_triplanar_pos.xy) * p_weights.z;
samp += texture(p_sampler, p_triplanar_pos.xz) * p_weights.y;
samp += texture(p_sampler, p_triplanar_pos.zy * vec2(-1.0, 1.0)) * p_weights.x;
return samp;
}
void fragment() {
vec2 base_uv2 = UV2;
vec4 albedo_tex = triplanar_texture(texture_albedo, uv1_power_normal, uv1_triplanar_pos);
ALBEDO = albedo.rgb * albedo_tex.rgb;
float metallic_tex = dot(triplanar_texture(texture_metallic, uv1_power_normal, uv1_triplanar_pos), metallic_texture_channel);
METALLIC = metallic_tex * metallic;
SPECULAR = specular;
vec4 roughness_texture_channel = vec4(1.0, 0.0, 0.0, 0.0);
float roughness_tex = dot(triplanar_texture(texture_roughness, uv1_power_normal, uv1_triplanar_pos), roughness_texture_channel);
ROUGHNESS = roughness_tex * roughness;
float tx = texel / 2048.0;
// Sample heights at neighboring pixels
float hL = texture(terrain, terrainUV - vec2(tx, 0)).r * texelNormalScale;
float hR = texture(terrain, terrainUV + vec2(tx, 0)).r * texelNormalScale;
float hD = texture(terrain, terrainUV - vec2(0, tx)).r * texelNormalScale;
float hU = texture(terrain, terrainUV + vec2(0, tx)).r * texelNormalScale;
// Compute gradient
//NORMAL = normalize( texture( terrainNormal, terrainUV ).rgb - vec3( 0.5, 0.5, 0.5 ) );
//NORMAL = normalize(vec3(hL - hR, hD - hU, 2.0));
vec3 worldNormal = heightMapNormalSmoothed( terrain, terrainUV, vec2(tx,tx), texelNormalScale, texelSpread );
NORMAL = worldToViewDirection( worldNormal, VIEW_MATRIX );
NORMAL_MAP = texture( texture_normal, UV ).rgb;
// Normal Map: Enabled
//NORMAL_MAP = normalize( texture( terrainNormal, terrainUV ).rgb * vec3( 1, terrainNormalScaling, 1 ) );
NORMAL_MAP_DEPTH = normal_scale * cameraDistanceFactor;
// Rim: Enabled
/*
vec2 rim_tex = triplanar_texture(texture_rim, uv1_power_normal, uv1_triplanar_pos).xy;
RIM = rim * rim_tex.x;
RIM_TINT = rim_tint * rim_tex.y;
*/
// Detail: Enabled
vec4 detail_tex = triplanar_texture(texture_detail_albedo, uv2_power_normal, uv2_triplanar_pos);
vec4 detail_norm_tex = triplanar_texture(texture_detail_normal, uv2_power_normal, uv2_triplanar_pos);
vec4 detail_mask_tex = triplanar_texture(texture_detail_mask, uv1_power_normal, uv1_triplanar_pos);
// Detail Blend Mode: Mix
vec3 detail = mix(ALBEDO.rgb, detail_tex.rgb, detail_tex.a);
vec3 detail_norm = mix(NORMAL_MAP, detail_norm_tex.rgb, detail_tex.a);
//NORMAL_MAP = mix(NORMAL_MAP, detail_norm, detail_mask_tex.r);
ALBEDO.rgb = mix(ALBEDO.rgb, detail, detail_mask_tex.r);
}