Team Fortress 2 Source Code as on 22/4/2020
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
|
|
// STATIC: "BASETEXTURE" "0..1" // STATIC: "ENVMAP" "0..1" // STATIC: "ENVMAPMASK" "0..1" // STATIC: "SELFILLUM" "0..1" // STATIC: "BASEALPHAENVMAPMASK" "0..1"
// SKIP: !$ENVMAP && ( $BASEALPHAENVMAPMASK || $ENVMAPMASK ) // SKIP: !$BASETEXTURE && $BASEALPHAENVMAPMASK // SKIP: $BASEALPHAENVMAPMASK && $ENVMAPMASK // SKIP: !$BASETEXTURE && $BASEALPHAENVMAPMASK // SKIP: $SELFILLUM && $BASEALPHAENVMAPMASK // SKIP: !$BASETEXTURE && $SELFILLUM
const float3 g_OverbrightFactor : register( c0 ); const float3 g_SelfIllumTint : register( c1 ); const float3 g_EnvmapTint : register( c2 );
sampler BaseTextureSampler : register( s0 ); sampler LightmapSampler : register( s1 ); sampler EnvmapSampler : register( s2 ); sampler EnvmapMaskSampler : register( s3 );
//sampler DetailSampler : register( s3 );
struct PS_INPUT { float2 baseTexCoord : TEXCOORD0; float2 lightmapTexCoord : TEXCOORD1; float3 envmapTexCoord : TEXCOORD2; float2 envmapMaskTexCoord : TEXCOORD3; float4 vertexColor : COLOR0; };
float4 main( PS_INPUT i ) : COLOR { bool bBaseTexture = BASETEXTURE ? true : false; bool bEnvmap = ENVMAP ? true : false; bool bEnvmapMask = ENVMAPMASK ? true : false; bool bSelfIllum = SELFILLUM ? true : false; bool bBaseAlphaEnvmapMask = BASEALPHAENVMAPMASK ? true : false;
#if 1 float4 baseColor = float4( 1.0f, 1.0f, 1.0f, 1.0f ); if( bBaseTexture ) { baseColor = tex2D( BaseTextureSampler, i.baseTexCoord ); }
float3 specularFactor = 1.0f; if( bEnvmapMask ) { specularFactor *= tex2D( EnvmapMaskSampler, i.envmapMaskTexCoord ).xyz; } if( bBaseAlphaEnvmapMask ) { specularFactor *= 1.0 - baseColor.a; // this blows! }
float3 diffuseLighting = tex2D( LightmapSampler, i.lightmapTexCoord );
float3 albedo = float3( 1.0f, 1.0f, 1.0f ); float alpha = 1.0f; if( bBaseTexture ) { albedo *= baseColor; if( !bBaseAlphaEnvmapMask && !bSelfIllum ) { alpha *= baseColor.a; } }
// The vertex color contains the modulation color + vertex color combined albedo *= i.vertexColor; alpha *= i.vertexColor.a; // not sure about this one
float3 diffuseComponent = ( albedo * diffuseLighting * 2.0f ) * g_OverbrightFactor;
if( bSelfIllum ) { float3 selfIllumComponent = g_SelfIllumTint * albedo; diffuseComponent = lerp( diffuseComponent, selfIllumComponent, baseColor.a ); }
float3 specularLighting = float3( 0.0f, 0.0f, 0.0f );
if( bEnvmap ) { specularLighting = tex2D( EnvmapSampler, i.envmapTexCoord ); specularLighting *= specularFactor; specularLighting *= g_EnvmapTint; }
float3 result = diffuseComponent + specularLighting; return float4( result, alpha ); #endif
#if 0 float4 baseColor = float4( 1.0f, 1.0f, 1.0f, 1.0f ); float3 diffuseLighting = tex2D( LightmapSampler, i.lightmapTexCoord );
float3 albedo = float3( 1.0f, 1.0f, 1.0f ); float alpha = 1.0f; albedo *= i.vertexColor; alpha *= i.vertexColor.a; // not sure about this one
float3 diffuseComponent = ( albedo * diffuseLighting * 2.0f ) * g_OverbrightFactor; float3 result = diffuseComponent; return float4( result, alpha ); #endif
#if 0 float4 result;
result.rgb = tex2D( LightmapSampler, i.lightmapTexCoord ).rgb * i.vertexColor.rgb; result.a = i.vertexColor.a; result.rgb = ( result.rgb * g_OverbrightFactor ) * 2.0f; return result; #endif }
|