70 lines
2.0 KiB
Plaintext
Raw Normal View History

2020-04-22 12:56:21 -04:00
//====== 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 );
}