2013-02-01 22:43:23 +00:00
|
|
|
#include "core.h"
|
|
|
|
|
2013-02-23 04:53:20 +00:00
|
|
|
#define DAMPING 0.95
|
2013-02-01 22:43:23 +00:00
|
|
|
|
|
|
|
#include "watersim_common.h"
|
|
|
|
|
|
|
|
SH_BEGIN_PROGRAM
|
|
|
|
shInput(float2, UV)
|
|
|
|
shSampler2D(heightPrevSampler)
|
|
|
|
shSampler2D(heightCurrentSampler)
|
|
|
|
shUniform(float3, previousFrameOffset) @shSharedParameter(previousFrameOffset, previousFrameOffset)
|
|
|
|
shUniform(float3, currentFrameOffset) @shSharedParameter(currentFrameOffset, currentFrameOffset)
|
|
|
|
shUniform(float4, rippleTextureSize) @shSharedParameter(rippleTextureSize, rippleTextureSize)
|
|
|
|
|
|
|
|
SH_START_PROGRAM
|
|
|
|
{
|
2013-03-16 13:36:37 +00:00
|
|
|
#if !SH_HLSL
|
2013-02-01 22:43:23 +00:00
|
|
|
const float3 offset[4] = float3[4](
|
|
|
|
float3(-1.0, 0.0, 0.25),
|
|
|
|
float3( 1.0, 0.0, 0.25),
|
|
|
|
float3( 0.0,-1.0, 0.25),
|
|
|
|
float3( 0.0, 1.0, 0.25)
|
|
|
|
);
|
2013-03-16 13:36:37 +00:00
|
|
|
#else
|
|
|
|
const float3 offset[4] = {
|
|
|
|
float3(-1.0, 0.0, 0.25),
|
|
|
|
float3( 1.0, 0.0, 0.25),
|
|
|
|
float3( 0.0,-1.0, 0.25),
|
|
|
|
float3( 0.0, 1.0, 0.25)
|
|
|
|
};
|
|
|
|
#endif
|
2013-02-01 22:43:23 +00:00
|
|
|
|
|
|
|
float fHeightPrev = DecodeHeightmap(heightPrevSampler, UV.xy + previousFrameOffset.xy + currentFrameOffset.xy);
|
|
|
|
|
|
|
|
float fNeighCurrent = 0;
|
|
|
|
for ( int i=0; i<4; i++ )
|
|
|
|
{
|
|
|
|
float2 vTexcoord = UV + currentFrameOffset.xy + offset[i].xy * rippleTextureSize.xy;
|
|
|
|
fNeighCurrent += (DecodeHeightmap(heightCurrentSampler, vTexcoord) * offset[i].z);
|
|
|
|
}
|
|
|
|
|
|
|
|
float fHeight = fNeighCurrent * 2.0 - fHeightPrev;
|
|
|
|
|
|
|
|
fHeight *= DAMPING;
|
|
|
|
|
|
|
|
shOutputColour(0) = EncodeHeightmap(fHeight);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|