$phong: Difference between revisions
No edit summary Tag: Reverted  | 
				m (Fix typo) Tag: Reverted  | 
				||
| Line 6: | Line 6: | ||
{{bug|hidetested=1|{{gmod|4}} reads lighting direction for brush phong from {{ent|env_sun}} instead; maps with multiple suns may not get accurate phong reflections on brushes.}}}}  | {{bug|hidetested=1|{{gmod|4}} reads lighting direction for brush phong from {{ent|env_sun}} instead; maps with multiple suns may not get accurate phong reflections on brushes.}}}}  | ||
{{Note|Phong shading for <code>LightmappedGeneric</code> is also available in {{mapbase|4}}, but it is implemented differently.}}  | {{Note|Phong shading for <code>LightmappedGeneric</code> is also available in {{mapbase|4}}, but it is implemented differently.}}  | ||
{{Note|Phong on brushes can only receive lighting from   | {{Note|Phong on brushes can only receive lighting from Dynamic Lights ([[Naming Lights|Named Light]], [[env_projectedtexture|Projected Texture]]), as Source doesn't store information of lighting direction for Static Lighting}}  | ||
{{important|In all [[Source Engine]] games since {{src07|4}} (until {{csgo}}) enabling this shader will also enable [[$halflambert]] automatically (including [[$halflambert_gbuffer_off|gbuffer's halflambert]] in {{bms|1}}), unless {{cmd|$phongdisablehalflambert}}{{since|{{as}}}} is used. This effect isn't physically accurate, so it should be disabled if possible in most cases.}}  | {{important|In all [[Source Engine]] games since {{src07|4}} (until {{csgo}}) enabling this shader will also enable [[$halflambert]] automatically (including [[$halflambert_gbuffer_off|gbuffer's halflambert]] in {{bms|1}}), unless {{cmd|$phongdisablehalflambert}}{{since|{{as}}}} is used. This effect isn't physically accurate, so it should be disabled if possible in most cases.}}  | ||
{{bug|tested={{bms}},{{csgo}}|Phong reflection vectors are broken on [[prop_static|static props]] with vertex lighting.}}  | {{bug|tested={{bms}},{{csgo}}|Phong reflection vectors are broken on [[prop_static|static props]] with vertex lighting.}}  | ||
Revision as of 05:25, 2 June 2025
$phong  is a   material shader parameter for the VertexLitGeneric shader available in all 
 Source games since 
 Source 2006. 
It is also available on the LightmappedGeneric and WorldVertexTransition shaders in all games since 
 Counter-Strike: Global Offensive(also in ![]()
). It provides 
 diffuse reflections at low intensity and 
 specular highlights at apex intensity, masked by a texture which control per-texel its intensity. For a full explanation, see Phong materials.
LightmappedGeneric and WorldVertexTransition is only available in LightmappedGeneric is also available in $phongdisablehalflambert(in all games since Syntax
$phong <bool>
- Todo: Other games that don't require all phong parameters present (likely Portal 2 and up)
 
VertexLitGeneric
{
	$phong 1
	$bumpmap				[texture]
	$phongexponent			5			// either/or
	$phongexponenttexture	[texture]	// either/or
	$phongboost				1.0
	$phongfresnelranges		"[0 0.5 1]"
}Parameters
Masking
- Using $selfillumfresnel without $normalmapalphaenvmapmask will mask the $envmap using the $basetexture's alpha channel.
 - Using $selfillumfresnel with $normalmapalphaenvmapmask will multiply the $envmap by 
0.0f. Effectively disabling the effect! - When not using $selfillumfresnel. The mask used for $envmap will be the $basetexture's alpha channel unless $normalmapalphaenvmapmask is also used.
 - If $normalmapalphaenvmapmask is used, the $bumpmap's alpha channel will be used for Phong masking. Using either 
$basemapalphaphongmaskor$basemapluminancephongmaskwill override it. 
$bumpmap
$basemapalphaphongmask
$basemapluminancephongmask
$phongexponent
$phongexponenttexture
$phongexponentfactor
$invertphongmask
$forcephong
$diffuseexp
$shinyblood
$shinybloodexponent
Brightness
$phongboost
$phongfresnelranges
$phongdisablehalflambert
Colors
Brush Shader Parameters
$phongmaskcontrastbrightness
$phongamount
$phongbasetint
Console Commands
| Cvar/Command | Parameters or default value | Descriptor | Effect | 
|---|---|---|---|
| mat_phong | 1 | bool | Disable or enable phong shading.  | 
	
See also
- Phong materials
 - $envmap (environment map)
 - $lightwarptexture
 - $rimlight
 
External links
- $Phong on brushes*: The Hacky Way - A TF2maps.net guide on how to fake $Phong on brushes for games prior to CS:GO. Can also be used to fake phong on static props which are lit per-vertex, without falling back to lower-quality point lighting on the main prop
 - SubstancePainter Source Engine Complex Phong Shader