This article's documentation is for anything that uses the Source engine. Click here for more information.

$phong: Difference between revisions

From Valve Developer Community
Jump to navigation Jump to search
(Added additional parameter $PhongExponentFactor)
No edit summary
 
(105 intermediate revisions by 36 users not shown)
Line 1: Line 1:
{{LanguageBar}}
{{this is a|shader parameter|name=$phong|since=Source 2006|shader=VertexLitGeneric}}
[[File:Alyx phong closeup.jpg|thumb|200px|Phong shading provides Alyx's skin, hairband and lip highlights.]]
[[File:Alyx phong closeup.jpg|thumb|200px|Phong shading provides Alyx's skin, hairband and lip highlights.]]
It is also available on the {{code|[[LightmappedGeneric]]}} and {{code|[[WorldVertexTransition]]}} shaders in all games since {{csgo|4}}{{also|{{gmod}}{{mapbase}}}}. It provides {{w|diffuse reflection|icon=hide|diffuse reflections}} at low intensity and {{w|specular highlight|icon=hide|specular highlights}} at apex intensity, masked by a texture which control per-texel its intensity. For a full explanation, see [[Phong materials]].


The '''<code>$phong</code>''' [[VMT]] command provides diffuse reflections. In most engine branches it is only available with <code>[[VertexLitGeneric]]</code>; {{csgo}} '''[[Counter-Strike: Global Offensive]]''' (as of early 2015) allows it to a limited extent on <code>[[LightmappedGeneric]]</code>. For a full explanation, see [[Phong materials]].
==Syntax==
 
==VMT syntax==


  $phong <[[bool]]>
  $phong <[[bool]]>


The Phong shader ''should'' use the default values for any configuration parameters that you omit from your material. However it appears that this doesn't happen. Therefore all of the below parameters are required, even if they stay on their default values.
{{note|All parameters in the following example must be specified in the material, otherwise Phong shading won't show up at all, except in {{insurgency|4}}.}}
 
:{{todo|Other games that don't require all phong parameters present (likely Portal 2 and up)}}
<syntaxhighlight lang=php>
<syntaxhighlight>
VertexLitGeneric
VertexLitGeneric
{
{
Line 23: Line 24:


== Parameters ==
== Parameters ==
=== Masking ===
=== Masking ===
 
{{warning|There are some caveats regarding {{ent|$normalmapalphaenvmapmask}} and [[Glowing_Textures#.24selfillum|$selfillumfresnel]] when using {{ent|$phong}}!}}
; <code>$bumpmap <[[texture]]></code>
* Using [[Glowing_Textures#.24selfillum|$selfillumfresnel]] '''without''' {{ent|$normalmapalphaenvmapmask}} will mask the {{ent|$envmap}} using the {{ent|$basetexture}}'s alpha channel.
: There must be a [[$bumpmap|bump map]]. Its [[alpha channel]] acts as a Phong mask by default.
* Using [[Glowing_Textures#.24selfillum|$selfillumfresnel]] '''with''' {{ent|$normalmapalphaenvmapmask}} will multiply the {{ent|$envmap}} by <code>0.0f</code>. Effectively disabling the effect!
; {{L4D add|<code>$BasemapLuminancePhongMask <[[bool]]></code>}}
* When '''not''' using [[Glowing_Textures#.24selfillum|$selfillumfresnel]]. The mask used for {{ent|$envmap}} will be the {{ent|$basetexture}}'s alpha channel '''unless''' {{ent|$normalmapalphaenvmapmask}} is also used.
: Phong intensity is based on the brightness of <code>$basetexture</code>.
* '''If''' {{ent|$normalmapalphaenvmapmask}} is used, the {{ent|$bumpmap}}'s alpha channel will be used for Phong masking. Using either <code>$basemapalphaphongmask</code> or <code>$basemapluminancephongmask</code> will override it.
;<code>$BasemapAlphaPhongMask <bool></code>
<br>
: Reads the Phong mask from <code>[[$basetexture]]</code>'s [[alpha channel]] instead of <code>$bumpmap</code>'s. The phong will not be influenced by the bumpmap, however.
{{MatParamDef|$bumpmap|texture|Phong requires mask. The [[alpha channel]] of a [[$bumpmap|bump map]] acts as a Phong mask by default.}}
; <code>$PhongExponent <[[int]]></code>
{{MatParamDef|$basemapalphaphongmask|bool|Use {{ent|$basetexture}}'s [[alpha channel]] as the Phong mask instead of <code>$bumpmap</code>'s [[alpha channel]].
: The numeric value overrides an exponent mask if present.
{{warning|Using this with {{ent|$normalmapalphaenvmapmask}} will override the mask used for {{ent|$envmap}} to be the contents of the {{ent|$basetexture}}'s alpha channel!}}
; <code>$PhongExponentTexture <texture></code>  
{{warning|{{gmod|4}} Using this with {{ent|$normalmapalphaenvmapmask}} and {{ent|$envmap}} renders in {{ent|$envmap}} and '''<code>$phong</code>''' be masked by both '''<code>$basemapalphaphongmask</code>''' alpha channel and {{ent|$normalmapalphaenvmapmask}} alpha channel.}} |since={{src07}}|shaders=VertexLitGeneric}}
: A global [[Phong materials#Phong mask and exponent texture|exponent]] value, or a per-texel exponent texture map. In an exponent map:
{{MatParamDef|$basemapluminancephongmask|bool|Mask phong intensity based on the brightness of the <code>$basetexture</code>.
:* '''Red channel:''' Exponent (size of highlight, 0-255, where a value of 0 is a large highlight, 255 small.)
{{bug|Basetexture Luminance will replace the mask used for {{ent|$envmap}}, '''if''' {{ent|$normalmapalphaenvmapmask}} is used.}}
:* '''Green channel:''' Albedo tint (if <code>$phongalbedotint 1</code>, higher is more tint)
{{bug|Doesn't work in {{gmod|4}}.}}
:* '''Blue channel:''' Nothing
|not={{gmod}}|since={{l4d}}|shaders=VertexLitGeneric}}
:* '''Alpha channel:''' <code>[[$rimlight]]</code> mask
{{MatParamDef|$phongexponent|and=$phongexponent2|int|A global [[Phong materials#Phong mask and exponent texture|exponent]] value. Overrides an exponent mask if present.
; <code>$PhongExponentFactor<[[int]]><code>
: <code>$phongexponent2</code> is for <code>WorldVertexTransition</code>'s second material in {{csgobranch|4}}.}}
: This number will be used to multiply the exponent texture.
{{MatParamDef|$phongexponenttexture|texture|A per-texel exponent map. In an exponent map:
; {{L4D add|<code>$shinyblood <[[int]]></code>}}
:* '''Red channel:''' Exponent mask (size of highlight, 0-255, where a value of 0 is a large highlight, 255 small.)
; {{L4D add|<code>$shinybloodexponent <int></code>}}
:* '''Green channel:''' Albedo tint mask (only if <code>$phongalbedotint 1</code>, 0-255, where a value of 0 is no tint, 255 full tint.)
: {{todo|1=See ''[http://www.valvesoftware.com/publications/2010/GDC10_ShaderTechniquesL4D2.pdf#page=33 Shading a Bigger, Better Sequel: Techniques in Left 4 Dead 2]''.}}
:* '''Blue channel:''' Nothing.
; <code>$allowdiffusemodulation <int></code>
:* '''Alpha channel:''' {{ent|$rimlight}} mask (only if '''<code>$rimmask 1</code>'''.)
: {{todo}}
:{{Note|<code>LightmappedGeneric</code> and <code>WorldVertexTransition</code> do not have support for <code>$phongexponenttexture</code>. You must use <code>$phongexponent</code> instead.}}|shaders=VertexLitGeneric}}
; <code>$DiffuseExp</code>
{{MatParamDef|$phongexponentfactor|float|Multiply the exponent from the <code>$phongexponenttexture</code> by this amount. {{tip| The default value of this parameter is <code>"0.0"</code>. However, a more reasonable default value would be <code>"149.0"</code>}}|only={{src13mp}}{{tf2}}|shaders=VertexLitGeneric}}
: {{todo|Does this have something to do with the ''$phongexponent'', ''$phongexponenttexture or both?}}
{{MatParamDef|$invertphongmask|bool|Invert the value of the phong mask.
{{bug|In {{as}}s and {{src13}}s Shadercode, using this parameter will invert the mask used for {{ent|$envmap}}, not the one used for <code>$phong</code>! }}
{{confirm| Is this the case for all branches?}}
|since={{src07}}|shaders=VertexLitGeneric}}
{{MatParamDef|$forcephong|bool|Force phong shading on phong-using materials even at low GPU levels when <code>mat_phong</code> is disabled.|since={{portal2}}|shaders=VertexLitGeneric}}
{{MatParamDef|$diffuseexp|float|Diffuse exponent used for dynamic lights only.
{{note|have this with {{ent|$halflambert}} greatly decrease it effect.}}|only={{L4ds}}|shaders=VertexLitGeneric, Infected}}
{{MatParamDef|$shinyblood|int|Derive phong mask from areas that are more red than others. Only when variation is disabled.|only={{L4ds}}|shaders=VertexLitGeneric, Infected}}
{{MatParamDef|$shinybloodexponent|int|Exponent for the above.|only={{L4ds}}|shaders=VertexLitGeneric, Infected}}


=== Brightness ===
=== Brightness ===
{{MatParamDef|$phongboost|float|Phong brightness factor. Larger values create a more intense highlight, useful for surfaces like metal and glass.{{tip|A phong boost of zero is visually identical to no phong, and can be used to work around certain shader parameter combinations that require phong (ex [[$lightwarptexture]]).}}|shaders=VertexLitGeneric, LightmappedGeneric({{mapbase|only}})}}
{{MatParamDef|$phongfresnelranges|matrix|See [[Phong materials#Phong Fresnel ranges|Phong Fresnel ranges]]. Default is <code>"[0 0.5 1]"</code>.
:{{note|<code>$envmap</code> is also affected by these fresnel ranges if both it and Phong are enabled in a material.}}
:{{note| drives the x component of a phongwarptexture if specified.}}|shaders=VertexLitGeneric, LightmappedGeneric({{mapbase|only}})}}
{{MatParamDef|$phongdisablehalflambert|bool|Disables forced [[$halflambert|half-lambertian]] shading on Phong materials. {{note|This parameter is effectively forced on in {{csgobranch|4}} due to <code>$halflambert</code> being disabled.}}<!--
-->{{tip|In games without this command, the effect can be simulated by using the {{cmd|$lightwarptexture}} found [[:File:Phongdisablehalflambert_warp.png|here]].}}|since={{as}}|also={{gmod}},{{Mapbase}}|shaders=VertexLitGeneric}}


; <code>$phongboost <[[int]]></code>
=== Colors ===
: Phong brightness factor. Larger values create a more intense highlight, useful for surfaces like metal and glass.
{{MatParamDef|$phongalbedotint|bool|Tints the phong reflection by the color of the <code>$basetexture</code>. The amount of tint is defined by the green channel of <code>$phongexponenttexture</code>. A <code>$phongexponenttexture</code> must be specified in order for <code>$phongalbedotint</code> to work.
; <code>$PhongFresnelRanges <matrix></code>
: {{Warning|<code>$phongalbedotint</code> cannot be used with <code>$phongtint</code>. The latter will disable the effect.}}
: See [[Phong materials#Phong Fresnel ranges|Phong Fresnel ranges]]. Default is <code>"[0 0.5 1]"</code>.
: {{Note|<code>$phongalbedotint</code> works by multiplying the <code>$basetexture</code> over the reflection, without darkening the albedo. The reflection will get dimmer as a result, so account for this in the phong mask or with <code>$phongboost</code>.}}
; <code>$PhongDisableHalfLambert <bool></code> {{P2 add}}
: {{Note|<code>$phongalbedotint</code> will tint highlights by the original color of the <code>$basetexture</code> even when the material is tinted by <code>$color2</code> or <code>rendercolor.</code>}}|since={{src07}}|shaders=VertexLitGeneric}}
: Used in [[Portal 2]] on the Personality Cores such as Wheatley, disables functionality of $halflambert. MAY need <code>$halflambert 0</code>!
[[File:Albedotint example.jpg|thumb|200px|An example model showing how AlbedoTint appears on a model.]]
;<code>$AmbientOcclusionTexture <texture></code>
{{MatParamDef|$phongalbedoboost|float|Phong albedo overbrightening factor. Ranges 0-255.
: A "dirtmap". Mentioned in the SDK samples and seen in the VMT for Alyx's face. [[$ambientocclusion|Ambient Occlusion]] is generally used for the eyes and face.
: {{note| This will multiply the tint that is being applied to phong from $phongalbedotint.}}
 
: {{bug| This does not work when using [[$detail]]. }}|since={{csgo}}|also={{gmod}}|shaders=VertexLitGeneric}}
=== Colours ===
[[File:Phongwarp example.png|thumb|200px|The Hunter without and with its <code>$phongwarptexture</code>, showing how it affects the Phong reflection.]]
 
{{MatParamDef|$phongtint|RGB matrix|Color tint of the phong reflection.
; <code>$PhongAlbedoTint <bool></code>
: {{Warning|This will override <code>$phongalbedotint</code> if both are used.}}
: Allows the <code>[[$basetexture]]</code> to affect the colour of the Phong highlight. The amount of tint is defined by the green channel of <code>$phongexponenttexture</code> (see above).
: {{note| Also tints {{ent|$rimlight}}}}|since={{src07}}|shaders=VertexLitGeneric}}
; <code>$phongtint "[<red [[float]]> <green float> <blue float>]"</code>
[[File:Phongwarp_coordinate_guide.png|thumb|200px|Breakdown of the $phongwarptexture: computed coordinates, texture and result]]
: Modifies the colour of the phong reflection. The channels are interpreted relative to each other (so "[0 0 0]" and "[1 1 1]" are the same).
{{MatParamDef|$phongwarptexture|texture|Used to create an iridescence effect, as seen on Episode Two's [[npc_hunter|Hunters]].
; <code>$PhongWarpTexture <texture></code> {{EP2 add}}
: The highlight is multiplied with a texture. The coordinates of the sampled pixel are as follows:
: {{todo|Used to create an iridescence effect, as seen on [[npc_hunter]]s.}}
:x: 1 - (distance to the center of the highlight)
 
:y: 1 - (fresnel component as computed by [[Phong materials#Phong Fresnel ranges|Phong Fresnel ranges]])
== Phong shading on brush faces ==
: {{note|Disables the initial phongfresnelranges masking}}
: {{bug|Does not work in {{l4d2|4}}.}}|since={{src07}}|shaders=VertexLitGeneric}}
[[File:Brush_phong.jpg|thumb|200px|Brush phong in {{csgo|2}} using tile/hr_t/inferno/tile_a. Note the complete absence of the reflection in the shaded area.]]


A May 2015 update to {{csgo}} '''[[Counter-Strike: Global Offensive]]''' added limited support for Phong-based highlights on <code>[[LightmappedGeneric]]</code> materials. Currently it only works when the material is directly lit by an env_cascade_lighting, using the dynamic shadows as a mask (although traditional Phong masking is supported on top of this). It is known to work on displacements as well as <code>[[WorldVertexTransition]]</code> materials, but not water or <code>[[Lightmapped_4WayBlend]]</code>.
===Brush Shader Parameters ===
:{{csgobranch|only}}{{also|{{gmod}}}}
{{MatParamDef|$phongmaskcontrastbrightness|and=$phongmaskcontrastbrightness2|vector2|The first value controls the contrast level between light and dark areas in the mask, and the second value controls the overall brightness.
: <code>$phongmaskcontrastbrightness2</code> is for <code>WorldVertexTransition</code>'s second material.
: {{todo|Find out the range of both values.}}|shaders=LightmappedGeneric, WorldVertexTransition}}
{{MatParamDef|$phongamount|and=$phongamount2|vector4|The first 3 values control the color tint, and the fourth value controls the brightness. The fourth value can go beyond 1, but affects the brightness of the whole texture, not just the highlight.  
: <code>$phongamount2</code> is for <code>WorldVertexTransition</code>'s second material.|shaders=LightmappedGeneric, WorldVertexTransition}}
{{MatParamDef|$phongbasetint|and=$phongbasetint2|float|Allows the <code>$basetexture</code> and/or <code>$basetexture2</code> to tint the color of the Phong highlight.|shaders=LightmappedGeneric, WorldVertexTransition}}


=== New Parameters ===
== Console Commands ==
{{varcom|start}}
{{varcom|mat_phong|1|bool|Disable or enable phong shading. {{bug|Doesn't work in {{csgo|4}} branch.|tested={{p2ce}}}}}}
{{varcom|end}}


; <code>$phongMaskContrastBrightness "[<float> <float>]"</code>
== Notes ==
: Defines the contrast level between light and dark areas in the mask, and the overall brightness, respectively. Added along with support for phong-shaded lightmapped textures. {{todo|Find out the range of both values, and whether or not it can be used on models.}}
{{Note|Phong shading for <code>LightmappedGeneric</code> and <code>WorldVertexTransition</code> is only available in {{csgobranch}}{{strata}}. It requires the material to be lit by the sunlight from a {{ent|env_cascade_light}} entity to work properly and uses the dynamic shadows generated by it as a mask on top of the traditional phong masking. ({{Strata|since}} {{ent|env_projectedtexture}} also affects brushes with phong enabled)
; <code>$phongAmount "[<red float> <green float> <blue float> <brightness> float]"</code>
{{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.}}}}
: Controls the tint and brightness. The fourth value can go beyond 1, but affects the brightness of the whole texture, not just the highlight.
{{Note|Phong shading for <code>LightmappedGeneric</code> is also available in {{mapbase|4}}, but it is implemented differently.}}
{{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.}}
{{tip|Use [[$specmap_mode|new specular]] shader in {{bms|4}} as an alternative of phong on brushes.}}


== See also ==
== See also ==
* [[Phong materials]]
* [[Phong materials]]
* [[$envmap]] (environment map)
* {{ent|$envmap}} (environment map)
* [[$lightwarptexture]]
* {{ent|$lightwarptexture}}
* [[$rimlight]]
* {{ent|$rimlight}}


[[Category:List of Shader Parameters|P]]
== External links ==
[[Category:VMT Lighting]]
* {{YouTube|tLCUE25KEmM|page=watch|A comprehensive YouTube video on how phong materials work in Source}}
* [https://tf2maps.net/threads/phong-on-brushes-the-hacky-way.26765 $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 [[prop_static|static props]] which are lit per-vertex, without falling back to lower-quality point lighting on the main prop
*[https://share.substance3d.com/libraries/6595 SubstancePainter Source Engine Complex Phong Shader]
[[Category:Shader parameters|p]][[Category:VMT Lighting]]
[[Category:Material System]]

Latest revision as of 11:40, 23 August 2025

English (en)Español (es)Русский (ru)中文 (zh)Translate (Translate)

$phong is a material shader parameter for the VertexLitGeneric shader available in all Source Source games since Source 2006 Source 2006.

Phong shading provides Alyx's skin, hairband and lip highlights.

It is also available on the LightmappedGeneric and WorldVertexTransition shaders in all games since Counter-Strike: Global Offensive Counter-Strike: Global Offensive(also in Garry's ModMapbase). It provides Wikipedia icon diffuse reflections at low intensity and Wikipedia icon specular highlights at apex intensity, masked by a texture which control per-texel its intensity. For a full explanation, see Phong materials.

Syntax

$phong <bool>
Note.pngNote:All parameters in the following example must be specified in the material, otherwise Phong shading won't show up at all, except in Insurgency Insurgency.
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

Warning.pngWarning:There are some caveats regarding $normalmapalphaenvmapmask and $selfillumfresnel when using $phong!


Phong requires mask. The alpha channel of a bump map acts as a Phong mask by default.
$basemapalphaphongmask <boolean> (in all games since Source 2007)
Shader(s): VertexLitGeneric
Use $basetexture's alpha channel as the Phong mask instead of $bumpmap's alpha channel.
Warning.pngWarning:Using this with $normalmapalphaenvmapmask will override the mask used for $envmap to be the contents of the $basetexture's alpha channel!
Warning.pngWarning:Garry's Mod Garry's Mod Using this with $normalmapalphaenvmapmask and $envmap renders in $envmap and $phong be masked by both $basemapalphaphongmask alpha channel and $normalmapalphaenvmapmask alpha channel.
Shader(s): VertexLitGeneric
Mask phong intensity based on the brightness of the $basetexture.
Icon-Bug.pngBug:Basetexture Luminance will replace the mask used for $envmap, if $normalmapalphaenvmapmask is used.  [todo tested in ?]
Icon-Bug.pngBug:Doesn't work in Garry's Mod Garry's Mod.  [todo tested in ?]
A global exponent value. Overrides an exponent mask if present.
$phongexponent2 is for WorldVertexTransition's second material in CS:GO engine branch CS:GO engine branch.
Shader(s): VertexLitGeneric
A per-texel exponent map. In an exponent map:
  • Red channel: Exponent mask (size of highlight, 0-255, where a value of 0 is a large highlight, 255 small.)
  • Green channel: Albedo tint mask (only if $phongalbedotint 1, 0-255, where a value of 0 is no tint, 255 full tint.)
  • Blue channel: Nothing.
  • Alpha channel: $rimlight mask (only if $rimmask 1.)
Note.pngNote:LightmappedGeneric and WorldVertexTransition do not have support for $phongexponenttexture. You must use $phongexponent instead.
$phongexponentfactor <float> (only in Source 2013 MultiplayerTeam Fortress 2)
Shader(s): VertexLitGeneric
Multiply the exponent from the $phongexponenttexture by this amount.
Tip.pngTip: The default value of this parameter is "0.0". However, a more reasonable default value would be "149.0"
$invertphongmask <boolean> (in all games since Source 2007)
Shader(s): VertexLitGeneric
Invert the value of the phong mask.
Icon-Bug.pngBug:In Alien Swarms and Source 2013s Shadercode, using this parameter will invert the mask used for $envmap, not the one used for $phong!   [todo tested in ?]
Confirm: Is this the case for all branches?
$forcephong <boolean> (in all games since Portal 2)
Shader(s): VertexLitGeneric
Force phong shading on phong-using materials even at low GPU levels when mat_phong is disabled.
$diffuseexp <float> (only in Left 4 Dead seriesLeft 4 Dead series)
Shader(s): VertexLitGeneric, Infected
Diffuse exponent used for dynamic lights only.
Note.pngNote:have this with $halflambert greatly decrease it effect.
$shinyblood <integer> (only in Left 4 Dead seriesLeft 4 Dead series)
Shader(s): VertexLitGeneric, Infected
Derive phong mask from areas that are more red than others. Only when variation is disabled.
Shader(s): VertexLitGeneric, Infected
Exponent for the above.

Brightness

Shader(s): VertexLitGeneric, LightmappedGeneric((only in Mapbase))
Phong brightness factor. Larger values create a more intense highlight, useful for surfaces like metal and glass.
Tip.pngTip:A phong boost of zero is visually identical to no phong, and can be used to work around certain shader parameter combinations that require phong (ex $lightwarptexture).
Shader(s): VertexLitGeneric, LightmappedGeneric((only in Mapbase))
See Phong Fresnel ranges. Default is "[0 0.5 1]".
Note.pngNote:$envmap is also affected by these fresnel ranges if both it and Phong are enabled in a material.
Note.pngNote: drives the x component of a phongwarptexture if specified.
$phongdisablehalflambert <boolean> (in all games since Alien Swarm) (also in Garry's Mod,Mapbase)
Shader(s): VertexLitGeneric
Disables forced half-lambertian shading on Phong materials.
Note.pngNote:This parameter is effectively forced on in CS:GO engine branch CS:GO engine branch due to $halflambert being disabled.
Tip.pngTip:In games without this command, the effect can be simulated by using the $lightwarptexture found here.

Colors

$phongalbedotint <boolean> (in all games since Source 2007)
Shader(s): VertexLitGeneric
Tints the phong reflection by the color of the $basetexture. The amount of tint is defined by the green channel of $phongexponenttexture. A $phongexponenttexture must be specified in order for $phongalbedotint to work.
Warning.pngWarning:$phongalbedotint cannot be used with $phongtint. The latter will disable the effect.
Note.pngNote:$phongalbedotint works by multiplying the $basetexture over the reflection, without darkening the albedo. The reflection will get dimmer as a result, so account for this in the phong mask or with $phongboost.
Note.pngNote:$phongalbedotint will tint highlights by the original color of the $basetexture even when the material is tinted by $color2 or rendercolor.
An example model showing how AlbedoTint appears on a model.
$phongalbedoboost <float> (in all games since Counter-Strike: Global Offensive) (also in Garry's Mod)
Shader(s): VertexLitGeneric
Phong albedo overbrightening factor. Ranges 0-255.
Note.pngNote: This will multiply the tint that is being applied to phong from $phongalbedotint.
Icon-Bug.pngBug: This does not work when using $detail.   [todo tested in ?]
The Hunter without and with its $phongwarptexture, showing how it affects the Phong reflection.
$phongtint <RGB matrix> (in all games since Source 2007)
Shader(s): VertexLitGeneric
Color tint of the phong reflection.
Warning.pngWarning:This will override $phongalbedotint if both are used.
Note.pngNote: Also tints $rimlight
Breakdown of the $phongwarptexture: computed coordinates, texture and result
$phongwarptexture <texture> (in all games since Source 2007)
Shader(s): VertexLitGeneric
Used to create an iridescence effect, as seen on Episode Two's Hunters.
The highlight is multiplied with a texture. The coordinates of the sampled pixel are as follows:
x: 1 - (distance to the center of the highlight)
y: 1 - (fresnel component as computed by Phong Fresnel ranges)
Note.pngNote:Disables the initial phongfresnelranges masking
Icon-Bug.pngBug:Does not work in Left 4 Dead 2 Left 4 Dead 2.  [todo tested in ?]
Brush phong in Counter-Strike: Global Offensive Counter-Strike: Global Offensive using tile/hr_t/inferno/tile_a. Note the complete absence of the reflection in the shaded area.

Brush Shader Parameters

(only in CS:GO engine branch)(also in Garry's Mod)
Shader(s): LightmappedGeneric, WorldVertexTransition
The first value controls the contrast level between light and dark areas in the mask, and the second value controls the overall brightness.
$phongmaskcontrastbrightness2 is for WorldVertexTransition's second material.
Todo: Find out the range of both values.
Shader(s): LightmappedGeneric, WorldVertexTransition
The first 3 values control the color tint, and the fourth value controls the brightness. The fourth value can go beyond 1, but affects the brightness of the whole texture, not just the highlight.
$phongamount2 is for WorldVertexTransition's second material.
Shader(s): LightmappedGeneric, WorldVertexTransition
Allows the $basetexture and/or $basetexture2 to tint the color of the Phong highlight.

Console Commands

Cvar/Command Parameters or default value Descriptor Effect
mat_phong 1 bool Disable or enable phong shading.
Icon-Bug.pngBug:Doesn't work in Counter-Strike: Global Offensive Counter-Strike: Global Offensive branch.  (tested in: Portal 2: Community Edition)

Notes

Note.pngNote:Phong shading for LightmappedGeneric and WorldVertexTransition is only available in CS:GO engine branchStrata Source. It requires the material to be lit by the sunlight from a env_cascade_light entity to work properly and uses the dynamic shadows generated by it as a mask on top of the traditional phong masking. ((in all games since Strata Source) env_projectedtexture also affects brushes with phong enabled)
Icon-Bug.pngBug:Garry's Mod Garry's Mod reads lighting direction for brush phong from env_sun instead; maps with multiple suns may not get accurate phong reflections on brushes.
Note.pngNote:Phong shading for LightmappedGeneric is also available in Mapbase Mapbase, but it is implemented differently.
Icon-Important.pngImportant:In all Source Engine games since Source 2007 Source 2007 (until Counter-Strike: Global Offensive) enabling this shader will also enable $halflambert automatically (including gbuffer's halflambert in Black Mesa), unless $phongdisablehalflambert(in all games since Alien Swarm) is used. This effect isn't physically accurate, so it should be disabled if possible in most cases.
Icon-Bug.pngBug:Phong reflection vectors are broken on static props with vertex lighting.  (tested in: Black Mesa,Counter-Strike: Global Offensive)
Tip.pngTip:Use new specular shader in Black Mesa Black Mesa as an alternative of phong on brushes.

See also

External links