LightmappedGeneric: Difference between revisions
		
		
		
		
		
		Jump to navigation
		Jump to search
		
				
		 
	
	
	
	
	
	
 Confirm:Is this for LW's Blinn–Phong reflections?
 Confirm:Is this for LW's Blinn–Phong reflections?
	
 Confirm:Is this for LW's Blinn–Phong reflections?
 Confirm:Is this for LW's Blinn–Phong reflections?
		
	
| mNo edit summary | No edit summary | ||
| (One intermediate revision by one other user not shown) | |||
| Line 7: | Line 7: | ||
| === Basics === | === Basics === | ||
| {{ | {{MatParamDef|$basetexture|texture|Defines an [[diffuse]] texture.}} | ||
| {{ | {{MatParamDef|$decal|bool|Use this material as a decal.}} | ||
| {{ | {{MatParamDef|$detail|texture|Detail texturing.}} | ||
| {{ | {{MatParamDef|$surfaceprop|string|Links the surface to a set of physical properties.}} | ||
| === Adjustment === | === Adjustment === | ||
| {{ | {{MatParamDef|$basetexturetransform|matrix| Transforms the texture before use in the material. This does not affect [[lightmap]]s on the surface. }} | ||
| {{ | {{MatParamDef|$color|RGB matrix|Independently scales the red, green and blue channels of an albedo. | ||
| {{bug|Greyscale materials using $color as a sole source of tint will not appear colored under light cast by the player flashlight (or a projected texture). This results in textures appearing grey and desaturated. A workaround for this is to add a base grey [[$detail]] to the material and then and then use [[$detailtint]] to color it.|tested={{src13sp}}, {{src13mp}}}}}} | {{bug|Greyscale materials using $color as a sole source of tint will not appear colored under light cast by the player flashlight (or a projected texture). This results in textures appearing grey and desaturated. A workaround for this is to add a base grey [[$detail]] to the material and then and then use [[$detailtint]] to color it.|tested={{src13sp}}, {{src13mp}}}}}} | ||
| {{ | {{MatParamDef|$decalscale|float|Same as a brush face's texture scale value: the number of [[unit|units]] that each [[texel]] covers. Normally 0.25 or lower. }} | ||
| {{ | {{MatParamDef|$detailscale|float|Fits the detail texture onto the material the given number of times (default {{=}} 4). Generally used instead of {{mono|$detailtexturetransform}} with a value of around 7 or 8 for a 128px detail texture. To independently scale the X and Y coordinates, place your values in brackets: {{mono|$detailscale "[ 4 8 ]"}}}} | ||
| {{ | {{MatParamDef|$detailblendfactor|normal|Controls the amount that the detail texture affects the base texture. The precise use of this depends on the blend factor; in most cases it acts similarly to [[$alpha]]. A value of 0 usually makes the detail texture have no effect, whilst a value of 1 applies the full effect.}} | ||
| {{ | {{MatParamDef|$detailblendmode|int|How to combine the detail material with the albedo.}} | ||
| {{ | {{MatParamDef|$modelmaterial|material|A separate [[VertexLitGeneric]] material to that will replace this one if the decal hits a [[Model|model]]. }} | ||
| {{ | {{MatParamDef|$pointsamplemagfilter|bool|only={{csgo}}{{jbep3}}|Disables texture filtering.}} | ||
| {{ | {{MatParamDef|$seamless_scale|since={{src07}}|float|Mitigation for displacement texture stretching.}} | ||
| === Transparency === | === Transparency === | ||
| {{ | {{MatParamDef|$alpha|float|Scales the opacity of an entire material. | ||
| {{modernImportant|Can result in alpha sorting issues if brush is flagged as detail or tied to an entity!}}}} | {{modernImportant|Can result in alpha sorting issues if brush is flagged as detail or tied to an entity!}}}} | ||
| {{ | {{MatParamDef|$alphatest|bool|Specifies a mask to use to determine binary opacity.}} | ||
| {{ | {{MatParamDef|$distancealpha|since={{src07}}|bool|Vector-like edge filtering.}} | ||
| {{ | {{MatParamDef|$nocull|bool|Disables backface culling.}} | ||
| {{ | {{MatParamDef|$translucent|bool|Specifies that the material should be partially see-through. | ||
| {{modernImportant|Can result in alpha sorting issues if brush is flagged as detail or tied to an entity!}}}} | {{modernImportant|Can result in alpha sorting issues if brush is flagged as detail or tied to an entity!}}}} | ||
| === Lighting === | === Lighting === | ||
| {{ | {{MatParamDef|$bumpmap|texture|Specifies a texture that will provide three-dimensional lighting information for a material.}} | ||
| {{ | {{MatParamDef|$blendmodulatetexture|since={{src06}}|texture|Control sharpness and bias of blend. See [[Blendmodulate]]}} | ||
| {{ | {{MatParamDef|$lightwarptexture|since={{src06}}|texture|Per-texel color modification via a warp texture.   | ||
| {{Note|Does not appear to be featured on {{ent|LightmappedGeneric}} in {{csgobranch|4}}.}}}} | {{Note|Does not appear to be featured on {{ent|LightmappedGeneric}} in {{csgobranch|4}}.}}}} | ||
| {{ | {{MatParamDef|$selfillum|bool|Determines whether the surface is self-illuminated independent of environment lighting.}} | ||
| {{ | {{MatParamDef|$ssbump|since={{src07}}|bool|Flags the {{ent|$bumpmap}} as being a self-shadowing bumpmap.}} | ||
| === Reflection === | === Reflection === | ||
| {{ | {{MatParamDef|$envmap|cubemap|Specular reflections.}} | ||
| {{ | {{MatParamDef|$phong|since={{csgo}}|also={{GMOD}}{{mapbase}}|bool|Diffuse reflections. | ||
| {{note|Phong is reflected only from [[env_cascade_light]].}} | {{note|Phong is reflected only from [[env_cascade_light]].}} | ||
| :{{todo|Are there reflections from any other light sources?.}}   | :{{todo|Are there reflections from any other light sources?.}}   | ||
| {{warning|Standard phong color is always white and doesn't depend on the color of [[light_environment]] or [[env_cascade_light]].}} | {{warning|Standard phong color is always white and doesn't depend on the color of [[light_environment]] or [[env_cascade_light]].}} | ||
| {{bug|Normal map does not affect phong reflections if there is empty $envmap on the material, or if you haven't assigned any brush face on [[env_cubemap]] entity.}}}} | {{bug|Normal map does not affect phong reflections if there is empty $envmap on the material, or if you haven't assigned any brush face on [[env_cubemap]] entity.}}}} | ||
| {{ | {{MatParamDef|$phong_exp|only={{lw}}|float|{{confirm|Is this for LW's Blinn–Phong reflections?}}}} | ||
| {{ | {{MatParamDef|$phong_exp2|only={{lw}}|float|{{confirm|Is this for LW's Blinn–Phong reflections?}}}} | ||
| ==={{portal2}}Paint=== | ==={{portal2}}Paint=== | ||
| {{ | These parameters can be used in any LightmappedGeneric material, and will affect the appearance of paint applied on top of that specific material. All materials that do not specify these will use the code-defined defaults. | ||
| {{ | {{MatParamDef|$paintsplatnormalmap|texture|The paint splat normal map to use when paint is applied to the material. Defaults to <code>paint/splatnormal_default</code> if not specified.}} | ||
| {{ | {{MatParamDef|$paintsplatbubblelayout|texture|The layout texture which defines the distribution of bubbles in the paint. Defaults to <code>paint/bubblelayout</code> if not specified.}} | ||
| {{ | {{MatParamDef|$paintsplatbubble|texture|The normal mapped texture of a single bubble. Defaults to <code>paint/bubble</code> if not specified.}} | ||
| {{MatParamDef|$paintenvmap|texture|The environment map reflected in the paint. Defaults to <code>paint/paint_envmap_hdr</code> if not specified.}} | |||
| === Texture Organization === | === Texture Organization === | ||
| {{ | {{MatParamDef|%keywords|string|Sets keywords <i>(comma separated)</i> filter that can be filtered in hammer for easier texture finding.{{example|<code>%keywords "wasteland,c17"</code> place the material under the <i>"wasteland"</i> and <i>"c17"</i> filters.}} }} | ||
| {{ | {{MatParamDef|%notooltexture|bool|Hides the material from Hammer's texture browser.{{warning|Non-functional in {{hammer++|4.1}}.}} }} | ||
| {{ | {{MatParamDef|%tooltexture|texture|Used to blend texture previews in [[Hammer]].}} | ||
| === Effect === | === Effect === | ||
| {{ | {{MatParamDef|$nofog|bool|Prevents fog from overdrawing a material.}} | ||
| == Caveats == | == Caveats == | ||
Latest revision as of 11:38, 23 August 2025
LightmappedGeneric  is a   Pixel shader  available in all  Source games. It is the shader most commonly used to render lightmapped brushes and displacements.
 Source games. It is the shader most commonly used to render lightmapped brushes and displacements. 
Models cannot use this shader; lightmapped models use the VertexLitGeneric shader.
Supported Parameters
Basics
Defines an diffuse texture.
Links the surface to a set of physical properties.
Adjustment
Transforms the texture before use in the material. This does not affect lightmaps on the surface.
Independently scales the red, green and blue channels of an albedo.
 Bug:Greyscale materials using $color as a sole source of tint will not appear colored under light cast by the player flashlight (or a projected texture). This results in textures appearing grey and desaturated. A workaround for this is to add a base grey $detail to the material and then and then use $detailtint to color it.  (tested in:
Bug:Greyscale materials using $color as a sole source of tint will not appear colored under light cast by the player flashlight (or a projected texture). This results in textures appearing grey and desaturated. A workaround for this is to add a base grey $detail to the material and then and then use $detailtint to color it.  (tested in:  ,
,  )
)
 Bug:Greyscale materials using $color as a sole source of tint will not appear colored under light cast by the player flashlight (or a projected texture). This results in textures appearing grey and desaturated. A workaround for this is to add a base grey $detail to the material and then and then use $detailtint to color it.  (tested in:
Bug:Greyscale materials using $color as a sole source of tint will not appear colored under light cast by the player flashlight (or a projected texture). This results in textures appearing grey and desaturated. A workaround for this is to add a base grey $detail to the material and then and then use $detailtint to color it.  (tested in:  ,
,  )
)Fits the detail texture onto the material the given number of times (default = 4). Generally used instead of $detailtexturetransform with a value of around 7 or 8 for a 128px detail texture. To independently scale the X and Y coordinates, place your values in brackets: $detailscale "[ 4 8 ]"
Controls the amount that the detail texture affects the base texture. The precise use of this depends on the blend factor; in most cases it acts similarly to $alpha. A value of 0 usually makes the detail texture have no effect, whilst a value of 1 applies the full effect.
How to combine the detail material with the albedo.
A separate VertexLitGeneric material to that will replace this one if the decal hits a model.
Disables texture filtering.
Mitigation for displacement texture stretching.
Transparency
Scales the opacity of an entire material.
 Important:Can result in alpha sorting issues if brush is flagged as detail or tied to an entity!
Important:Can result in alpha sorting issues if brush is flagged as detail or tied to an entity!
 Important:Can result in alpha sorting issues if brush is flagged as detail or tied to an entity!
Important:Can result in alpha sorting issues if brush is flagged as detail or tied to an entity!Specifies a mask to use to determine binary opacity.
Vector-like edge filtering.
Specifies that the material should be partially see-through.
 Important:Can result in alpha sorting issues if brush is flagged as detail or tied to an entity!
Important:Can result in alpha sorting issues if brush is flagged as detail or tied to an entity!
 Important:Can result in alpha sorting issues if brush is flagged as detail or tied to an entity!
Important:Can result in alpha sorting issues if brush is flagged as detail or tied to an entity!Lighting
Specifies a texture that will provide three-dimensional lighting information for a material.
Control sharpness and bias of blend. See Blendmodulate
Per-texel color modification via a warp texture. 
 Note:Does not appear to be featured on LightmappedGeneric in
Note:Does not appear to be featured on LightmappedGeneric in  CS:GO engine branch.
 CS:GO engine branch.
 Note:Does not appear to be featured on LightmappedGeneric in
Note:Does not appear to be featured on LightmappedGeneric in  CS:GO engine branch.
 CS:GO engine branch.Determines whether the surface is self-illuminated independent of environment lighting.
Reflection
Diffuse reflections.
 Note:Phong is reflected only from env_cascade_light.
Note:Phong is reflected only from env_cascade_light.
 Warning:Standard phong color is always white and doesn't depend on the color of light_environment or env_cascade_light.
Warning:Standard phong color is always white and doesn't depend on the color of light_environment or env_cascade_light.
 Bug:Normal map does not affect phong reflections if there is empty $envmap on the material, or if you haven't assigned any brush face on env_cubemap entity.  [todo tested in ?]
Bug:Normal map does not affect phong reflections if there is empty $envmap on the material, or if you haven't assigned any brush face on env_cubemap entity.  [todo tested in ?]
 Note:Phong is reflected only from env_cascade_light.
Note:Phong is reflected only from env_cascade_light.- Todo: Are there reflections from any other light sources?.
 Warning:Standard phong color is always white and doesn't depend on the color of light_environment or env_cascade_light.
Warning:Standard phong color is always white and doesn't depend on the color of light_environment or env_cascade_light. Bug:Normal map does not affect phong reflections if there is empty $envmap on the material, or if you haven't assigned any brush face on env_cubemap entity.  [todo tested in ?]
Bug:Normal map does not affect phong reflections if there is empty $envmap on the material, or if you haven't assigned any brush face on env_cubemap entity.  [todo tested in ?] Confirm:Is this for LW's Blinn–Phong reflections?
 Confirm:Is this for LW's Blinn–Phong reflections? Confirm:Is this for LW's Blinn–Phong reflections?
 Confirm:Is this for LW's Blinn–Phong reflections? Paint
Paint
These parameters can be used in any LightmappedGeneric material, and will affect the appearance of paint applied on top of that specific material. All materials that do not specify these will use the code-defined defaults.
The paint splat normal map to use when paint is applied to the material. Defaults to 
paint/splatnormal_default if not specified.The layout texture which defines the distribution of bubbles in the paint. Defaults to 
paint/bubblelayout if not specified.The normal mapped texture of a single bubble. Defaults to 
paint/bubble if not specified.The environment map reflected in the paint. Defaults to 
paint/paint_envmap_hdr if not specified.Texture Organization
Sets keywords (comma separated) filter that can be filtered in hammer for easier texture finding. Example:
Example:
 Example:
Example:%keywords "wasteland,c17" place the material under the "wasteland" and "c17" filters.Hides the material from Hammer's texture browser. Warning:Non-functional in
Warning:Non-functional in  Hammer++.
 Hammer++.
 Warning:Non-functional in
Warning:Non-functional in  Hammer++.
 Hammer++.Used to blend texture previews in Hammer.
Effect
Caveats
Mapbase
LightmappedGeneric materials in Mapbase should have the shader SDK_LightmappedGeneric.
See also
- WorldVertexTransition, a shader used on displacements to blend two materials together.
- LightmappedTwoTexture, a brush shader that multiplies a texture on top of another one.
- Lightmapped_4WayBlend, a shader used on displacements to blend up to four materials together.
































