70 lines
2.0 KiB
Plaintext
70 lines
2.0 KiB
Plaintext
|
//====== Copyright <20> 1996-2004, Valve Corporation, All rights reserved. =======
|
|||
|
//
|
|||
|
// Purpose:
|
|||
|
//
|
|||
|
//=============================================================================
|
|||
|
|
|||
|
// STATIC: "NORMALMAP" "0..1"
|
|||
|
// STATIC: "NOCULL" "0..1"
|
|||
|
|
|||
|
#include "common_ps_fxc.h"
|
|||
|
|
|||
|
sampler SpotSampler : register( s0 );
|
|||
|
sampler BaseTextureSampler : register( s1 );
|
|||
|
sampler NormalizingCubemapSampler : register( s2 );
|
|||
|
// use a normalizing cube map here if we aren't normal mapping
|
|||
|
#if NORMALMAP
|
|||
|
sampler NormalMapSampler : register( s3 );
|
|||
|
#else
|
|||
|
sampler NormalizingCubemapSampler2 : register( s3 );
|
|||
|
#endif
|
|||
|
|
|||
|
static const HALF g_OverbrightFactor = 2.0f;
|
|||
|
|
|||
|
struct PS_INPUT
|
|||
|
{
|
|||
|
float4 spotTexCoord : TEXCOORD0;
|
|||
|
float2 baseTexCoord : TEXCOORD1;
|
|||
|
#if NORMALMAP
|
|||
|
float3 tangentPosToLightVector : TEXCOORD2;
|
|||
|
float2 normalMapTexCoord : TEXCOORD3;
|
|||
|
#else
|
|||
|
float3 worldPosToLightVector : TEXCOORD2;
|
|||
|
float3 normal : TEXCOORD3;
|
|||
|
#endif
|
|||
|
float4 vertAtten : COLOR0;
|
|||
|
};
|
|||
|
|
|||
|
float4 main( PS_INPUT i ) : COLOR
|
|||
|
{
|
|||
|
#if NORMALMAP
|
|||
|
float3 normal = tex2D( NormalMapSampler, i.normalMapTexCoord ) * 2.0f - 1.0f;
|
|||
|
#else
|
|||
|
float3 normal = texCUBE( NormalizingCubemapSampler2, i.normal ) * 2.0f - 1.0f;
|
|||
|
#endif
|
|||
|
|
|||
|
float3 spotColor = tex2D( SpotSampler, i.spotTexCoord );
|
|||
|
float4 baseSample = tex2D( BaseTextureSampler, i.baseTexCoord );
|
|||
|
float3 baseColor = baseSample.xyz;
|
|||
|
#if NORMALMAP
|
|||
|
// wrap this!
|
|||
|
float3 tangentPosToLightVector = texCUBE( NormalizingCubemapSampler, i.tangentPosToLightVector ) * 2.0f - 1.0f;
|
|||
|
float nDotL = saturate( dot( tangentPosToLightVector, normal ) );
|
|||
|
#else
|
|||
|
float3 worldPosToLightVector = texCUBE( NormalizingCubemapSampler, i.worldPosToLightVector ) * 2.0f - 1.0f;
|
|||
|
float nDotL = saturate( dot( worldPosToLightVector, normal ) );
|
|||
|
#endif
|
|||
|
float3 outcolor;
|
|||
|
|
|||
|
outcolor = spotColor * baseColor * g_OverbrightFactor;
|
|||
|
|
|||
|
#if !NOCULL
|
|||
|
outcolor *= nDotL;
|
|||
|
#endif
|
|||
|
|
|||
|
// NOTE!! This has to be last to avoid loss of range.
|
|||
|
outcolor *= i.vertAtten;
|
|||
|
|
|||
|
return float4( outcolor.xyz, baseSample.a * i.vertAtten.a );
|
|||
|
}
|