forked from teamnwah/openmw-tes3coop
52 lines
1.5 KiB
GLSL
52 lines
1.5 KiB
GLSL
#include "core.h"
|
|
|
|
#define MRT @shGlobalSettingBool(mrt_output)
|
|
|
|
#ifdef SH_VERTEX_SHADER
|
|
|
|
SH_BEGIN_PROGRAM
|
|
shUniform(float4x4, wvp) @shAutoConstant(wvp, worldviewproj_matrix)
|
|
shInput(float2, uv0)
|
|
shOutput(float2, UV)
|
|
shColourInput(float4)
|
|
shOutput(float4, colourPassthrough)
|
|
|
|
SH_START_PROGRAM
|
|
{
|
|
colourPassthrough = colour;
|
|
shOutputPosition = shMatrixMult(wvp, shInputPosition);
|
|
UV = uv0;
|
|
}
|
|
|
|
#else
|
|
|
|
SH_BEGIN_PROGRAM
|
|
shInput(float2, UV)
|
|
shInput(float4, colourPassthrough)
|
|
#if MRT
|
|
shDeclareMrtOutput(1)
|
|
#endif
|
|
|
|
shSampler2D(diffuseMap1)
|
|
shSampler2D(diffuseMap2)
|
|
|
|
shUniform(float, cloudBlendFactor) @shSharedParameter(cloudBlendFactor)
|
|
shUniform(float, cloudAnimationTimer) @shSharedParameter(cloudAnimationTimer)
|
|
shUniform(float, cloudOpacity) @shSharedParameter(cloudOpacity)
|
|
shUniform(float3, cloudColour) @shSharedParameter(cloudColour)
|
|
|
|
SH_START_PROGRAM
|
|
{
|
|
// Scroll in y direction
|
|
float2 scrolledUV = UV + float2(0,1) * cloudAnimationTimer * 0.003;
|
|
|
|
float4 albedo = shSample(diffuseMap1, scrolledUV) * (1-cloudBlendFactor) + shSample(diffuseMap2, scrolledUV) * cloudBlendFactor;
|
|
|
|
shOutputColour(0) = colourPassthrough * float4(cloudColour, 1) * albedo * float4(1,1,1, cloudOpacity);
|
|
|
|
#if MRT
|
|
shOutputColour(1) = float4(1,1,1,1);
|
|
#endif
|
|
}
|
|
|
|
#endif
|