openmw-tes3coop/files/materials/clouds.shader

53 lines
1.5 KiB
Text
Raw Normal View History

2012-07-06 08:31:48 +00:00
#include "core.h"
2012-07-11 07:08:55 +00:00
#define MRT @shGlobalSettingBool(mrt_output)
2012-07-06 08:31:48 +00:00
#ifdef SH_VERTEX_SHADER
SH_BEGIN_PROGRAM
2012-07-11 07:08:55 +00:00
shUniform(float4x4, wvp) @shAutoConstant(wvp, worldviewproj_matrix)
2012-07-06 08:31:48 +00:00
shInput(float2, uv0)
shOutput(float2, UV)
2012-07-11 00:31:03 +00:00
shColourInput(float4)
shOutput(float4, colourPassthrough)
2012-07-06 08:31:48 +00:00
SH_START_PROGRAM
{
2012-07-11 07:08:55 +00:00
colourPassthrough = colour;
2012-07-06 08:31:48 +00:00
shOutputPosition = shMatrixMult(wvp, shInputPosition);
UV = uv0;
}
#else
SH_BEGIN_PROGRAM
shInput(float2, UV)
2012-07-11 07:08:55 +00:00
shInput(float4, colourPassthrough)
2012-07-06 08:31:48 +00:00
#if MRT
shDeclareMrtOutput(1)
#endif
2012-07-11 07:08:55 +00:00
shSampler2D(diffuseMap1)
shSampler2D(diffuseMap2)
shUniform(float, cloudBlendFactor) @shSharedParameter(cloudBlendFactor)
shUniform(float, cloudAnimationTimer) @shSharedParameter(cloudAnimationTimer)
shUniform(float, cloudOpacity) @shSharedParameter(cloudOpacity)
shUniform(float3, cloudColour) @shSharedParameter(cloudColour)
2012-07-06 08:31:48 +00:00
SH_START_PROGRAM
{
2012-07-11 07:08:55 +00:00
// 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);
2012-07-20 15:08:15 +00:00
2012-07-06 08:31:48 +00:00
#if MRT
2012-07-11 00:31:03 +00:00
shOutputColour(1) = float4(1,1,1,1);
2012-07-06 08:31:48 +00:00
#endif
}
#endif