Updated Islands

This commit is contained in:
Josef 2025-03-27 19:31:20 +01:00
parent 271412d932
commit 068e072388
4 changed files with 151 additions and 138 deletions

File diff suppressed because one or more lines are too long

Binary file not shown.

View File

@ -44,6 +44,7 @@ uniform float normalMinDistance = 5;
uniform float normalMaxDistance = 100;
uniform float normalMinValue = 0.5;
uniform float normalMaxValue = 1;
uniform float normalPower:hint_range(0,1) = 1;
uniform float rim : hint_range(0.0, 1.0, 0.01);
uniform float rim_tint : hint_range(0.0, 1.0, 0.01);
@ -73,6 +74,7 @@ uniform vec3 uv2_offset;
varying float cameraDistanceFactor;
uniform float terrainUVScale = 1;
varying float camDist;
void vertex()
{
@ -102,11 +104,11 @@ void vertex()
vec3 worldPosition = localToWorld( VERTEX, MODEL_MATRIX );
terrainUV = heightMapUV( worldPosition, terrainSize, terrainOffset );
//vec4 heightMapData = texture( terrain, terrainUV );
float heightMapDataRaw = texture( terrain, terrainUV ).r;
float tx = texelVertexSpread / 2048.0;
vec3 camPosWorld = ( vec4( 0, 0, 0, 1 ) * INV_VIEW_MATRIX ).xyz;
float cameraDistance = length( worldPosition - CAMERA_POSITION_WORLD );
float cameraDistance = length( (worldPosition + vec3( 0.0, heightMapDataRaw, 0.0 )) - CAMERA_POSITION_WORLD );
float txCam = texelVertexSpreadCamAmount * pow( cameraDistance / texelVertexSpreadCamDistance, texelVertexSpreadCamPower );
txCam /= 2048.0;
txCam = min( txCam, 1.0/100.0 );
@ -115,8 +117,10 @@ void vertex()
worldPosition.y += heightMapData.r * terrainMaxHeight;
cameraDistanceFactor = mapClamped( cameraDistance, normalMinDistance, normalMaxDistance, normalMinValue, normalMaxValue );
camDist = cameraDistance;
float cDNormalized = normalizeToRange01( cameraDistance, normalMinDistance, normalMaxDistance );
cDNormalized = mix( cDNormalized, cDNormalized * cDNormalized * cDNormalized, normalPower );
cameraDistanceFactor = mix( normalMinValue, normalMaxValue, cDNormalized );
// (dx, dy, dz)
VERTEX.y += heightMapData.r * terrainMaxHeight;
@ -179,4 +183,5 @@ void fragment() {
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);
//ALBEDO.rgb = vec3( 0.0, 0.0, pow( camDist / 2000.0, 5) );
}

@ -1 +1 @@
Subproject commit 560668edf8d4aa94e14517409aa4969badfe4700
Subproject commit 74e78d9d8365a0b1e89f73e2c298c41ef337b545