62 lines
1.7 KiB
Plaintext
62 lines
1.7 KiB
Plaintext
|
// STATIC: "CONVERT_TO_SRGB" "0..1" [ps20b][= g_pHardwareConfig->NeedsShaderSRGBConversion()] [PC]
|
||
|
// STATIC: "CONVERT_TO_SRGB" "0..0" [= 0] [XBOX]
|
||
|
// STATIC: "VERTEXCOLOR" "0..1"
|
||
|
// STATIC: "CONSTANTCOLOR" "0..1"
|
||
|
// STATIC: "HDRTYPE" "0..2"
|
||
|
// STATIC: "SRGB" "0..1"
|
||
|
// STATIC: "SRGB_OUTPUT_ADAPTER" "0..1" [ps20b]
|
||
|
|
||
|
// DYNAMIC: "HDRENABLED" "0..1"
|
||
|
// DYNAMIC: "PIXELFOGTYPE" "0..1"
|
||
|
|
||
|
#include "common_ps_fxc.h"
|
||
|
#include "shader_constant_register_map.h"
|
||
|
|
||
|
const HALF4 g_Color : register( c0 );
|
||
|
const float g_HDRColorScale : register( c1 );
|
||
|
|
||
|
const float4 g_FogParams : register( PSREG_FOG_PARAMS );
|
||
|
const float4 g_EyePos_SpecExponent : register( PSREG_EYEPOS_SPEC_EXPONENT );
|
||
|
|
||
|
sampler TexSampler : register( s0 );
|
||
|
|
||
|
struct PS_INPUT
|
||
|
{
|
||
|
HALF2 baseTexCoord : TEXCOORD0; // Base texture coordinate
|
||
|
float4 color : TEXCOORD2; // Vertex color (from lighting or unlit)
|
||
|
|
||
|
float4 worldPos_projPosZ : TEXCOORD7; // Necessary for pixel fog
|
||
|
};
|
||
|
|
||
|
float4 main( PS_INPUT i ) : COLOR
|
||
|
{
|
||
|
float4 result, sample = tex2D( TexSampler, i.baseTexCoord );
|
||
|
|
||
|
#if VERTEXCOLOR
|
||
|
sample *= i.color;
|
||
|
#endif
|
||
|
|
||
|
#if CONSTANTCOLOR
|
||
|
sample *= g_Color;
|
||
|
#endif
|
||
|
|
||
|
#if HDRTYPE && HDRENABLED
|
||
|
sample.xyz *= g_HDRColorScale;
|
||
|
#endif
|
||
|
|
||
|
float fogFactor = CalcPixelFogFactor( PIXELFOGTYPE, g_FogParams, g_EyePos_SpecExponent.z, i.worldPos_projPosZ.z, i.worldPos_projPosZ.w );
|
||
|
#if SRGB
|
||
|
result = FinalOutput( sample, fogFactor, PIXELFOGTYPE, TONEMAP_SCALE_LINEAR );
|
||
|
#else
|
||
|
result = FinalOutput( sample, fogFactor, PIXELFOGTYPE, TONEMAP_SCALE_GAMMA );
|
||
|
#endif
|
||
|
|
||
|
// On Posix, we're being forced through a linear-to-gamma curve but don't want it, so we do the opposite here first
|
||
|
#if SRGB_OUTPUT_ADAPTER
|
||
|
result = GammaToLinear( result );
|
||
|
#endif
|
||
|
|
||
|
return result;
|
||
|
}
|
||
|
|