VertexLitGeneric: Difference between revisions
		
		
		
		
		
		Jump to navigation
		Jump to search
		
				
		
	
	
	
	
	
	
	
	
	
	
	
	
	
	
		
	
| m (Category rename) | No edit summary | ||
| (39 intermediate revisions by 19 users not shown) | |||
| Line 1: | Line 1: | ||
| {{LanguageBar}} | |||
| = | {{this is a|vertex shader|name=VertexLitGeneric}} It is the shader most commonly used to render [[models|models]], and supports a variety of effects. Do not use this on world geometry, else you may encounter lighting bugs. | ||
| == Supported Parameters == | |||
| ===  | === Basics === | ||
| {{MatParamDef|$basetexture|texture|[[$basetexture]] defines [[diffuse]] texture.}} | |||
| {{MatParamDef|$detail|texture|[[$detail|Detail]] texturing.}} | |||
| {{MatParamDef|$decaltexture|texture|Use a 2nd UV channel for high-resolution decal support.|only={{csgo}}}} | |||
| === Adjustment === | |||
| {{MatParamDef|$color2|RGB matrix|[[$color#Models|Color tinting]].}} | |||
| {{MatParamDef|$basetexturetransform|matrix|[[$basetexture#.24basetexturetransform|Transform]] [[$basetexture]]'s alignment, scale, rotation and position.}} | |||
| {{MatParamDef|$allowdiffusemodulation|bool|Prevents the model's material from being tinted by [[$color2]] or <code>rendercolor.</code>|since={{l4d}}}} | |||
| {{MatParamDef|$seperatedetailuvs|bool|{{todo|''Confirm use of texcoord1 for [[$detail|detail]] texture''}}|since={{src07}}}} | |||
| {{MatParamDef|$desaturatewithbasealpha|float|Use the base alpha to desaturate the base texture. Set to non-zero to enable, value gets multiplied into the alpha channel before desaturating.|since={{as}}}} | |||
| {{MatParamDef|$notint|bool|Prevents the model's material from being tinted by [[$color2]] or <code>rendercolor.</code>|only={{csgo}}|also={{P2CE}}}} | |||
| === Transparency === | |||
| '''VertexLitGeneric''' support a few different methods for transparency, each for different purposes | |||
| {{MatParamDef|$alpha|bool|[[$alpha]] [[Cheap|Cheaply]] scales the opacity of an entire material.{{confirm|Does this work in any engine branch? It does not in {{src13mp}}.}}}} | |||
| {{MatParamDef|$alphatest|bool|[[$alphatest]] is a [[Cheap]] transparency using a binary opacity mask.}} | |||
| {{MatParamDef|$nocull|bool|[[$nocull]] disables backface culling optimization.}} | |||
| :  | {{MatParamDef|$translucent|bool|[[$translucent]] is a [[Expensive|expensive]] translucency using a full [[Alpha]] mask, for very fine gradients.<br/>{{note|Add material sorting issues}}}} | ||
| {{MatParamDef|$additive|bool|[[$additive]] alike [[$translucent]] perform full [[Alpha]] mask, however it add colors instead of performing a multiplication. This renders in a always brighter material.}} | |||
| {{MatParamDef|$distancealpha|bool|[[$distancealpha]] is a vector-like edge filtering.|since={{src07}}}} | |||
| === Lighting === | |||
| {{MatParamDef|$bumpmap|texture| [[Bump_map|Normal map]].}} | |||
| {{MatParamDef|$lightwarptexture|texture|1 dimension Per-texel color modification via a [[$lightwarptexture|warp texture]].|since={{src06}}}} | |||
| {{MatParamDef|$halflambert|bool|Use [[$halflambert|Half-lambertian]] shading.}} | |||
| {{MatParamDef|$selfillum|bool|Determines whether the surface is [[Glowing_Textures#.24selfillum|self-illuminated]] independent of environment lighting.}} | |||
| {{MatParamDef|$emissiveblendenabled|bool|[[Glowing_Textures#.24emissiveblend|Advanced flowing self-illumination]], used on the [[Vortigaunt|Vortigaunts]] in {{hl2ep2|1}}.|since={{src07}}}} | |||
| {{MatParamDef|$lightmap|texture|Pre-baked [[lightmap]]; subject to [[$lightmap#Limitations_and_caveats|limitations]].|since={{src13mp}}|also={{gmod}}}} | |||
| === Reflection === | |||
| {{MatParamDef|$envmap|texture|[[$envmap|Specular reflections]].}} | |||
| {{MatParamDef|$phong|bool|[[$phong|Diffuse reflections]].|since={{src06}}}} | |||
| {{MatParamDef|$rimlight|bool|Constant [[$rimlight|rimlight]] based on [[phong]] and the ambient lighting.|since={{src07}}}} | |||
| === Effect === | |||
| {{MatParamDef|$compress|texture|[[Wrinkle_maps#Materials_and_textures|Wrinklemaps]] for character faces.|since={{src07}}}} | |||
| {{MatParamDef|$stretch|texture|[[Wrinkle_maps#Materials_and_textures|Wrinklemaps]] for character faces.|since={{src07}}}} | |||
| {{MatParamDef|$flesh|bool|The [[$flesh|flesh]] effect used for Alyx in Half-Life 2: Episode Two.|since={{src07}}}} | |||
| {{MatParamDef|$treeSway|bool|Vertex manipulation to give the effect of [[$treeSway|trees swaying]] in the wind.|since={{l4d}}|also={{tf2}}{{mapbase}}{{gmod}}{{bms}}}} | |||
| === Technical Workarounds === | |||
| {{MatParamDef|$flashlightnolambert|bool|Tell [[env_projectedtexture|projected textures]] such as the flashlight to ignore the surface normal of the model. Useful for models with {{ent|$nocull}} such as foilage. Otherwise, lighting the face with a flashlight from behind will not affect it. ''Default 0''.|since={{src07}}}} | |||
| {{MatParamDef|$lowqualityflashlightshadows|bool|Force low quality flashlight/projected texture shadows for faster performance.|since={{portal2}}}} | |||
| {{MatParamDef|$allowfencerenderstatehack|bool|Fence render hack for cascade shadow maps, allows shadow maps to work properly with fences.|since={{csgo}}}} | |||
| {{MatParamDef|$disablecsmlookup|bool|Disable cascade shadow map lookup/filtering, useful on dense foilage.|since={{csgo}}}} | |||
| {{MatParamDef|$noshadowpass|bool|Allows turning off the shadow pass of this material.|only={{lw}}}} | |||
| {{MatParamDef|$nodeferredlight|bool|No deferred light input.|only={{lw}}}} | |||
| {{MatParamDef|$modelglobalnormal|bool|Use global light direction as normal for all model vertices.|only={{lw}}}} | |||
| ===Cloak=== | |||
| <code>VertexLitGeneric</code> natively supports the Spy cloak effect from {{tf2|1}}. Combine it with a sine wave [[Material Proxies|proxy]] for the full effect. | |||
| {{MatParamDef|$cloakpassenabled|bool|Enables cloaking effects. {{warning|Enabling this on static props causes a heavy performance penalty, even if the cloak effect itself isn't being used!}}}} | |||
| {{MatParamDef|$cloakfactor|normal|0.00 {{=}} fully visible,<br/> | |||
| 1.00 {{=}} fully invisible.}} | |||
| {{MatParamDef|$cloakcolortint|RGB matrix|Colors the refraction effect. ''Default " [ 1 1 1 ] "''.}} | |||
| {{MatParamDef|$refractamount|float|How strong the refraction effect should be when the material is partially cloaked. ''Default 2''.}} | |||
| == Caveats == | |||
| === Mapbase === | |||
| VertexLitGeneric materials in [[Mapbase]] should have the shader '''<code>SDK_VertexLitGeneric</code>'''. | |||
| == See also == | == See also == | ||
| * [[Materials_for_models#Compiling_your.VMT_:_Valve_Material_Type|Materials for models]] | * [[Materials_for_models#Compiling_your.VMT_:_Valve_Material_Type|Materials for models]] | ||
| * | *{{ent|EyeRefract}}, the shader for modeled eyes. | ||
| * | *{{ent|Teeth}}, the shader for modeled teeth. | ||
Latest revision as of 11:17, 23 September 2025
VertexLitGeneric  is a   Vertex shader  available in all  Source games. It is the shader most commonly used to render models, and supports a variety of effects. Do not use this on world geometry, else you may encounter lighting bugs.
 Source games. It is the shader most commonly used to render models, and supports a variety of effects. Do not use this on world geometry, else you may encounter lighting bugs.
Supported Parameters
Basics
$basetexture defines diffuse texture.
Use a 2nd UV channel for high-resolution decal support.
Adjustment
Transform $basetexture's alignment, scale, rotation and position.
Prevents the model's material from being tinted by $color2 or 
rendercolor.Todo: Confirm use of texcoord1 for detail texture
Use the base alpha to desaturate the base texture. Set to non-zero to enable, value gets multiplied into the alpha channel before desaturating.
Prevents the model's material from being tinted by $color2 or 
rendercolor.Transparency
VertexLitGeneric support a few different methods for transparency, each for different purposes
$alphatest is a Cheap transparency using a binary opacity mask.
$translucent is a expensive translucency using a full Alpha mask, for very fine gradients.
 Note:Add material sorting issues
Note:Add material sorting issues
 Note:Add material sorting issues
Note:Add material sorting issues$additive alike $translucent perform full Alpha mask, however it add colors instead of performing a multiplication. This renders in a always brighter material.
$distancealpha is a vector-like edge filtering.
Lighting
1 dimension Per-texel color modification via a warp texture.
Use Half-lambertian shading.
Determines whether the surface is self-illuminated independent of environment lighting.
Pre-baked lightmap; subject to limitations.
Reflection
Effect
Wrinklemaps for character faces.
Wrinklemaps for character faces.
Vertex manipulation to give the effect of trees swaying in the wind.
Technical Workarounds
Tell projected textures such as the flashlight to ignore the surface normal of the model. Useful for models with $nocull such as foilage. Otherwise, lighting the face with a flashlight from behind will not affect it. Default 0.
Force low quality flashlight/projected texture shadows for faster performance.
Fence render hack for cascade shadow maps, allows shadow maps to work properly with fences.
Disable cascade shadow map lookup/filtering, useful on dense foilage.
Allows turning off the shadow pass of this material.
No deferred light input.
Use global light direction as normal for all model vertices.
Cloak
VertexLitGeneric natively supports the Spy cloak effect from Team Fortress 2. Combine it with a sine wave proxy for the full effect.
Enables cloaking effects.  Warning:Enabling this on static props causes a heavy performance penalty, even if the cloak effect itself isn't being used!
Warning:Enabling this on static props causes a heavy performance penalty, even if the cloak effect itself isn't being used!
 Warning:Enabling this on static props causes a heavy performance penalty, even if the cloak effect itself isn't being used!
Warning:Enabling this on static props causes a heavy performance penalty, even if the cloak effect itself isn't being used!0.00 = fully visible,
1.00 = fully invisible.
1.00 = fully invisible.
Colors the refraction effect. Default " [ 1 1 1 ] ".
How strong the refraction effect should be when the material is partially cloaked. Default 2.
Caveats
Mapbase
VertexLitGeneric materials in Mapbase should have the shader SDK_VertexLitGeneric.
See also
- Materials for models
- EyeRefract, the shader for modeled eyes.
- Teeth, the shader for modeled teeth.
































 Confirm:
 Confirm:






