浏览代码

renaming

/feature-infinite-sea
Andre McGrail 5 年前
当前提交
01a887f2
共有 4 个文件被更改,包括 86 次插入86 次删除
  1. 74
      Assets/scenes/Testing/InfiniteWater.unity
  2. 6
      Packages/com.verasl.water-system/Shaders/InfiniteWater.shader
  3. 90
      Packages/com.verasl.water-system/Shaders/WaterCommon.hlsl
  4. 2
      Packages/com.verasl.water-system/Shaders/WaterInput.hlsl

74
Assets/scenes/Testing/InfiniteWater.unity


m_AmbientIntensity: 1
m_AmbientMode: 0
m_SubtractiveShadowColor: {r: 0.42, g: 0.478, b: 0.627, a: 1}
m_SkyboxMaterial: {fileID: 0}
m_SkyboxMaterial: {fileID: 2100000, guid: e14f29569c2db49fdb0a5fd5b3e95b86, type: 2}
m_HaloStrength: 0.5
m_FlareStrength: 1
m_FlareFadeSpeed: 3

m_ReflectionIntensity: 1
m_CustomReflection: {fileID: 8900000, guid: 6e8b646e70b4e410daa65a80eedd3182, type: 3}
m_Sun: {fileID: 0}
m_IndirectSpecularColor: {r: 0, g: 0, b: 0, a: 1}
m_IndirectSpecularColor: {r: 0.18028545, g: 0.22571565, b: 0.30692434, a: 1}
m_UseRadianceAmbientProbe: 0
--- !u!157 &3
LightmapSettings:

m_PrefabAsset: {fileID: 0}
m_GameObject: {fileID: 341762015}
m_Mesh: {fileID: 10207, guid: 0000000000000000e000000000000000, type: 0}
--- !u!84 &486698662
RenderTexture:
m_ObjectHideFlags: 0
m_CorrespondingSourceObject: {fileID: 0}
m_PrefabInstance: {fileID: 0}
m_PrefabAsset: {fileID: 0}
m_Name: WaterDepthMap
m_ImageContentsHash:
serializedVersion: 2
Hash: 00000000000000000000000000000000
m_ForcedFallbackFormat: 4
m_DownscaleFallback: 0
serializedVersion: 3
m_Width: 1024
m_Height: 1024
m_AntiAliasing: 1
m_MipCount: -1
m_DepthFormat: 2
m_ColorFormat: 142
m_MipMap: 0
m_GenerateMips: 1
m_SRGB: 0
m_UseDynamicScale: 0
m_BindMS: 0
m_EnableCompatibleFormat: 1
m_TextureSettings:
serializedVersion: 2
m_FilterMode: 1
m_Aniso: 1
m_MipBias: 0
m_WrapU: 1
m_WrapV: 1
m_WrapW: 1
m_Dimension: 2
m_VolumeDepth: 1
--- !u!1 &537372327
GameObject:
m_ObjectHideFlags: 0

m_PrefabAsset: {fileID: 0}
m_GameObject: {fileID: 611616626}
m_Mesh: {fileID: 10207, guid: 0000000000000000e000000000000000, type: 0}
--- !u!84 &734942345
RenderTexture:
m_ObjectHideFlags: 0
m_CorrespondingSourceObject: {fileID: 0}
m_PrefabInstance: {fileID: 0}
m_PrefabAsset: {fileID: 0}
m_Name: WaterDepthMap
m_ImageContentsHash:
serializedVersion: 2
Hash: 00000000000000000000000000000000
m_ForcedFallbackFormat: 4
m_DownscaleFallback: 0
serializedVersion: 3
m_Width: 1024
m_Height: 1024
m_AntiAliasing: 1
m_MipCount: -1
m_DepthFormat: 2
m_ColorFormat: 142
m_MipMap: 0
m_GenerateMips: 1
m_SRGB: 0
m_UseDynamicScale: 0
m_BindMS: 0
m_EnableCompatibleFormat: 1
m_TextureSettings:
serializedVersion: 2
m_FilterMode: 1
m_Aniso: 1
m_MipBias: 0
m_WrapU: 1
m_WrapV: 1
m_WrapW: 1
m_Dimension: 2
m_VolumeDepth: 1
--- !u!1 &867751506
GameObject:
m_ObjectHideFlags: 0

6
Packages/com.verasl.water-system/Shaders/InfiniteWater.shader


output.screenPosition = ComputeScreenPos(vertexInput.positionCS);
output.viewDir.xyz = UNITY_MATRIX_IT_MV[2].xyz;
output.viewDir.w = length(viewPos / viewPos.z);
output.viewDirectionWS.xyz = UNITY_MATRIX_IT_MV[2].xyz;
output.viewDirectionWS.w = length(viewPos / viewPos.z);
return output;
}

half4 waterFX = SAMPLE_TEXTURE2D(_WaterFXMap, sampler_ScreenTextures_linear_clamp, screenUV.xy);
InfinitePlane plane = WorldPlane(i.screenPosition, i.viewDir);
InfinitePlane plane = WorldPlane(i.screenPosition, i.viewDirectionWS);
float3 normal = half3(0.0, 1.0, 0.0);
half3 viewDirectionWS = normalize(GetCameraPositionWS() - plane.positionWS);
float4 additionalData = float4(1, length(viewDirectionWS), waterFX.w, 1);

90
Packages/com.verasl.water-system/Shaders/WaterCommon.hlsl


struct Varyings // fragment struct
{
float4 uv : TEXCOORD0; // Geometric UVs stored in xy, and world(pre-waves) in zw
float3 posWS : TEXCOORD1; // world position of the vertices
half3 normal : NORMAL; // vert normals
float4 viewDir : TEXCOORD2; // view direction
float3 positionWS : TEXCOORD1; // world position of the vertices
half3 normalWS : NORMAL; // vert normals
float4 viewDirectionWS : TEXCOORD2; // view direction
float3 preWaveSP : TEXCOORD3; // screen position of the verticies before wave distortion
half2 fogFactorNoise : TEXCOORD4; // x: fogFactor, y: noise
float4 additionalData : TEXCOORD5; // x = distance to surface, y = distance to surface, z = normalized wave height, w = horizontal movement

return float2(d * additionalData.x - additionalData.y, (rawD * -_ProjectionParams.x) + (1-UNITY_REVERSED_Z));
}
float WaterTextureDepth(float3 posWS)
float WaterTextureDepth(float3 positionWS)
return (1 - SAMPLE_TEXTURE2D_LOD(_WaterDepthMap, sampler_WaterDepthMap_linear_clamp, posWS.xz * 0.002 + 0.5, 1).r) * (_MaxDepth + _VeraslWater_DepthCamParams.x) - _VeraslWater_DepthCamParams.x;
return (1 - SAMPLE_TEXTURE2D_LOD(_WaterDepthMap, sampler_WaterDepthMap_linear_clamp, positionWS.xz * 0.002 + 0.5, 1).r) * (_MaxDepth + _VeraslWater_DepthCamParams.x) - _VeraslWater_DepthCamParams.x;
float3 WaterDepth(float3 posWS, half4 additionalData, half2 screenUVs)// x = seafloor depth, y = water depth
float3 WaterDepth(float3 positionWS, half4 additionalData, half2 screenUVs)// x = seafloor depth, y = water depth
float wd = WaterTextureDepth(posWS);
outDepth.y = wd + posWS.y;
float wd = WaterTextureDepth(positionWS);
outDepth.y = wd + positionWS.y;
return outDepth;
}

return output;
}
void DetailNormals(inout float3 normals, float4 uvs, float4 waterFX, float depth)
void DetailNormals(inout float3 normalWS, float4 uvs, float4 waterFX, float depth)
{
half2 detailBump1 = SAMPLE_TEXTURE2D(_SurfaceMap, sampler_SurfaceMap, uvs.zw).xy * 2 - 1;
half2 detailBump2 = SAMPLE_TEXTURE2D(_SurfaceMap, sampler_SurfaceMap, uvs.xy).xy * 2 - 1;

half3 normal2 = half3(1-waterFX.y, 0.5h, 1-waterFX.z) - 0.5;
normals = normalize(normals + normal1 + normal2);
normalWS = normalize(normalWS + normal1 + normal2);
input.normal = float3(0, 1, 0);
input.fogFactorNoise.y = ((noise((input.posWS.xz * 0.5) + WATER_TIME) + noise((input.posWS.xz * 1) + WATER_TIME)) * 0.25 - 0.5) + 1;
input.normalWS = float3(0, 1, 0);
input.fogFactorNoise.y = ((noise((input.positionWS.xz * 0.5) + WATER_TIME) + noise((input.positionWS.xz * 1) + WATER_TIME)) * 0.25 - 0.5) + 1;
input.uv = DetailUVs(input.posWS, input.fogFactorNoise.y);
input.uv = DetailUVs(input.positionWS, input.fogFactorNoise.y);
half4 screenUV = ComputeScreenPos(TransformWorldToHClip(input.posWS));
half4 screenUV = ComputeScreenPos(TransformWorldToHClip(input.positionWS));
half waterDepth = WaterTextureDepth(input.posWS);
input.posWS.y += pow(saturate((-waterDepth + 1.5) * 0.4), 2);
half waterDepth = WaterTextureDepth(input.positionWS);
input.positionWS.y += pow(saturate((-waterDepth + 1.5) * 0.4), 2);
SampleWaves(input.posWS, saturate((waterDepth * 0.1 + 0.05)), wave);
input.normal = wave.normal;
input.posWS += wave.position;
SampleWaves(input.positionWS, saturate((waterDepth * 0.1 + 0.05)), wave);
input.normalWS = wave.normal;
input.positionWS += wave.position;
input.posWS.y -= 0.5;
input.positionWS.y -= 0.5;
input.posWS.y += waterFX.w * 2 - 1;
input.positionWS.y += waterFX.w * 2 - 1;
input.clipPos = TransformWorldToHClip(input.posWS);
input.clipPos = TransformWorldToHClip(input.positionWS);
input.viewDir.xyz = SafeNormalize(_WorldSpaceCameraPos - input.posWS);
input.viewDirectionWS.xyz = SafeNormalize(_WorldSpaceCameraPos - input.positionWS);
// Fog
input.fogFactorNoise.x = ComputeFogFactor(input.clipPos.z);

input.additionalData = AdditionalData(input.posWS, wave);
input.additionalData = AdditionalData(input.positionWS, wave);
half distanceBlend = saturate(abs(length((_WorldSpaceCameraPos.xz - input.posWS.xz) * 0.005)) - 0.25);
input.normal = lerp(input.normal, half3(0, 1, 0), distanceBlend);
half distanceBlend = saturate(abs(length((_WorldSpaceCameraPos.xz - input.positionWS.xz) * 0.005)) - 0.25);
input.normalWS = lerp(input.normalWS, half3(0, 1, 0), distanceBlend);
return input;
}

inputData.positionWS = input.posWS;
inputData.positionWS = input.positionWS;
inputData.normalWS = input.normal;
inputData.normalWS = input.normalWS;
inputData.viewDirectionWS = input.viewDir;
inputData.viewDirectionWS = input.viewDirectionWS;
inputData.reflectionUV = 0;

{
surfaceData.absorption = 0;
surfaceData.scattering = 0;
surfaceData.normal = 0;
surfaceData.normalWS = 0;
/*
// Foam
half3 foamMap = SAMPLE_TEXTURE2D(_FoamMap, sampler_FoamMap, IN.uv.zw).rgb; //r=thick, g=medium, b=light

UNITY_INITIALIZE_VERTEX_OUTPUT_STEREO(o);
o.uv.xy = v.texcoord; // geo uvs
o.posWS = TransformObjectToWorld(v.positionOS.xyz);
o.positionWS = TransformObjectToWorld(v.positionOS.xyz);
o = WaveVertexOperations(o);
return o;

half4 waterFX = SAMPLE_TEXTURE2D(_WaterFXMap, sampler_ScreenTextures_linear_clamp, IN.preWaveSP.xy);
// Depth
float3 depth = WaterDepth(IN.posWS, IN.additionalData, screenUV.xy);// TODO - hardcoded shore depth UVs
float3 depth = WaterDepth(IN.positionWS, IN.additionalData, screenUV.xy);// TODO - hardcoded shore depth UVs
DetailNormals(IN.normal, IN.uv, waterFX, depth.x);
DetailNormals(IN.normalWS, IN.uv, waterFX, depth.x);
Light mainLight = GetMainLight(TransformWorldToShadowCoord(IN.posWS));
half shadow = SoftShadows(screenUV.xy, IN.posWS);
half3 GI = SampleSH(IN.normal);
Light mainLight = GetMainLight(TransformWorldToShadowCoord(IN.positionWS));
half shadow = SoftShadows(screenUV.xy, IN.positionWS);
half3 GI = SampleSH(IN.normalWS);
directLighting += saturate(pow(dot(IN.viewDir.xyz, -mainLight.direction) * IN.additionalData.z, 3)) * 5 * mainLight.color;
directLighting += saturate(pow(dot(IN.viewDirectionWS.xyz, -mainLight.direction) * IN.additionalData.z, 3)) * 5 * mainLight.color;
half3 sss = directLighting * shadow + GI;
// Foam

half3 foam = foamMask.xxx * (mainLight.shadowAttenuation * mainLight.color + GI);
// Distortion
half2 distortion = DistortionUVs(depth.x, IN.normal);
half2 distortion = DistortionUVs(depth.x, IN.normalWS);
distortion = screenUV.xy + distortion;// * clamp(depth.x, 0, 5);
float d = depth.x;
depth.xz = AdjustedDepth(distortion, IN.additionalData); // only x y

// Fresnel
half fresnelTerm = CalculateFresnelTerm(IN.normal, IN.viewDir.xyz);
half fresnelTerm = CalculateFresnelTerm(IN.normalWS, IN.viewDirectionWS.xyz);
half3 spec = DirectBDRF(brdfData, IN.normal, mainLight.direction, IN.viewDir.xyz) * shadow * mainLight.color;
half3 spec = DirectBDRF(brdfData, IN.normalWS, mainLight.direction, IN.viewDirectionWS.xyz) * shadow * mainLight.color;
Light light = GetAdditionalLight(lightIndex, IN.posWS);
spec += LightingPhysicallyBased(brdfData, light, IN.normal, IN.viewDir);
Light light = GetAdditionalLight(lightIndex, IN.positionWS);
spec += LightingPhysicallyBased(brdfData, light, IN.normalWS, IN.viewDirectionWS.xyz);
sss += light.distanceAttenuation * light.color;
}
#endif

// Reflections
half3 reflection = SampleReflections(IN.normal, IN.viewDir.xyz, screenUV.xy, 0.0);
half3 reflection = SampleReflections(IN.normalWS, IN.viewDirectionWS.xyz, screenUV.xy, 0.0);
// Refraction
half3 refraction = Refraction(distortion, depth.x);

comp = MixFog(comp, fogFactor);
// alpha
float alpha = 1 - saturate((distance(IN.posWS, GetCameraPositionWS()) - 30) * 0.1);
float alpha = 1 - saturate((distance(IN.positionWS, GetCameraPositionWS()) - 30) * 0.1);
#if defined(_DEBUG_FOAM)
return half4(foamMask.xxx, 1);

#elif defined(_DEBUG_REFLECTION)
return half4(reflection, 1);
#elif defined(_DEBUG_NORMAL)
return half4(IN.normal.x * 0.5 + 0.5, 0, IN.normal.z * 0.5 + 0.5, 1);
return half4(IN.normalWS.x * 0.5 + 0.5, 0, IN.normalWS.z * 0.5 + 0.5, 1);
#elif defined(_DEBUG_FRESNEL)
return half4(fresnelTerm.xxx, 1);
#elif defined(_DEBUG_WATEREFFECTS)

2
Packages/com.verasl.water-system/Shaders/WaterInput.hlsl


{
half3 absorption;
half3 scattering;
half3 normal;
half3 normalWS;
half foam;
half foamMask;
};

正在加载...
取消
保存