source-engine/materialsystem/stdshaders/lightmappedgeneric_ps11.fxc

123 lines
3.2 KiB
Plaintext
Raw Normal View History

2020-04-22 16:56:21 +00:00
// 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
}