List of material proxies: Difference between revisions

From Valve Developer Community
Jump to navigation Jump to search
No edit summary
 
(47 intermediate revisions by 14 users not shown)
Line 1: Line 1:
<!-- {{Page Help|wikilink=Material Proxies}} unfortunately nobody notices this... and this is only used in three VDC pages?? -->
 
{{lang|List Of Material Proxies}}
{{LanguageBar}}
All [[Material Proxies]] usable in [[Material|materials]] at all {{src13}} games can be found here, along with proxies only present in specific games. (Mostly other Valve titles)<br>
{{Main|Material proxies}}
{{todo|There are still lots of undocumented proxies / proxies lacking enough documentation!}}
 
All material proxies usable in [[Material|materials]] at all {{src13}} games can be found here, along with proxies only present in specific games. (Mostly other Valve titles)<br>
{{todo|There are still lots of undocumented proxies / proxies lacking enough documentation! <!-- such as? -->}}
{{important|Unlike material variables, material proxy names are case sensitive.}}


== Calculation ==
== Calculation ==
{{note|Operations involving integers of all these proxies will be converted to a float result value, except for <code>Equals</code> and <code>Clamp</code>.}}
{{MatProxyCell|title=Add|desc=Adds two variables.|arguments=
{{MatProxyCell|title=Add|desc=Adds two variables.|arguments=
; <code>srcVar1</code>
; <code>srcVar1</code>
; <code>srcVar2</code>
; <code>srcVar2</code>
; <code>resultVar</code>
; <code>resultVar</code>
: Returns <code>srcVar1 + srcVar2</code>.
}}
}}
{{MatProxyCell|title=Multiply|desc=Multiplies two variables.|arguments=
{{MatProxyCell|title=Multiply|desc=Multiplies two variables.|arguments=
Line 14: Line 20:
; <code>srcVar2</code>
; <code>srcVar2</code>
; <code>resultVar</code>
; <code>resultVar</code>
: Returns <code>srcVar1 * srcVar2</code>.
}}
}}
{{MatProxyCell|title=Subtract|desc=Subtracts the second variable from the first.|arguments=
{{MatProxyCell|title=Subtract|desc=Subtracts the second variable from the first.|arguments=
Line 19: Line 26:
; <code>srcVar2</code>
; <code>srcVar2</code>
; <code>resultVar</code>
; <code>resultVar</code>
: Returns <code>srcVar1 - srcVar2</code>.
}}
}}
{{MatProxyCell|title=Divide|desc=Divides the first variable by the second.|arguments=
{{MatProxyCell|title=Divide|desc=Divides the first variable by the second.|arguments=
Line 24: Line 32:
; <code>srcVar2</code>
; <code>srcVar2</code>
; <code>resultVar</code>
; <code>resultVar</code>
: Returns <code>srcVar1 / srcVar2</code>.
}}
}}
{{MatProxyCell|title=Equals|desc=Copies the value of a variable to another.|arguments=
{{MatProxyCell|title=Equals|desc=Copies the value of a variable to another.|arguments=
; <code>srcVar1</code>
; <code>srcVar1</code>
; <code>resultVar</code>
; <code>resultVar</code>
: Returns <code>srcVar1</code>.
}}
}}
{{MatProxyCell|title=Abs|desc=Computes the absolute (i.e. [[unsigned]]) value of a variable.|arguments=
{{MatProxyCell|title=Abs|desc=Computes the absolute (i.e. [[unsigned]]) value of a variable.|arguments=
; <code>srcVar1</code>
; <code>srcVar1</code>
; <code>resultVar</code>
; <code>resultVar</code>
: Returns <code>abs(srcVar1)</code>.
}}
}}
{{MatProxyCell|title=Frac|desc=Returns the fractional component of a variable.'' {{tip|frac(4.23) <nowiki>=</nowiki> .23}} For integer values, no change occurs.|arguments=
{{MatProxyCell|title=Frac|desc=Returns the fractional component of a variable. For integer values, no change occurs. {{tip|frac(4.23) {{=}} .23}}|arguments=
; <code>srcVar1</code>
; <code>srcVar1</code>
; <code>resultVar</code>
; <code>resultVar</code>
}}
}}
{{MatProxyCell|title=Int|desc=Returns the integer component of a variable.'' {{tip|int(4.23) <nowiki>=</nowiki> 4}}|arguments=
{{MatProxyCell|title=Int|desc=Returns the integer component of a variable.'' {{tip|int(4.23) {{=}} 4}}|arguments=
; <code>srcVar1</code>
; <code>srcVar1</code>
; <code>resultVar</code>
; <code>resultVar</code>
}}
}}
{{MatProxyCell|title=Clamp|desc=Keeps a variable within a specified range.|arguments=
{{MatProxyCell|title=Clamp|desc=Keeps a variable within a specified range. <code>srcVar1</code> and <code>resultVar</code> can be the same.|arguments=
; <code>min</code>
; <code>min</code>
; <code>max</code>
; <code>max</code>
; <code>srcVar1</code>
; <code>srcVar1</code>
; <code>resultVar</code>
; <code>resultVar</code>
: srcVar1 and resultVar can be the same.
: Returns the value in the range <code>[min, max]</code> that is the closest to <code>srcVar1</code>.
}}
}}
{{MatProxyCell|title=LessOrEqual|desc=Compares the first value to the second.|arguments=
{{MatProxyCell|title=LessOrEqual|desc=Compares the first value to the second.|arguments=
; <code>lessEqualVar</code>
; <code>lessEqualVar</code>
: If <code>srcVar1 <= srcVar2</code> then the value of this variable is copied into <code>resultVar</code>
; <code>greaterVar</code>
; <code>greaterVar</code>
: If <code>srcVar1 > srcVar2</code> then the value of this variable is copied into <code>resultVar</code>
; <code>srcVar1</code>
; <code>srcVar1</code>
; <code>srcVar2</code>
; <code>srcVar2</code>
; <code>resultVar</code>
; <code>resultVar</code>
: If <code>srcVar1 &le; srcVar2</code>, returns <code>lessEqualVar</code>, otherwise <code>greaterVar</code>.
}}
}}
{{MatProxyCell|title=SelectFirstIfNonZero|desc=Selects the first value over the second if it is anything other than zero.|arguments=
{{MatProxyCell|title=SelectFirstIfNonZero|desc=Selects the first value over the second if it is anything other than zero.|arguments=
Line 61: Line 71:
; <code>srcVar2</code>
; <code>srcVar2</code>
; <code>resultVar</code>
; <code>resultVar</code>
: If <code>srcVar1 {{=}}{{=}} 0</code>, returns <code>srcVar1</code>, otherwise <code>srcVar2</code>.
}}
}}
{{MatProxyCell|title=WrapMinMax|desc=Constrains a value into a range, wrapping around if it exceeds it.|arguments=
{{MatProxyCell|title=WrapMinMax|desc=Constrains a value into a range, wrapping around if it exceeds it.|arguments=
Line 79: Line 90:
; <code>scale</code>
; <code>scale</code>
; <code>resultVar</code>
; <code>resultVar</code>
: resultVar <nowiki>=</nowiki> scale * exp( srcVar1 + offset ) {{tip|1=exp(n) = e<sup>n</sup>}}
: Returns <code>scale * exp( srcVar1 + offset )</code> {{tip|1=exp(n) = e<sup>n</sup>}}
}}
}}


== Number generation ==
== Number generation ==
{{MatProxyCell|title=Sine|desc=A [[w:sine wave|sine wave]].|arguments=
{{MatProxyCell|title=Sine|desc=A [[w:sine wave|sine wave]].|arguments=
; <code>sineperiod</code>
; <code>sineperiod</code>
Line 93: Line 103:
: Used to offset the starting position of the wave
: Used to offset the starting position of the wave
; <code>resultVar</code>
; <code>resultVar</code>
: Returns <code>sinemin + (sinemax-sinemin)/2 * (1 + sin( 2*pi/sineperiod * (time + timeoffset) ))</code>.
}}
}}
{{MatProxyCell|title=LinearRamp|desc=An ever-increasing [[float]] value.|arguments=
{{MatProxyCell|title=LinearRamp|desc=An ever-increasing [[float]] value.|arguments=
Line 100: Line 111:
: Value at map start.
: Value at map start.
; <code>resultVar</code>
; <code>resultVar</code>
: Returns <code>rate * time + initialValue</code>.
{{note|The value is ''not'' continuous as one might expect, i.e. if the rate is changed dynamically, it will not 'add' to the previous value. }}
}}
}}
{{MatProxyCell|title=CurrentTime|desc=The number of seconds the current map has been running on the server for.|arguments=
{{MatProxyCell|title=CurrentTime|desc=The number of seconds the current map has been running on the server for.|arguments=
Line 110: Line 123:
; <code>maxVal</code>
; <code>maxVal</code>
; <code>resultVar</code>
; <code>resultVar</code>
: Returns an random value in the range <code>[minVal, maxVal]</code> with equal probability.
}}
}}
{{MatProxyCell|title=GaussianNoise|desc=A noisy signal where values are biased towards the average.|arguments=
{{MatProxyCell|title=GaussianNoise|desc=A noisy signal where values are biased towards the average.|arguments=
Line 130: Line 144:


== Entity Data Access ==
== Entity Data Access ==
These proxies read values from the entity the proxy is applied to.
These proxies read values from the entity the proxy is applied to.
{{warning|Will cause a crash when used on prop_static or world brushes, which don't have an entity. Named overlays are fine.}}
{{warning|Will cause a crash when used on [[prop_static]], [[world brush]]es, [[infodecal]], [[info_projecteddecal]], or unnamed [[info_overlay]]s. Named [[info_overlay]]s are fine.}}


{{MatProxyCell|title=Alpha|desc=Copies the entity's Render Alpha value to the <code>$alpha</code> material parameter.|arguments=
{{MatProxyCell|title=Alpha|desc=Copies the entity's {{code|renderamt}} value to the <code>$alpha</code> material parameter.|arguments=
; <code>$alpha</code>
; <code>$alpha</code>
: The alpha material variable is set to the Render Alpha value.
: The alpha material variable is set to the value of the entity's {{code|renderamt}}
}}
}}
{{MatProxyCell|title=Cycle|desc=Outputs the progress through the current animation of the entity.|arguments=
{{MatProxyCell|title=Cycle|desc=Outputs the progress through the current animation of the entity.|arguments=
Line 188: Line 201:
: The value is rescaled to be between 0 and the scale value.
: The value is rescaled to be between 0 and the scale value.
; <code>resultVar</code>
; <code>resultVar</code>
{{bug|hidetested=1|Entities using this in {{portal}} will cause a crash the moment that they move through a portal.}}
}}
}}
{{MatProxyCell|title=Health|desc=The material's entity's health (0-1).|arguments=
{{MatProxyCell|title=Health|desc=The material's entity's health (0-1).|arguments=
Line 193: Line 207:
: The value is rescaled to be between 0 and the scale value.
: The value is rescaled to be between 0 and the scale value.
; <code>resultVar</code>
; <code>resultVar</code>
{{bug|Does not work in most games. The game maintains a cache of unique keys in [[KeyValues]] case-insensitive, while material proxies are internally a case-sensitive lookup. This causes the lookup to fail as a KeyValues file with a lowercase <code>health</code> key defined is parsed (e.g. [[Prop_data#Gibs|propdata.txt]]) before the material. This can be workarounded by adding an uppercase <code>Health</code> key into [[gameinfo.txt]] or defining the material proxy lowercase in the client code.}}
{{bug|hidetested=1|Does not work in most games. The game maintains a cache of unique keys in [[KeyValues]] case-insensitive, while material proxies are internally a case-sensitive lookup. This causes the lookup to fail as a KeyValues file with a lowercase <code>health</code> key defined is parsed (e.g. [[Prop_data#Gibs|propdata.txt]]) before the material. This can be workarounded by adding an uppercase <code>Health</code> key into [[gameinfo.txt]] or defining the material proxy lowercase in the client code.}}
}}
}}
{{MatProxyCell|title=IsNPC|desc=Returns whether the material is applied to a NPC. Used in HL2 for [[npc_hunter]]'s eye glow, which is supposed to stay off on ragdolls.|arguments=
{{MatProxyCell|title=IsNPC|desc=Returns whether the material is applied to a NPC. Used in HL2 for [[npc_hunter]]'s eye glow, which is supposed to stay off on ragdolls.|arguments=
Line 213: Line 227:


== Texture manipulation ==
== Texture manipulation ==
{{MatProxyCell|title=AnimatedTexture|desc=Increments the current frame of an animated VTF.|arguments=
{{MatProxyCell|title=AnimatedTexture|desc=Increments the current frame of an animated VTF.|arguments=
; <code>animatedtexturevar</code>
; <code>animatedTextureVar</code>
: Texture to increment frame for.
: Texture to increment frame for.
: ( i.e. <code>$basetexture</code>, <code>$bumpmap</code>, <code>$normalmap</code>, <code>$envmapmask</code>, <code>$detail</code>)
: ( i.e. <code>$basetexture</code>, <code>$bumpmap</code>, <code>$normalmap</code>, <code>$envmapmask</code>, <code>$detail</code>)
; <code>animatedtextureframenumvar</code>
; <code>animatedTextureFrameNumVar</code>
: Frame variable to increment.
: Frame variable to increment.
: ( i.e. <code>$frame</code>, <code>$bumpframe</code>, <code>$envmapmaskframe</code>, <code>$detailframe</code>)
: ( i.e. <code>$frame</code>, <code>$bumpframe</code>, <code>$envmapmaskframe</code>, <code>$detailframe</code>)
; <code>animatedtextureframerate</code>
; <code>animatedTextureFrameRate</code>
: Framerate in frames per second. Fixed; cannot be changed once set.
: Framerate in frames per second. Fixed; cannot be changed once set.
; <code>animationNoWrap</code>
: If 1, prevents the animation from looping.
}}
}}
{{MatProxyCell|title=AnimatedEntityTexture|desc=Identical to AnimatedTexture, except the entity controls when the animation starts and is "notified" when the animation is wrapped.|arguments=
{{MatProxyCell|title=AnimatedEntityTexture|desc=Identical to AnimatedTexture, except the entity controls when the animation starts and is "notified" when the animation is wrapped.|arguments=
; <code>animatedtexturevar</code>
; <code>animatedTextureVar</code>
; <code>animatedtextureframenumvar</code>
; <code>animatedTextureFrameNumVar</code>
; <code>animatedtextureframerate</code>
; <code>animatedTextureFrameRate</code>
; <code>animationNoWrap</code>
}}
}}
{{MatProxyCell|title=AnimatedOffsetTexture|desc=Identical to AnimatedTexture, except the animation begins when the entity it's applied to spawns.|arguments=
{{MatProxyCell|title=AnimatedOffsetTexture|desc=Identical to AnimatedTexture, except the animation begins when the entity it's applied to spawns.|arguments=
; <code>animatedtexturevar</code>
; <code>animatedTextureVar</code>
; <code>animatedtextureframenumvar</code>
; <code>animatedTextureFrameNumVar</code>
; <code>animatedtextureframerate</code>
; <code>animatedTextureFrameRate</code>
; <code>animationNoWrap</code>
}}
}}
{{MatProxyCell|title=AnimateSpecificTexture|desc=Identical to AnimatedTexture, except only the specified texture could be animated.|arguments=
{{MatProxyCell|title=AnimateSpecificTexture|desc=Identical to AnimatedTexture, except only the specified texture could be animated.|arguments=
; <code>animatedtexturevar</code>
; <code>animatedTextureVar</code>
; <code>animatedtextureframenumvar</code>
; <code>animatedTextureFrameNumVar</code>
; <code>animatedtextureframerate</code>
; <code>animatedTextureFrameRate</code>
; <code>animationNoWrap</code>
; <code>onlyAnimateOnTexture</code>
; <code>onlyAnimateOnTexture</code>
: The full path for the texture that this proxy should function with.
: The full path for the texture that this proxy should function with.
Line 269: Line 287:
; <code>textureScrollAngle</code>
; <code>textureScrollAngle</code>
: Angle of rotation to move along. (90 = up, 180 = left, etc)
: Angle of rotation to move along. (90 = up, 180 = left, etc)
; <code>textureScale</code>
: Scale of the texture; defaults to 1.0 if unspecified. Works similarly to the TextureTransform proxy's scaleVar and [[$basetexturetransform]]'s scale component (e.g., 2.0 is a 50% scale). Unlike those, however, textureScale only accepts a single [[float]]—not a 2D vector—so this proxy can't scale a texture's X and Y axes individually.
}}
}}
{{MatProxyCell|title=LampBeam|desc=Modulates the material's alpha value based on angle between the beam's direction and the viewer's eye point. This is used to make the beams of volumetric light on lights fade as you look at them dead on. Must be attached to entity for angle use.
{{MatProxyCell|title=LampBeam|desc=Modulates the material's alpha value based on angle between the beam's direction and the viewer's eye point. This is used to make the beams of volumetric light on lights fade as you look at them dead on. Must be attached to entity for angle use.
}}
}}
{{MatProxyCell|title=LampHalo|desc=Modulates the material's alpha value based on angle between the beam's direction and the viewer's eye point. Like the LampBeam proxy, but used for the halo at the beam's base. Must be attached to entity for angle use.
{{MatProxyCell|title=LampHalo|desc=Modulates the material's alpha value based on angle between the beam's direction and the viewer's eye point. Like the LampBeam proxy, but used for the halo at the beam's base. Must be attached to entity for angle use.
}}
{{MatProxyCell|title=CustomSteamImageOnModel|desc=Replaces the $baseTexture with a custom texture. No parameters.
}}
}}


== Entity integration ==
== Entity integration ==
 
{{MatProxyCell|title=MaterialModify / MaterialModifyAnimated|desc=Used in conjunction with the [[material_modify_control]] entity to configure arbitrary parameters from map I/O. Only works when the material is applied to an entity. MaterialModify takes no parameters. MaterialModifyAnimated takes the same parameters as AnimatedTexture.'' {{note|Searches for <kbd>material_modify_control</kbd> among children of an entity a material with this proxy is rendered on and then applies its effects.}}
{{MatProxyCell|title=MaterialModify / MaterialModifyAnimated|desc=Used in conjunction with the [[material_modify_control]] entity to configure arbitrary parameters from map I/O. Only works when the material is applied to an entity. MaterialModify takes no parameters. MaterialModifyAnimated takes the same parameters as AnimatedTexture.''
}}
}}
{{MatProxyCell|title=WaterLOD|desc=Coordinates water LOD values between the map's [[water_lod_control]] entity and the material's internal values.|arguments=
{{MatProxyCell|title=WaterLOD|desc=Coordinates water LOD values between the map's [[water_lod_control]] entity and the material's internal values. {{warning|Both of the parameters MUST be defined in the VMT or the proxy will fail.}}|arguments=
; <code>$CHEAPWATERSTARTDISTANCE</code>
; <code>$CHEAPWATERSTARTDISTANCE</code>
: Start distance for cheap water {{note|must be set outside of proxy block.}}
: Start distance for cheap water {{note|must be set outside of proxy block.}}
Line 294: Line 310:
: Name of variable to place result in. Must be a matrix or vector type variable (i.e. <code>$baseTextureOffset</code>).
: Name of variable to place result in. Must be a matrix or vector type variable (i.e. <code>$baseTextureOffset</code>).
}}
}}
{{MatProxyCell|title=Camo|desc=Only used by material "Dev\dev_camo.vmt". This generates a texture matching the surroundings, which appears to be intended to be used for [[Npc_combine_s|Combine Elite]] at some point. Much of the code is disabled, so this is not usable. |arguments=
{{MatProxyCell|title=Camo|desc=Only used by material <code>Dev\dev_camo.vmt</code>. This generates a texture matching the surroundings, which appears to be intended to be used for [[Npc_combine_s|Combine Elite]] at some point. Much of the code is disabled, so this is not usable. |arguments=
; <code>$camopatterntexture</code>
; <code>$camopatterntexture</code>
: The source texture for the camo effect. Should be I8 format.
: The source texture for the camo effect. Should be I8 format.
Line 318: Line 334:
: This proxy sets the value of the alpha variable.
: This proxy sets the value of the alpha variable.
}}
}}
{{MatProxyCell|title=ParticleSphereProxy|desc=Only used by material "particle\SmokeStack.vmt". Seems to be defined in <code>particle_proxies.cpp</code>. Valve remark: "FIXME:  Is this even needed any more?"
{{MatProxyCell|title=ParticleSphereProxy|desc=Only used by material <code>particle\SmokeStack.vmt</code>. Seems to be defined in <code>particle_proxies.cpp</code>. Valve remark: "FIXME:  Is this even needed any more?"
}}
}}
{{MatProxyCell|title=PlayerLogo|desc=Internal proxy for "decals/playerlogo##" decals. Generates and assigns a texture for a specific player index.}}
{{MatProxyCell|title=PlayerLogo|desc=Internal proxy for "decals/playerlogo##" decals. Generates and assigns a texture for a specific player index.}}
Line 329: Line 345:
: Uses [[$color]] as <code>ThermalVar</code> internal reference and proxie output.
: Uses [[$color]] as <code>ThermalVar</code> internal reference and proxie output.
; <code>$ThermalPeriod</code>
; <code>$ThermalPeriod</code>
: Duration to be curl from game's Current Time. *(Default: [[Float|1.0]])*
: Duration to be curl from game's Current Time. Default: [[Float|1.0]].
; <code>$ThermalMin</code>
; <code>$ThermalMin</code>
; <code>$ThermalMax</code>
; <code>$ThermalMax</code>
: Min/Max values to multiply over sine's by product while prevent go lower than <code>$ThermalMin</code>
: Min/Max values to multiply over sine's by product while prevent go lower than <code>$ThermalMin</code>
}}
}}
{{MatProxyCell|title=ToggleTexture|desc=Toggles a texture based on the frame number set by [[env_texturetoggle]]. Must be attached to an entity.|arguments=
{{MatProxyCell|title=ToggleTexture|desc=Toggles a texture based on the frame number [[SetTextureFrameIndex()|set by game code]] (in most games, only via [[env_texturetoggle]]). Must be attached to an entity.|arguments=
; <code>toggleTextureVar</code>
; <code>toggleTextureVar</code>
: Texture to modify based on frames.
: Texture to modify based on frames.
Line 340: Line 356:
: Variable used for frame number.
: Variable used for frame number.
; <code>toggleShouldWrap</code>
; <code>toggleShouldWrap</code>
: Whether the animation should wrap over not.
: Whether the animation should wrap over not. Enabled by default.
:{{confirm|Disabling wrapping probably doesn't work correctly if [[env_texturetoggle]]'s {{mono|IncrementTextureIndex}} input is called 256 times due to {{w|integer overflow}}.}}
}}
}}
== Utility ==
== Utility ==


Line 350: Line 368:


== Miscellaneous ==
== Miscellaneous ==
{{MatProxyCell|title=ConVar {{L4D add}}|desc=Allows you to link a specific variable to a ConVar a client has set.|arguments=
{{MatProxyCell|title=ConVar|desc={{l4d|since}}<br>Allows you to link a specific variable to a ConVar a client has set.|arguments=
; <code>convar</code>
; <code>convar</code>
: The ConVar name to link to. ( E.G. "mat_specular" ) {{note|Strings will not be parsed through, the value of the ConVar must be a number.}}
: The ConVar name to link to, e.g. <code>mat_specular</code>. {{note|Strings will not be parsed through, the value of the ConVar must be a number.}}
; <code>resultVar</code>
; <code>resultVar</code>
: Returns the value of the ConVar. If this is a vector type, all axes will be set individually to the ConVar's value.
: Returns the value of the ConVar. If this is a vector type, all axes will be set individually to the ConVar's value.
Line 359: Line 377:
== Game Specific ==
== Game Specific ==


=== {{game name|hl2|name=Half-Life 2}} ===
=== {{hl2|4}} ===
<hr>
<hr>
{{MatProxyCell|title=EntityOriginAlyx|desc=Identical to EntityOrigin with an x offset of 15. Created as a last-minute hack before The Orange Box shipped.
{{MatProxyCell|title=EntityOriginAlyx|desc=Identical to EntityOrigin with an x offset of 15. Created as a last-minute hack before The Orange Box shipped.
Line 374: Line 392:
}}
}}


==={{game name|tf2|name=Team Fortress 2}}===
==={{tf2|4}}===
<hr>
<hr>
{{MatProxyCell|title=invis|desc=Works if [[VertexLitGeneric#Cloak|$cloakPassEnabled]] is true. Supports both world models and view models, but doesn't have team color support.
{{MatProxyCell|title=invis|desc=Works if [[VertexLitGeneric#Cloak|$cloakPassEnabled]] is true. Supports both world models and view models, but doesn't have team color support.
Line 416: Line 434:
{{MatProxyCell|title=TeamTexture|desc=Changes the animation frame of the texture depending on the current team.|
{{MatProxyCell|title=TeamTexture|desc=Changes the animation frame of the texture depending on the current team.|
arguments=
arguments=
; <code>resultVar</code>
; <code>resultVar</code> - Only writes to <code>$frame</code>
}}
}}
{{MatProxyCell|title=AnimatedWeaponSheen|desc=Performs the [https://wiki.teamfortress.com/wiki/Killstreak_Kit#Specialized_Killstreak_Kit killstreak sheen effect].
{{MatProxyCell|title=AnimatedWeaponSheen|desc=Performs the [https://wiki.teamfortress.com/wiki/Killstreak_Kit#Specialized_Killstreak_Kit killstreak sheen effect].
Line 446: Line 464:
; <code>resultVar</code>
; <code>resultVar</code>
}}
}}
{{MatProxyCell|title=SniperRifleCharge|desc=Returns the [https://wiki.teamfortress.com/wiki/Sniper_Rifle Sniper Rifle] chargeup, from 0 to 1.|
{{MatProxyCell|title=SniperRifleCharge|desc=Returns a transform matrix for the [https://wiki.teamfortress.com/wiki/Sniper_Rifle Sniper Rifle] charge up. Other weapons can affect the return value such as melee weapons and the Medi Gun|
arguments=
arguments=
; <code>resultVar</code>
; <code>resultVar</code>
Line 461: Line 479:
arguments=
arguments=
; <code>resultVar</code>
; <code>resultVar</code>
}}
{{MatProxyCell|title=CustomSteamImageOnModel|desc=Replaces the $baseTexture with a custom texture. No parameters.
{{note|This is used to make it possible to use the decal tool on hats in {{tf2}}, for example.}}
}}
}}


=== {{game name|l4d2|name=Left 4 Dead 2}} ===
=== {{l4d2|4}} ===
<hr>
<hr>
{{MatProxyCell|title=PlayerTeam|desc=Returns a value depending on the team the player is currently in.|arguments=
{{MatProxyCell|title=PlayerTeam|desc=Returns a value depending on the team the player is currently in.|arguments=
Line 485: Line 506:
: 1 = on fire / 0 = not on fire
: 1 = on fire / 0 = not on fire
}}
}}
{{MatProxyCell|title=BBQLevel|desc=Seen in materials\models\infected\hulk\hulk_01.vmt|arguments=
{{MatProxyCell|title=BBQLevel|desc=Seen in <code>materials\models\infected\hulk\hulk_01.vmt</code>|arguments=
; <code>resultVar</code>
; <code>resultVar</code>
}}
}}


==={{game name|as|name=Alien Swarm}}===
==={{as|4}}===
<hr>
<hr>
{{MatProxyCell|title=NightVisionSelfIllum|desc=When the player has a night vision effect or sniper scope active, outputs a strength to modulate selfillumination on objects.|arguments=
{{MatProxyCell|title=NightVisionSelfIllum|desc=When the player has a night vision effect or sniper scope active, outputs a strength to modulate selfillumination on objects.|arguments=
Line 512: Line 533:
}}
}}


===Portal 1 and 2 {{Portalseries}} ===
==={{portal|4}} and {{portal2|4}}===
<hr>
<hr>
{{MatProxyCell|title=PortalOpenAmount|desc=On portals, transitions from 0 to 1 as the portal opens.|arguments=
{{MatProxyCell|title=PortalOpenAmount|desc=On portals, transitions from 0 to 1 as the portal opens.|arguments=
Line 520: Line 541:
; <code>resultVar</code>
; <code>resultVar</code>
}}
}}
==={{game name|portal2|name=Portal 2}} only===
 
==={{portal2|4}} only===
<hr>
<hr>
{{MatProxyCell|title=FizzlerVortex|desc=Sets various parameters used by the [[SolidEnergy]] shader for [[Fizzler|fizzler]] effects - the location of nearby objects, flashing from portal shots, and power transition times. Doesn't take any arguments.|arguments=
{{MatProxyCell|title=FizzlerVortex|desc=Sets various parameters used by the [[SolidEnergy]] shader for [[Fizzler|fizzler]] effects - the location of nearby objects, flashing from portal shots, and power transition times. Doesn't take any arguments.|arguments=
Line 550: Line 572:
}}
}}


==={{game name|bms|name=Black Mesa}}===
==={{bms|4}}===
<hr>
{{MatProxyCell|title=TauCharge|desc=Seen in <code>materials/models/weapons/<wbr>v_gauss/v_taucannon_core.vmt</code>.|arguments=
{{MatProxyCell|title=TauCharge|desc=Seen in materials\models\weapons\v_gauss\v_taucannon_core.vmt|arguments=
; <code>resultVar</code>
}}
 
{{MatProxyCell|title=WebBurnFactorProxy|desc=Seen in <code>materials/models/props_xen/<wbr>gonarch/gon_web_tough_burnable.vmt</code>.|arguments=
; <code>resultVar</code>
}}
 
{{MatProxyCell|title=ModelDetailFx|desc=Seen in <code>materials/models/weapons/<wbr>v_gauss/v_taucannon_core.vmt</code>.
}}
 
{{MatProxyCell|title=AnimatedWeaponSheen|desc=Seen in <code>materials/models/<wbr>world_models/w_357_mp.vmt</code>.
}}
 
{{MatProxyCell|title=NoHudPostProcess|desc=Seen in <code>vgui/hud<wbr>weapon_dummy.vmt</code>.|arguments=
; <code>resultVar</code>
; <code>resultVar</code>
}}
}}


==={{game name|csgo|name=Counter-Strike: Global Offensive}}===
==={{csgo|4}}===
<hr>
<hr>
{{MatProxyCell|title=Select|desc=Picks a result value depending on the input value, like a [[w:Switch statement|switch statement]].|arguments=
{{MatProxyCell|title=Select|desc=Picks a result value depending on the input value, like a [[w:Switch statement|switch statement]].|arguments=
Line 563: Line 598:
; <code>default</code>
; <code>default</code>
: The default return value if the value of <code>srcVar1</code> does not match any case.
: The default return value if the value of <code>srcVar1</code> does not match any case.
; <code><case></code>
; ''<code><case></code>''
: The return value if the value of <code>srcVar1</code> has the value <code><case></code>. There can be multiple cases.
: The return value if the value of <code>srcVar1</code> has the value <code><case></code>. There can be multiple cases.''
Example from <code>materials\models\inventory_items\dogtags\dogtags_lightray.vmt</code>:
''Example from <code>materials/models/inventory_items/<wbr>dogtags/dogtags_lightray.vmt</code>:
<pre style="background:#444; color:#eeeeee; border-color:#666">
<pre style="background:#444; color:#eeeeee; border-color:#666">
"srcVar1"  "$localTeamNumber"
"srcVar1"  "$localTeamNumber"
Line 575: Line 610:
{{todo|Works for other case types? Other games?}}
{{todo|Works for other case types? Other games?}}
}}
}}
{{MatProxyCell|title=GetTeamNumber|desc=Gets the team of an entity. Seen in <code>materials\models\inventory_items\dogtags\dogtags_lightray.vmt</code>.|arguments=
{{MatProxyCell|title=GetTeamNumber|desc=Gets the team of an entity. Seen in <code>materials/models/inventory_items/<wbr>dogtags/dogtags_lightray.vmt</code>.|arguments=
; <code>resultVar</code>
; <code>resultVar</code>
: Returns an integer.
:*0: Unassigned
:*0: Unassigned
:*1: Spectator
:*1: Spectator
Line 584: Line 618:
{{todo|Other games?}}
{{todo|Other games?}}
}}
}}
{{MatProxyCell|title=survivalteammate|desc=Used to paint the teammate in {{csgo mode|Dz}}. Seen in <code>materials\models\player\custom_player\econ\body\tm_jumpsuit\jumpsuit_body.vmt</code>|arguments=
{{MatProxyCell|title=survivalteammate|desc=Used to paint the teammate in {{csgo mode|Dz}}. Seen in <code>materials/models/player/custom_player/econ/<wbr>body/tm_jumpsuit/jumpsuit_body.vmt</code>.|arguments=
; <code>resultVar</code>
; <code>resultVar</code>
: Returns 1 if the local player is the teammate of the player that the material is applied to and 0 if not.{{note|Always returns 0 outside of Danger Zone.}}
: Returns 1 if the local player is the teammate of the player that the material is applied to and 0 if not.{{note|Always returns 0 outside of Danger Zone — use GetTeamNumber instead!}}
}}
}}
{{MatProxyCell|title=RemapValClamp|desc=Remaps a variable within the specified ranges.|arguments=
{{MatProxyCell|title=RemapValClamp|desc=Remaps a variable within the specified ranges.|arguments=
Line 621: Line 655:
; <code>resultVar</code>
; <code>resultVar</code>
: the result of the transition is stored in the resultvar.
: the result of the transition is stored in the resultvar.
}}
==={{titanfall|4}} and {{titanfall2|4}}===
<hr>
{{MatProxyCell|title=ADSFraction|desc=Returns a value between 0 and 1, depending on how much the player is adsing.|arguments=
; <code>use_weapon_settings</code>
: If set, uses the weapon's <code>zoom_scope_frac_start</code> and <code>zoom_scope_frac_end</code> settings.
; <code>startFrac</code>
; <code>endFrac</code>
; <code>invert</code>
; <code>spline</code>
; <code>scale</code>
; <code>resultVar</code>
}}
{{MatProxyCell|title=ADSFOVTarget|arguments=
; <code>range</code>
; <code>invert</code>
; <code>resultVar</code>
}}
{{MatProxyCell|title=BackgroundAmmoColor|desc=Passes an RGB value according to the current clip of the player's weapon. Goes from blue -> orange -> red.|arguments=
; <code>resultVar</code>
}}
{{MatProxyCell|title=ClipAmmo|desc=Returns the current clip of the player's current weapon.|arguments=
; <code>resultVar</code>
}}
{{MatProxyCell|title=ClipAmmoColor|desc=Similar to <code>BackgroundAmmoColor</code>, but the ammount where the value changes is different.|arguments=
; <code>resultVar</code>
}}
{{MatProxyCell|title=CockpitLights
}}
{{MatProxyCell|title=CockpitOpenAmount
}}
{{MatProxyCell|title=CockpitScreen
}}
{{MatProxyCell|title=EntityScript|desc=Calls a Vscript function and returns a value.|arguments=
; <code>scriptFuncName</code>
; <code>resultVar</code>
}}
{{MatProxyCell|title=Holosight|desc=Similar to <code>ADSFraction</code>, but with seemingly no settings.|arguments=
; <code>resultVar</code>
}}
{{MatProxyCell|title=HoloSightOffset|desc=Base offset from UV centre relative to vector2 $attachment position.|arguments=
; <code>attachmentName</code>
; <code>horizontalScalar</code>
; <code>verticalScalar</code>
; <code>resultVar</code>
''Example from <code>materials/models/weapons/<wbr>attachments/hcog_reticle_front.vmt</code>:
<pre style="background:#444; color:#eeeeee; border-color:#666">
"attachmentName"  "HCOG_REAR"
"horizontalScalar" "0.55"
"verticalScalar"  "-0.72"
"resultVar"        "$holoOffset"
</pre>
}}
{{MatProxyCell|title=MaxCarryAmmo|desc=Returns the max reserve ammo size of the player's current weapon.|arguments=
; <code>resultVar</code>
{{bug|tested=Titanfall 2|Doesn't work if the weapon doesn't use clips.}}
}}
{{MatProxyCell|title=MaxClipAmmo|desc=Returns the max clip size of the player's current weapon.|arguments=
; <code>resultVar</code>
}}
{{MatProxyCell|title=MiniMap|arguments=
; <code>resultVar</code>
}}
{{MatProxyCell|title=NumericCounterAtlasFrame|arguments=
; <code>value</code>
; <code>digitIndex</code>
; <code>resultAtlasFrameIndexVar</code>
}}
{{MatProxyCell|title=ProgressBar|arguments=
; <code>value</code>
; <code>max</code>
; <code>resultVar</code>
: The result is a transformation matrix.
}}
{{MatProxyCell|title=RemainingAmmo|desc=Returns the current reserve ammo of the player's current weapon.|arguments=
; <code>resultVar</code>
{{bug|tested=Titanfall 2|Doesn't work if the weapon doesn't use clips.}}
}}
{{MatProxyCell|title=RemainingAmmoColor|desc= Similar to <code>BackgroundAmmoColor</code>, but uses the weapon's reserve ammo instead.| arguments=
; <code>resultVar</code>
{{bug|tested=Titanfall 2|Doesn't work if the weapon doesn't use clips.}}
}}
{{MatProxyCell|title=RemainingClipCount|desc=Returns the max reserve ammo divided by the max clip size of the player's current weapon.|arguments=
; <code>resultVar</code>
}}
{{MatProxyCell|title=ScriptModify|desc=Calls a Vscript function and returns a value.|arguments=
; <code>scriptFuncName</code>
; <code>resultVar</code>
''Example from <code>materials/vgui/hud/compass_ticker.vmt</code>:
<pre style="background:#444; color:#eeeeee; border-color:#666">
"scriptFuncName" "VMTCallback_CompassTickerOffset"
"resultVar" "$offset"
</pre>
{{confirm|Identical to <code>EntityScript</code>?}}
}}
{{MatProxyCell|title=TextureAtlas|arguments=
; <code>frameSize</code>
; <code>frameStart</code>
; <code>resultVar</code>
}}
{{MatProxyCell|title=TickCounterAtlasFrames|arguments=
; <code>tickCount</code>
; <code>rowLength</code>
; <code>rowIndex</code>
; <code>atlasFrameSize</code>
; <code>resultAtlasFrameStartVar</code>
; <code>resultAtlasFrameCountVar</code>
}}
{{MatProxyCell|title=WeaponChargeFraction|desc=Returns a value between 0 and 1, depending on the charge amount of the player's current weapon.|arguments=
; <code>resultVar</code>
}}
}}


== See also ==
== See also ==
* [[Material Proxies]]
* [[Material Proxies]]
* [[Material Creation]]
* [[Material Creation]]


[[Category:Material System]]
[[Category:Material System]]
[[Category:Lists]]

Latest revision as of 02:39, 12 October 2025

English (en)Español (es)中文 (zh)Translate (Translate)
Main article:  Material proxies

All material proxies usable in materials at all Source 2013 games can be found here, along with proxies only present in specific games. (Mostly other Valve titles)

Todo: There are still lots of undocumented proxies / proxies lacking enough documentation!
Icon-Important.pngImportant:Unlike material variables, material proxy names are case sensitive.

Calculation

Note.pngNote:Operations involving integers of all these proxies will be converted to a float result value, except for Equals and Clamp.

Add Adds two variables.

srcVar1
srcVar2
resultVar
Returns srcVar1 + srcVar2.

Multiply Multiplies two variables.

srcVar1
srcVar2
resultVar
Returns srcVar1 * srcVar2.

Subtract Subtracts the second variable from the first.

srcVar1
srcVar2
resultVar
Returns srcVar1 - srcVar2.

Divide Divides the first variable by the second.

srcVar1
srcVar2
resultVar
Returns srcVar1 / srcVar2.

Equals Copies the value of a variable to another.

srcVar1
resultVar
Returns srcVar1.

Abs Computes the absolute (i.e. unsigned) value of a variable.

srcVar1
resultVar
Returns abs(srcVar1).

Frac

Returns the fractional component of a variable. For integer values, no change occurs.
Tip.pngTip:frac(4.23) = .23
srcVar1
resultVar

Int

Returns the integer component of a variable.
Tip.pngTip:int(4.23) = 4
srcVar1
resultVar

Clamp Keeps a variable within a specified range. srcVar1 and resultVar can be the same.

min
max
srcVar1
resultVar
Returns the value in the range [min, max] that is the closest to srcVar1.

LessOrEqual Compares the first value to the second.

lessEqualVar
greaterVar
srcVar1
srcVar2
resultVar
If srcVar1 ≤ srcVar2, returns lessEqualVar, otherwise greaterVar.

SelectFirstIfNonZero Selects the first value over the second if it is anything other than zero.

srcVar1
srcVar2
resultVar
If srcVar1 == 0, returns srcVar1, otherwise srcVar2.

WrapMinMax Constrains a value into a range, wrapping around if it exceeds it.

srcVar1
The value to constrain.
minVal
maxVal
Range to constrain the value to. If min is less than max, min is always returned.
resultVar
The variable to write the results to.

Exponential A value that changes at a faster and faster rate.

minVal
maxVal
Upper and lower value clamps.
srcVar1
offset
scale
resultVar
Returns scale * exp( srcVar1 + offset )
Tip.pngTip:exp(n) = en

Number generation

Sine A sine wave.

sineperiod
Period between wave peaks, in seconds.
sinemin
sinemax
Values at the top and bottom of the wave
timeoffset
Used to offset the starting position of the wave
resultVar
Returns sinemin + (sinemax-sinemin)/2 * (1 + sin( 2*pi/sineperiod * (time + timeoffset) )).

LinearRamp An ever-increasing float value.

rate
Units per second.
initialValue
Value at map start.
resultVar
Returns rate * time + initialValue.
Note.pngNote:The value is not continuous as one might expect, i.e. if the rate is changed dynamically, it will not 'add' to the previous value.

CurrentTime The number of seconds the current map has been running on the server for.

resultVar
This is intended to set the $time shader variable, used by several shaders to adjust their effects over time.

UniformNoise A noisy signal where each value is equally likely to occur.

minVal
maxVal
resultVar
Returns an random value in the range [minVal, maxVal] with equal probability.

GaussianNoise A noisy signal where values are biased towards the average.

mean
The average value around which the noise will centre
halfWidth
The distance from the average at which it's only 30% likely to occur.
minVal
maxVal
resultVar

MatrixRotate A rotation matrix from the provided axis and angle.

axisVar
Axis of rotation, in the format [x y z]
angle
Degrees of rotation around axis.
resultVar
The result of this is a transformation matrix, suitable to set $basetexturetransform and other similar variables.

Entity Data Access

These proxies read values from the entity the proxy is applied to.

Warning.pngWarning:Will cause a crash when used on prop_static, world brushes, infodecal, info_projecteddecal, or unnamed info_overlays. Named info_overlays are fine.

Alpha Copies the entity's renderamt value to the $alpha material parameter.

$alpha
The alpha material variable is set to the value of the entity's renderamt

Cycle Outputs the progress through the current animation of the entity.

start
The value to output at the start of the animation. This can't be a variable reference.
end
The value to output at the end of the animation. This can't be a variable reference.
easein
Apply easing to the beginning of the output. This can't be a variable reference.
easeout
Apply easing to the beginning of the output. This can't be a variable reference.
resultVar
The variable to store the result in.

PlayerProximity Outputs the distance in units between the local player and the origin of the entity that the material is applied to.

scale
A factor by which the result is multiplied.
resultVar

PlayerTeamMatch Returns 1 if the team of the entity the material is applied to matches that of the local player. Used in TF2 for func_respawnroomvisualizer.

resultVar
This value is 1 if the local player is on the same team and 0 if the local player is not.

PlayerView The dot product of the player's view angle and the relative origin of the material's entity.

scale
The value is rescaled to be between 0 and the scale value.
resultVar

PlayerSpeed Speed of the local player.

scale
The value is multiplied by this value. This factor defaults to 0.005.
resultVar

PlayerPosition The local player's position.

scale
The value is multiplied by this value. This factor defaults to 0.005.
resultVar
Set to the vector position.

EntitySpeed The material's entity's speed.

resultVar
The current speed of this entity, in units per second.

EntityOrigin The material's entity's origin. The variable set cannot be changed.

$entityorigin
Set to the origin of the entity.

EntityRandom A static random number associated with the entity the material is applied to. Helpful for staggering effects that appear on multiple objects.

scale
The value is rescaled to be between 0 and the scale value.
resultVar
Icon-Bug.pngBug:Entities using this in Portal will cause a crash the moment that they move through a portal.

Health The material's entity's health (0-1).

scale
The value is rescaled to be between 0 and the scale value.
resultVar
Icon-Bug.pngBug:Does not work in most games. The game maintains a cache of unique keys in KeyValues case-insensitive, while material proxies are internally a case-sensitive lookup. This causes the lookup to fail as a KeyValues file with a lowercase health key defined is parsed (e.g. propdata.txt) before the material. This can be workarounded by adding an uppercase Health key into gameinfo.txt or defining the material proxy lowercase in the client code.

IsNPC Returns whether the material is applied to a NPC. Used in HL2 for npc_hunter's eye glow, which is supposed to stay off on ragdolls.

scale
The value to return when the material is applied to a NPC. Despite the name, nothing in this process is actually multiplied. (although this must be a float)
resultVar
If the material is applied to a NPC, this value is equal to scale. Otherwise, this value stays at 0.

WorldDims The dimensions of the world entity. The variables set cannot be changed.

$world_mins
Set to the minimum X/Y/Z coordinates.
$world_maxs
Set to the maximum X/Y/Z coodinates.

CrosshairColor The color of the local player's crosshair. cl_crosshaircolor_(r, g, b)

resultVar
Returns [r g b] with values from 0 to 1.

Texture manipulation

AnimatedTexture Increments the current frame of an animated VTF.

animatedTextureVar
Texture to increment frame for.
( i.e. $basetexture, $bumpmap, $normalmap, $envmapmask, $detail)
animatedTextureFrameNumVar
Frame variable to increment.
( i.e. $frame, $bumpframe, $envmapmaskframe, $detailframe)
animatedTextureFrameRate
Framerate in frames per second. Fixed; cannot be changed once set.
animationNoWrap
If 1, prevents the animation from looping.

AnimatedEntityTexture Identical to AnimatedTexture, except the entity controls when the animation starts and is "notified" when the animation is wrapped.

animatedTextureVar
animatedTextureFrameNumVar
animatedTextureFrameRate
animationNoWrap

AnimatedOffsetTexture Identical to AnimatedTexture, except the animation begins when the entity it's applied to spawns.

animatedTextureVar
animatedTextureFrameNumVar
animatedTextureFrameRate
animationNoWrap

AnimateSpecificTexture Identical to AnimatedTexture, except only the specified texture could be animated.

animatedTextureVar
animatedTextureFrameNumVar
animatedTextureFrameRate
animationNoWrap
onlyAnimateOnTexture
The full path for the texture that this proxy should function with.
Todo: What is this used for? None out of around 40 thousand official Valve .vmt files use this proxy

Pupil Used for character's eyes, computes the light brightness at the material's position and reacts to bright lights by incrementing the texture's frame.

TextureVar
Texture to increment frame for.
TextureFrameNumVar
Frame variable to increment.
PupilCloseRate
The maximum speed the pupil can close, in fractions/second. The default is 0.1.
PupilOpenRate
The maximum speed the pupil can open, in fractions/second. The default is 0.03.
$lighting
This material variable is used to store the previous frame, and should be set to 0.5 in the material. It will be set to the average light value, from 0-1.

TextureTransform Generates a texture transform matrix for use with $basetexturetransform etc.

centerVar
scaleVar
rotateVar
translateVar
Optional input variables for the matrix. Each one can be a float or a 2D vector.
resultVar

TextureScroll Returns a transform matrix or vector that will translate a texture at a given angle at a given rate.

textureScrollVar
Destination for the resulting transformation.
textureScrollRate
Rate of scroll in units per second.
textureScrollAngle
Angle of rotation to move along. (90 = up, 180 = left, etc)
textureScale
Scale of the texture; defaults to 1.0 if unspecified. Works similarly to the TextureTransform proxy's scaleVar and $basetexturetransform's scale component (e.g., 2.0 is a 50% scale). Unlike those, however, textureScale only accepts a single float—not a 2D vector—so this proxy can't scale a texture's X and Y axes individually.

LampBeam Modulates the material's alpha value based on angle between the beam's direction and the viewer's eye point. This is used to make the beams of volumetric light on lights fade as you look at them dead on. Must be attached to entity for angle use.

LampHalo Modulates the material's alpha value based on angle between the beam's direction and the viewer's eye point. Like the LampBeam proxy, but used for the halo at the beam's base. Must be attached to entity for angle use.

Entity integration

MaterialModify / MaterialModifyAnimated

Used in conjunction with the material_modify_control entity to configure arbitrary parameters from map I/O. Only works when the material is applied to an entity. MaterialModify takes no parameters. MaterialModifyAnimated takes the same parameters as AnimatedTexture.
Note.pngNote:Searches for material_modify_control among children of an entity a material with this proxy is rendered on and then applies its effects.

WaterLOD

Coordinates water LOD values between the map's water_lod_control entity and the material's internal values.
Warning.pngWarning:Both of the parameters MUST be defined in the VMT or the proxy will fail.
$CHEAPWATERSTARTDISTANCE
Start distance for cheap water
Note.pngNote:must be set outside of proxy block.
$CHEAPWATERENDDISTANCE
End distance for cheap water
Note.pngNote:must be set outside of proxy block.

BreakableSurface Sets the base texture to a material name held by the entity (used for switching surface material on shatter). Must be attached to a func_breakable_surf entity.

ConveyorScroll Returns the scroll parameters for a texture used as a conveyor, so it matches the entity's settings. Must be attached to func_conveyor entity.

textureScrollVar
Name of variable to place result in. Must be a matrix or vector type variable (i.e. $baseTextureOffset).

Camo Only used by material Dev\dev_camo.vmt. This generates a texture matching the surroundings, which appears to be intended to be used for Combine Elite at some point. Much of the code is disabled, so this is not usable.

$camopatterntexture
The source texture for the camo effect. Should be I8 format.
$camoboundingboxmin
$camoboundingboxmax
Random points within this bounding box will be sampled to determine the camo coloring.

FleshInterior Outputs the locations of nearby point_flesh_effect_targets for use by the $flesh effect.

$FleshEffectCenterRadius1
$FleshEffectCenterRadius2
$FleshEffectCenterRadius3
$FleshEffectCenterRadius4
Set to the world locations of four flesh targets, with the fourth axis set to the radius. If a target is not present, all four axes are set to zero.
$FleshGlobalOpacity
This material variable has to exist for the proxy to function, but it's not actually set at any point.
$FleshSubsurfaceTint
This is just set to [0 0 0 0].

HeliBlade Controls transition on npc_helicopter's blades. This fades in or out the blades to convert from a set of physical blades into a spinning blurred circle.

$fadeout
If the variable is set to 1, fade out the blades as it starts up. If 0, fade in.
$alpha
This proxy sets the value of the alpha variable.

ParticleSphereProxy Only used by material particle\SmokeStack.vmt. Seems to be defined in particle_proxies.cpp. Valve remark: "FIXME: Is this even needed any more?"

Shadow Only used by Shadow. No known parameters. This sets lots of material parameters to render projected texture shadows.

ShadowModel Only used by ShadowModel. No known parameters. This sets lots of material parameters for rendering projected texture shadows.

Thermal Uses $color vectors and work around $ThermalPeriod, $ThermalMin, and $ThermalMax to generate a Hue scaled Sine and applies back to $color.

$color
Uses $color as ThermalVar internal reference and proxie output.
$ThermalPeriod
Duration to be curl from game's Current Time. Default: 1.0.
$ThermalMin
$ThermalMax
Min/Max values to multiply over sine's by product while prevent go lower than $ThermalMin

ToggleTexture Toggles a texture based on the frame number set by game code (in most games, only via env_texturetoggle). Must be attached to an entity.

toggleTextureVar
Texture to modify based on frames.
toggleTextureFrameNumVar
Variable used for frame number.
toggleShouldWrap
Whether the animation should wrap over not. Enabled by default.
Confirm:Disabling wrapping probably doesn't work correctly if env_texturetoggle's IncrementTextureIndex input is called 256 times due to Wikipedia icon integer overflow.

Utility

Empty Used to comment out proxies. Surround a bunch of proxies with the empty proxy to cause those proxies to not operate.

Dummy Prints developer messages in response to the proxy being created, the proxy being initialized, the proxy being bound to an entity, and the proxy being removed.

Miscellaneous

ConVar (in all games since Left 4 Dead)
Allows you to link a specific variable to a ConVar a client has set.

convar
The ConVar name to link to, e.g. mat_specular.
Note.pngNote:Strings will not be parsed through, the value of the ConVar must be a number.
resultVar
Returns the value of the ConVar. If this is a vector type, all axes will be set individually to the ConVar's value.

Game Specific

Half-Life 2 Half-Life 2


EntityOriginAlyx Identical to EntityOrigin with an x offset of 15. Created as a last-minute hack before The Orange Box shipped.

Ep1IntroVortRefract Uses $refractamount to generate a ratio and sends it to the same variable, not using resultVar. Created as a last-minute hack before The Orange Box shipped.

VortEmissive Sets $emissiveblendstrength and $detailblendfactor to apply the Vortigaunt's blue-purple glow effects in Episode 1's opening.

Shield Likely intended to be used for one of the Combine shield types. This is equivalent to a combination of the TextureScroll and Alpha proxies.

$translucency
This variable is set to the Render Alpha value of the attached entity, similar to the Alpha proxy.
textureScrollVar
textureScrollRate
textureScrollAngle
Has identical functionality to the TextureScroll proxy.

Team Fortress 2 Team Fortress 2


invis Works if $cloakPassEnabled is true. Supports both world models and view models, but doesn't have team color support.

spy_invis Works if $cloakPassEnabled is true. Used in player world model materials. No parameters. Cloak color will be team-colored on players by default. Incompatible with $weapon_invis and $vm_invis.

weapon_invis Works if $cloakPassEnabled is true. Used in weapon world model materials. No parameters. Incompatible with $spy_invis and $vm_invis.

vm_invis Works if $cloakPassEnabled is true. Used in player and weapon view model materials. No parameters. Incompatible with $spy_invis and $weapon_invis.

building_invis Unused, intended to be used in building model materials to support cloaking.

CommunityWeapon Passes the value 1 when item is flagged as a Community quality item. Passes 0 otherwise.

resultVar

InvulnLevel Passes a float value to set the opacity of the invulnerability effect when a player has been ÜberCharged.

resultVar

BurnLevel Passes a float value to set the opacity of the fire overlay effect when a player is on fire.

resultVar

YellowLevel Passes an RGB value when Jarate has been used on a player.

resultVar

ModelGlowColor When active, passes hard coded color value to create the crit glow effect. Color is either red or blue. When inactive value is pure white (255 255 255).

resultVar

ItemTintColor Passes an RGB value when a Paint Can is used. Value is specific to Paint color. Passes 0 when no Paint is used.

resultVar

BuildingRescueLevel Passes a transform matrix to set the amplitude of the Rescue Ranger display.

resultVar

TeamTexture Changes the animation frame of the texture depending on the current team.

resultVar - Only writes to $frame

AnimatedWeaponSheen Performs the killstreak sheen effect.

animatedtexturevar
animatedtextureframenumvar
animatedtextureframerate

WeaponSkin Sets basetexture for Decorated items.

ShieldFalloff Pulses the Vaccinator's Über shield.

StatTrakIllum Returns 0.75 on viewmodels.

resultVar

StatTrakDigit Returns one digit of the item's Strange counter. If trimZeros is positive, leading zeroes will return 10 instead.

resultVar
displayDigit
trimZeros

StatTrakIcon Non-functional. Returns a constant matrix.

resultVar

StickybombGlowColor When active, passes hard coded color value to create the 'Scottish Resistance' selection effect. Color is either red or blue.

resultVar

SniperRifleCharge Returns a transform matrix for the Sniper Rifle charge up. Other weapons can affect the return value such as melee weapons and the Medi Gun

resultVar

Heartbeat Returns a time-varying value between 0.48 and 0.6 (mostly 0.6) to simulate a heartbeat.

resultVar

WheatlyEyeGlow Pulsates a color with Gaussian Distribution. Used for the Ap-Sap item.

resultVar

BenefactorLevel Used for scaling the beating heart based on the number of gifts the player has given. Returns a texture scale factor where 1 is max size (big benefactor) and factor gets larger the fewer gifts you've given.

resultVar

CustomSteamImageOnModel Replaces the $baseTexture with a custom texture. No parameters.

Note.pngNote:This is used to make it possible to use the decal tool on hats in Team Fortress 2, for example.

Left 4 Dead 2 Left 4 Dead 2


PlayerTeam Returns a value depending on the team the player is currently in.

team
Unknown
resultVar
0 = survivor / 1 = infected / 2 = spectator

BloodyHands Returns a value between 0 and 1 depending on the number of hits with a melee weapon.

resultVar
number of hits / 5
doesn't go over 1 after 5 hits
value is shared between world and view model

IT Returns a value between 0 and 1 depending on the fact that the survivor is covered in Boomer bile.

resultVar
1 = fully covered / 0 = not covered

BurnLevel Passes a float value to set the opacity of the fire overlay effect when an infected has been burned.

resultVar
1 = on fire / 0 = not on fire

BBQLevel Seen in materials\models\infected\hulk\hulk_01.vmt

resultVar

Alien Swarm Alien Swarm


NightVisionSelfIllum When the player has a night vision effect or sniper scope active, outputs a strength to modulate selfillumination on objects.

resultVar
The value to change. Generally set to $selfillumtint.
asw_night_vision_self_illum_multiplier
This ConVar specifies the value output when night vision is on at full strength.
asw_sniper_scope_self_illum_multiplier
This ConVar specifies the value output when the sniper scope is active.

AlienSurfaceFX Sets the $detail texture and parameters to display fire, freezing and electrical shock effects.

texturescrollvar
Set to the name of the matrix or transform variable that shifts the detail texture, usually $detailtexturetransform.

LanguagePreference (only in Alien Swarm: Reactive Drop) Sets a value based on the client's language setting.

resultVar
The variable to change. (eg. $basetexture)
default
The default value for the variable if no listed language matches.
english, french, schinese, etc.
Specific values for specific languages.

Portal Portal and Portal 2 Portal 2


PortalOpenAmount On portals, transitions from 0 to 1 as the portal opens.

resultVar

PortalStatic On portals, specifies how much the opaque static effect should render. 1 is a unpaired portal, 0 is an open portal.

resultVar

Portal 2 Portal 2 only


FizzlerVortex Sets various parameters used by the SolidEnergy shader for fizzler effects - the location of nearby objects, flashing from portal shots, and power transition times. Doesn't take any arguments.

$powerup
Transitions to 0 when the fizzler is turned off, 1 when turned on.
$FLOW_VORTEX1
Set to 1 when an object is brought near the field, otherwise set to 0.
$FLOW_VORTEX_POS1
Set to the position of the first object.
$FLOW_VORTEX2
Set to 1 when a second object is brought near the field, otherwise set to 0.
$FLOW_VORTEX_POS2
Set to the position of the second object.
Todo: What parameter does the portal shot flash set?

WheatlyEyeGlow

Presumably controls the glow effect on Wheatley. Not actually used.
Todo: Does this do anything? Seems to have been replaced by Lightedmouth.

Lightedmouth Used on the various Personality Cores and PoTaTOS to blink their eye-light in sync with their choreo scenes. When idle, the tint is still partially lit. On the viewmodel, it can also be manually controlled via VScript to make GLaDOS appear to shut down.

resultVar
A tint to pass to $selfillumtint.

LightedFloorButton Used on the clean Super Button materials, sets $selfillumtint to 1 if the material is being used on a prop_floor_button, otherwise sets it to 0. This has no real benefit and just causes the model to appear incorrectly when used on other entities, it was presumably a beta leftover.

resultVar
The tint to use, or [0 0 0] if not on a button.

TractorBeam Used on the Excursion Funnel effect materials, outputs the scroll rate and does other unknown operations.

resultVar
Passed to the textureScrollRate parameter of various TextureScroll proxies.

Black Mesa Black Mesa

TauCharge Seen in materials/models/weapons/v_gauss/v_taucannon_core.vmt.

resultVar

WebBurnFactorProxy Seen in materials/models/props_xen/gonarch/gon_web_tough_burnable.vmt.

resultVar

ModelDetailFx Seen in materials/models/weapons/v_gauss/v_taucannon_core.vmt.

AnimatedWeaponSheen Seen in materials/models/world_models/w_357_mp.vmt.

NoHudPostProcess Seen in vgui/hudweapon_dummy.vmt.

resultVar

Counter-Strike: Global Offensive Counter-Strike: Global Offensive


Select Picks a result value depending on the input value, like a switch statement.

srcVar1
resultVar
default
The default return value if the value of srcVar1 does not match any case.
<case>
The return value if the value of srcVar1 has the value <case>. There can be multiple cases.

Example from materials/models/inventory_items/dogtags/dogtags_lightray.vmt:

"srcVar1"   "$localTeamNumber"
"resultVar" "$color"
"default"   "[0.680 0.680 0.680]"
"2"         "[0.680 0.544 0.136]"
"3"         "[0.269 0.474 0.680]"
Todo: Works for other case types? Other games?

GetTeamNumber Gets the team of an entity. Seen in materials/models/inventory_items/dogtags/dogtags_lightray.vmt.

resultVar
  • 0: Unassigned
  • 1: Spectator
  • 2: Terrorist
  • 3: Counter-Terrorist
Todo: Other games?

survivalteammate Used to paint the teammate in CS:GO Danger Zone Danger Zone. Seen in materials/models/player/custom_player/econ/body/tm_jumpsuit/jumpsuit_body.vmt.

resultVar
Returns 1 if the local player is the teammate of the player that the material is applied to and 0 if not.
Note.pngNote:Always returns 0 outside of Danger Zone — use GetTeamNumber instead!

RemapValClamp Remaps a variable within the specified ranges.

range_in_min
range_in_max
range_out_min
range_out_max
srcVar1
resultVar

Modulo Divides the first variable by the second and writes the remainder value to the resultvar.

srcVar1
srcVar2
resultVar

MoneyProxy Reads from the players money value. Only works on viewmodel materials.

resultVar

WeaponLabelText Calculates where to offset the $basetexture based on the displaydigit value. Only works on the viewmodel.

displaydigit

C4CompassArrow [Todo]

IronSightAmount Returns 1 when the player is scoped in, 0 when scoped out.

invert
resultvar

ApproachValue Performs a smooth transition from the current value of srcVar1 to the targetvalue of srcVar2.

srcVar1
srcVar2
speed
specifies how quickly the transition happens, with a higher value leading to a faster transition.
resultVar
the result of the transition is stored in the resultvar.

Titanfall Titanfall and Titanfall 2 Titanfall 2


ADSFraction Returns a value between 0 and 1, depending on how much the player is adsing.

use_weapon_settings
If set, uses the weapon's zoom_scope_frac_start and zoom_scope_frac_end settings.
startFrac
endFrac
invert
spline
scale
resultVar

ADSFOVTarget [Todo]

range
invert
resultVar

BackgroundAmmoColor Passes an RGB value according to the current clip of the player's weapon. Goes from blue -> orange -> red.

resultVar

ClipAmmo Returns the current clip of the player's current weapon.

resultVar

ClipAmmoColor Similar to BackgroundAmmoColor, but the ammount where the value changes is different.

resultVar

CockpitLights [Todo]

CockpitOpenAmount [Todo]

CockpitScreen [Todo]

EntityScript Calls a Vscript function and returns a value.

scriptFuncName
resultVar

Holosight Similar to ADSFraction, but with seemingly no settings.

resultVar

HoloSightOffset Base offset from UV centre relative to vector2 $attachment position.

attachmentName
horizontalScalar
verticalScalar
resultVar

Example from materials/models/weapons/attachments/hcog_reticle_front.vmt:

"attachmentName"   "HCOG_REAR"
"horizontalScalar" "0.55"
"verticalScalar"   "-0.72"
"resultVar"         "$holoOffset"

MaxCarryAmmo Returns the max reserve ammo size of the player's current weapon.

resultVar
Icon-Bug.pngBug:Doesn't work if the weapon doesn't use clips.  (tested in: Titanfall 2)

MaxClipAmmo Returns the max clip size of the player's current weapon.

resultVar

MiniMap [Todo]

resultVar

NumericCounterAtlasFrame [Todo]

value
digitIndex
resultAtlasFrameIndexVar

ProgressBar [Todo]

value
max
resultVar
The result is a transformation matrix.

RemainingAmmo Returns the current reserve ammo of the player's current weapon.

resultVar
Icon-Bug.pngBug:Doesn't work if the weapon doesn't use clips.  (tested in: Titanfall 2)

RemainingAmmoColor Similar to BackgroundAmmoColor, but uses the weapon's reserve ammo instead.

resultVar
Icon-Bug.pngBug:Doesn't work if the weapon doesn't use clips.  (tested in: Titanfall 2)

RemainingClipCount Returns the max reserve ammo divided by the max clip size of the player's current weapon.

resultVar

ScriptModify Calls a Vscript function and returns a value.

scriptFuncName
resultVar

Example from materials/vgui/hud/compass_ticker.vmt:

"scriptFuncName" "VMTCallback_CompassTickerOffset"
"resultVar" "$offset"
Confirm:Identical to EntityScript?

TextureAtlas [Todo]

frameSize
frameStart
resultVar

TickCounterAtlasFrames [Todo]

tickCount
rowLength
rowIndex
atlasFrameSize
resultAtlasFrameStartVar
resultAtlasFrameCountVar

WeaponChargeFraction Returns a value between 0 and 1, depending on the charge amount of the player's current weapon.

resultVar

See also