1
0
mirror of https://gitlab.com/OpenMW/openmw.git synced 2025-01-26 18:35:20 +00:00
OpenMW/files/materials/terrain.shader

128 lines
2.9 KiB
Plaintext
Raw Normal View History

2012-07-13 06:16:55 +02:00
#include "core.h"
2012-07-13 09:13:12 +02:00
#define FOG @shGlobalSettingBool(fog)
2012-07-13 06:16:55 +02:00
#define MRT @shGlobalSettingBool(mrt_output)
2012-07-14 11:13:38 +02:00
#define COLOUR_MAP @shPropertyBool(colour_map)
2012-07-14 18:25:43 +02:00
#define NUM_LAYERS @shPropertyString(num_layers)
#define COMPONENT_0 x
#define COMPONENT_1 y
#define COMPONENT_2 z
#define COMPONENT_3 w
#define IS_FIRST_PASS 1
2012-07-13 06:16:55 +02:00
@shAllocatePassthrough(1, depth)
2012-07-14 11:13:38 +02:00
@shAllocatePassthrough(2, UV)
2012-07-13 06:16:55 +02:00
#ifdef SH_VERTEX_SHADER
SH_BEGIN_PROGRAM
shUniform(float4x4, worldMatrix) @shAutoConstant(worldMatrix, world_matrix)
shUniform(float4x4, viewProjMatrix) @shAutoConstant(viewProjMatrix, viewproj_matrix)
shInput(float2, uv0)
@shPassthroughVertexOutputs
SH_START_PROGRAM
{
float4 worldPos = shMatrixMult(worldMatrix, shInputPosition);
shOutputPosition = shMatrixMult(viewProjMatrix, worldPos);
@shPassthroughAssign(depth, shOutputPosition.z);
2012-07-14 11:13:38 +02:00
@shPassthroughAssign(UV, uv0);
2012-07-13 06:16:55 +02:00
}
#else
SH_BEGIN_PROGRAM
2012-07-14 11:13:38 +02:00
#if COLOUR_MAP
shSampler2D(colourMap)
#endif
2012-07-14 18:25:43 +02:00
shSampler2D(normalMap) // global normal map
@shForeach(@shPropertyString(num_blendmaps))
shSampler2D(blendMap@shIterator)
@shEndForeach
@shForeach(@shPropertyString(num_layers))
shSampler2D(diffuseMap@shIterator)
@shEndForeach
2012-07-14 11:13:38 +02:00
#if FOG
shUniform(float3, fogColor) @shAutoConstant(fogColor, fog_colour)
shUniform(float4, fogParams) @shAutoConstant(fogParams, fog_params)
#endif
2012-07-13 06:16:55 +02:00
@shPassthroughFragmentInputs
#if MRT
shDeclareMrtOutput(1)
2012-07-14 11:13:38 +02:00
shUniform(float, far) @shAutoConstant(far, far_clip_distance)
2012-07-13 06:16:55 +02:00
#endif
SH_START_PROGRAM
{
float depth = @shPassthroughReceive(depth);
2012-07-14 11:13:38 +02:00
float2 UV = @shPassthroughReceive(UV);
2012-07-13 09:13:12 +02:00
2012-07-14 18:25:43 +02:00
float3 normal = shSample(normalMap, UV).rgb * 2 - 1;
// fetch blendmaps
@shForeach(@shPropertyString(num_blendmaps))
float4 blendValues@shIterator = shSample(blendMap@shIterator, UV);
@shEndForeach
float3 albedo;
@shForeach(@shPropertyString(num_layers))
#if IS_FIRST_PASS == 1 && @shIterator == 0
// first layer of first pass doesn't need a blend map
2012-07-14 18:44:03 +02:00
albedo = shSample(diffuseMap0, UV * 10).rgb;
2012-07-14 18:25:43 +02:00
#else
2012-07-14 18:44:03 +02:00
#define BLEND_AMOUNT blendValues@shPropertyString(blendmap_index_@shIterator).@shPropertyString(blendmap_component_@shIterator)
2012-07-14 18:25:43 +02:00
2012-07-14 18:44:03 +02:00
albedo = shLerp(albedo, shSample(diffuseMap@shIterator, UV * 10).rgb, BLEND_AMOUNT);
2012-07-14 18:25:43 +02:00
#endif
@shEndForeach
shOutputColour(0) = float4(1,1,1,1);
2012-07-14 11:13:38 +02:00
#if COLOUR_MAP
shOutputColour(0).rgb *= shSample(colourMap, UV).rgb;
#endif
2012-07-14 18:25:43 +02:00
shOutputColour(0).rgb *= albedo;
2012-07-14 11:13:38 +02:00
#if FOG
float fogValue = shSaturate((depth - fogParams.y) * fogParams.w);
shOutputColour(0).xyz = shLerp (shOutputColour(0).xyz, fogColor, fogValue);
#endif
2012-07-13 06:16:55 +02:00
#if MRT
2012-07-14 11:13:38 +02:00
shOutputColour(1) = float4(depth / far,1,1,1);
2012-07-13 06:16:55 +02:00
#endif
}
#endif