LightmappedReflective: Difference between revisions
		
		
		
		
		
		Jump to navigation
		Jump to search
		
				
		 Warning:All parameters listed in the example (except $bumpframe, %tooltexture and $surfaceprop) must be included when used, or func_reflective_glass may not work properly.
Warning:All parameters listed in the example (except $bumpframe, %tooltexture and $surfaceprop) must be included when used, or func_reflective_glass may not work properly.  Counter-Strike: Global Offensive additionally requires $translucent.
 Counter-Strike: Global Offensive additionally requires $translucent.
 Important:This shader must be used on a brush tied to a func_reflective_glass, or the real time reflections will fail to work and it will be rendered as a plain brush.
Important:This shader must be used on a brush tied to a func_reflective_glass, or the real time reflections will fail to work and it will be rendered as a plain brush.
 Bug:In
Bug:In  Black Mesa this shader was missed in the deferred renderer update. To achieve the same effect, use 3D Skybox with logic_measure_movement to simulate reflection[Elaborate?] or use the
 Black Mesa this shader was missed in the deferred renderer update. To achieve the same effect, use 3D Skybox with logic_measure_movement to simulate reflection[Elaborate?] or use the  
 Note:Not available in DirectX 8 and earlier, and lacks shader fallbacks.
Note:Not available in DirectX 8 and earlier, and lacks shader fallbacks.
 Bug:Stops correction and reflection itself if you look at reflective water.  [todo tested in ?]
Bug:Stops correction and reflection itself if you look at reflective water.  [todo tested in ?]
 Bug:Adding proxies to a lightmappedreflective causes the texture to not be drawn. (Could this be because it includes some default proxy in order for it to work, and once there is a user-defined proxy, those "behind the scenes" proxies are no longer there?)  [todo tested in ?]
Bug:Adding proxies to a lightmappedreflective causes the texture to not be drawn. (Could this be because it includes some default proxy in order for it to work, and once there is a user-defined proxy, those "behind the scenes" proxies are no longer there?)  [todo tested in ?]
 Bug:If there is a portal in the reflection in
Bug:If there is a portal in the reflection in  Portal 2 and Portal 2 branch games, it will cause the game to crash. Almost works in The Beginner Guide under the same conditions. This is fixed in
 Portal 2 and Portal 2 branch games, it will cause the game to crash. Almost works in The Beginner Guide under the same conditions. This is fixed in  Portal 2: Community Edition  [todo tested in ?]
 Portal 2: Community Edition  [todo tested in ?]
 Warning:Although this is functional in
Warning:Although this is functional in  Portal, the reflection does not update when viewed through portals and portals will only update in the reflection if both of them are visible to you and to the func_reflective glass. Also, if the portals are rotated differently and viewed through the func_reflective_glass, the portals will display incorrectly. This second bug has carried over into Portal 2 and Portal 2: Community Edition
 Portal, the reflection does not update when viewed through portals and portals will only update in the reflection if both of them are visible to you and to the func_reflective glass. Also, if the portals are rotated differently and viewed through the func_reflective_glass, the portals will display incorrectly. This second bug has carried over into Portal 2 and Portal 2: Community Edition
 Warning:$bumpmap is NOT supported! $normalmap must be used!
Warning:$bumpmap is NOT supported! $normalmap must be used!
		
	
| NvC DmN CH (talk | contribs)  (Adding proxies to a lightmappedreflective causes the texture to not be drawn. This is very weird, and probably suggests there are some automatically included proxies, which arent documented yet. probably.) | No edit summary | ||
| (39 intermediate revisions by 18 users not shown) | |||
| Line 1: | Line 1: | ||
| {{ | {{this is a|pixel shader|since=Source 2007|name=LightmappedReflective|dx=dx9}} This shader renders real-time reflection and refractions similar to [[Water (shader)]]. | ||
| [[File:Reflectiveglass0000.jpg|thumb|250px|{{code|func_reflective_glass}} (using materials with {{code|LightmappedReflective}} shader)]] | |||
| {{warning|All parameters listed in the example (except [[$bumpframe]], [[%tooltexture]] and [[$surfaceprop]]) must be included when used, or [[func_reflective_glass]] may not work properly. {{csgo|4}} additionally requires [[$translucent]].}} | |||
| {{Important|This shader '''''must''''' be used on a brush tied to a {{ent|func_reflective_glass}}, or the real time reflections will fail to work and it will be rendered as a plain brush.}} | |||
| [[ | {{Bug|In {{Bms|4}} this shader was missed in the deferred renderer update. To achieve the same effect, use [[3D Skybox]] with [[logic_measure_movement]] to simulate reflection{{elaborate}} or use the {{Shader Name|Water (shader)|alt=Water}} [[shader]] (see [[True reflections under CSS]]).|hidetested=1}} | ||
| {{note|Not available in [[DirectX Versions|DirectX 8]] and earlier, and lacks [[shader fallback]]s.}} | |||
| == Example == | == Example == | ||
| Line 29: | Line 31: | ||
|   } |   } | ||
| {{bug|Adding proxies to a lightmappedreflective causes the texture to not be drawn. | {{bug|Doesn't support 3D skyboxes, instead of your [[3D Skybox]], the reflection will show a black void.}} | ||
| {{bug|Stops correction and reflection itself if you look at reflective water.}} | |||
| {{bug|Adding proxies to a lightmappedreflective causes the texture to not be drawn. (Could this be because it includes some default proxy in order for it to work, and once there is a user-defined proxy, those "behind the scenes" proxies are no longer there?)}} | |||
| {{bug|If there is a portal in the reflection in {{portal2|4}} and {{portal2|3.1}} branch games, it will cause the game to crash. Almost works in The Beginner Guide under the same conditions. This is fixed in {{p2ce|4}}}} | |||
| {{warning|Although this is functional in {{portal|4}}, the reflection does not update when viewed through portals and portals will only update in the reflection if both of them are visible to you and to the func_reflective glass. Also, if the portals are rotated differently and viewed through the func_reflective_glass, the portals will display incorrectly. This second bug has carried over into {{p2|3.1}} and {{p2ce|3.1}}}} | |||
| == Shader parameters == | |||
| === Textures === | |||
| {{Warning|[[$bumpmap]] is '''''NOT''''' supported! [[$normalmap]] must be used!}} | |||
| {{MatParamDef|$basetexture|texture|[[Diffuse]] texture, optional.}} | |||
| {{MatParamDef|$normalmap|texture|[[bump map]], per-pixel warping of the reflection}} | |||
| {{MatParamDef|$bumpframe|int|Frame to start the animated du/dv map and bump map on, respectively. Somewhat confusingly, <code>$bumpframe</code> affects <code>$''normal''map</code>, which should be pointing to a [[bump map]].}} | |||
| {{MatParamDef|$bumptransform|matrix|Transforms the bump map texture. | |||
| {{VMT UVtransform}}}} | |||
| === Reflection === | |||
| {{MatParamDef|$reflecttexture|texture|Texture to use for reflection. For real-time reflections, use <code>[[_rt_WaterReflection]]</code>.}} | |||
| {{MatParamDef|$reflectamount|float|Amount of warp for the reflection. Higher values produce more warping. Also controls the strenght of the bump map}} | |||
| {{MatParamDef|$reflecttint|RGB matrix|Color tint for the real-time reflection.}} | |||
| {{MatParamDef|$reflectance|float|Controls opacity of reflection. Similar to [[$alpha]]}} | |||
| {{MatParamDef|$envmapmask|texture|Per-pixel opacity of reflection}} | |||
| {{MatParamDef|$minreflectivity|float|{{todo|What is this?}}}} | |||
| {{MatParamDef|$maxreflectivity|float|{{todo|What is this? It seems to do as the name suggests, controls the max reflection strength similar to $reflectance}}}} | |||
| ===Refraction=== | |||
| {{MatParamDef|$refracttexture|texture|Texture to use for refraction. For real-time refractions, use <code>[[_rt_WaterRefraction]]</code>.}} | |||
| {{MatParamDef|$refractamount|float|Amount of warp for the refraction. Higher values produce more warping.}} | |||
| {{MatParamDef|$refracttint|RGB matrix|Color of the refraction. | |||
| : {{warning|It is recommended that you set this to white or something close to white so that edge transitions work properly on DX9.}}}} | |||
| === Other === | |||
| {{MatParamDef|$surfaceprop|name|See [[$surfaceprop]].}} | |||
| {{MatParamDef|%tooltexture|texture|Defines the texture Hammer will display in the material browser.}} | |||
| {{MatParamDef|$fresnelpower|float|Controls fresnel effect of reflections.}} | |||
| {{MatParamDef|$translucent|boolean|Will make the surface both reflective and transparent dependent on the angle and distance of view. | |||
| : {{bug| Must be set to "1" in {{csgo|3.1}}, or the entity shifts its origin to [0 0 0]. | |||
| :: {{note|Fixed in {{Strata|4}}}}}}}} | |||
| [[Category:Shaders]] | |||
Latest revision as of 11:41, 23 August 2025
LightmappedReflective (DX9 SM2) is a   Pixel shader  available in all  Source games since
 Source games since  Source 2007. This shader renders real-time reflection and refractions similar to Water (shader).
 Source 2007. This shader renders real-time reflection and refractions similar to Water (shader).
 Warning:All parameters listed in the example (except $bumpframe, %tooltexture and $surfaceprop) must be included when used, or func_reflective_glass may not work properly.
Warning:All parameters listed in the example (except $bumpframe, %tooltexture and $surfaceprop) must be included when used, or func_reflective_glass may not work properly.  Counter-Strike: Global Offensive additionally requires $translucent.
 Counter-Strike: Global Offensive additionally requires $translucent. Important:This shader must be used on a brush tied to a func_reflective_glass, or the real time reflections will fail to work and it will be rendered as a plain brush.
Important:This shader must be used on a brush tied to a func_reflective_glass, or the real time reflections will fail to work and it will be rendered as a plain brush. Bug:In
Bug:In  Black Mesa this shader was missed in the deferred renderer update. To achieve the same effect, use 3D Skybox with logic_measure_movement to simulate reflection[Elaborate?] or use the
 Black Mesa this shader was missed in the deferred renderer update. To achieve the same effect, use 3D Skybox with logic_measure_movement to simulate reflection[Elaborate?] or use the  
Water shader (see True reflections under CSS). Note:Not available in DirectX 8 and earlier, and lacks shader fallbacks.
Note:Not available in DirectX 8 and earlier, and lacks shader fallbacks.Example
The example shown here is materials/glass/reflectiveglass001.vmt
"lightmappedreflective"
{
	"%tooltexture" "dev/flat_normal"
	"$refracttexture" "_rt_WaterRefraction"
	"$refractamount" "0"
	"$refracttint" "[.5 .5 .6]"
	"$reflecttexture" "_rt_WaterReflection"
	"$reflectamount" "0"
	"$reflecttint" "[1 1 1]"
	"$fresnelpower" "0"
	"$minreflectivity" "0.8"
	"$maxreflectivity" "1.0"
	
	"$normalmap" "dev/flat_normal"
	"$surfaceprop" "glass"
	"$bumpframe" "0"
}
 Bug:Stops correction and reflection itself if you look at reflective water.  [todo tested in ?]
Bug:Stops correction and reflection itself if you look at reflective water.  [todo tested in ?] Bug:Adding proxies to a lightmappedreflective causes the texture to not be drawn. (Could this be because it includes some default proxy in order for it to work, and once there is a user-defined proxy, those "behind the scenes" proxies are no longer there?)  [todo tested in ?]
Bug:Adding proxies to a lightmappedreflective causes the texture to not be drawn. (Could this be because it includes some default proxy in order for it to work, and once there is a user-defined proxy, those "behind the scenes" proxies are no longer there?)  [todo tested in ?] Bug:If there is a portal in the reflection in
Bug:If there is a portal in the reflection in  Portal 2 and Portal 2 branch games, it will cause the game to crash. Almost works in The Beginner Guide under the same conditions. This is fixed in
 Portal 2 and Portal 2 branch games, it will cause the game to crash. Almost works in The Beginner Guide under the same conditions. This is fixed in  Portal 2: Community Edition  [todo tested in ?]
 Portal 2: Community Edition  [todo tested in ?] Warning:Although this is functional in
Warning:Although this is functional in  Portal, the reflection does not update when viewed through portals and portals will only update in the reflection if both of them are visible to you and to the func_reflective glass. Also, if the portals are rotated differently and viewed through the func_reflective_glass, the portals will display incorrectly. This second bug has carried over into Portal 2 and Portal 2: Community Edition
 Portal, the reflection does not update when viewed through portals and portals will only update in the reflection if both of them are visible to you and to the func_reflective glass. Also, if the portals are rotated differently and viewed through the func_reflective_glass, the portals will display incorrectly. This second bug has carried over into Portal 2 and Portal 2: Community EditionShader parameters
Textures
 Warning:$bumpmap is NOT supported! $normalmap must be used!
Warning:$bumpmap is NOT supported! $normalmap must be used!Diffuse texture, optional.
bump map, per-pixel warping of the reflection
Frame to start the animated du/dv map and bump map on, respectively. Somewhat confusingly, 
$bumpframe affects $normalmap, which should be pointing to a bump map.Transforms the bump map texture.
- The default position is center .5 .5 scale 1 1 rotate 0 translate 0 0.- centerdefines the point of rotation. Only useful if- rotateis being used.
- scalefits the texture into the material the given number of times.- 2 1is a 50% scale in the horizontal X axis while the vertical Y axis is still at original scale.
- rotaterotates the texture counter-clockwise in degrees. Accepts any number, including negatives.
- translateshifts the texture by the given numbers.- .5will shift it half-way. 1 will shift it once completely over, which is the same as not moving it at all.
  Note:All values must be included! Note:All values must be included!
 Bug:Scaling the texture may cause odd issues where the Texture Lock tool in Hammer will not actually lock the texture in place.  [todo tested in ?] Bug:Scaling the texture may cause odd issues where the Texture Lock tool in Hammer will not actually lock the texture in place.  [todo tested in ?]
 Bug:Rotating textures applied on brushes will rotate around the map origin (confirm: Orangebox engine only?). A fix for this is to change the center position in the VMT to the brush's origin.  [todo tested in ?] Bug:Rotating textures applied on brushes will rotate around the map origin (confirm: Orangebox engine only?). A fix for this is to change the center position in the VMT to the brush's origin.  [todo tested in ?]
 
Reflection
Texture to use for reflection. For real-time reflections, use 
_rt_WaterReflection.Amount of warp for the reflection. Higher values produce more warping. Also controls the strenght of the bump map
Color tint for the real-time reflection.
Controls opacity of reflection. Similar to $alpha
Per-pixel opacity of reflection
Todo: What is this?
Todo: What is this? It seems to do as the name suggests, controls the max reflection strength similar to $reflectance
Refraction
Texture to use for refraction. For real-time refractions, use 
_rt_WaterRefraction.Amount of warp for the refraction. Higher values produce more warping.
Color of the refraction.
 Warning:It is recommended that you set this to white or something close to white so that edge transitions work properly on DX9. Warning:It is recommended that you set this to white or something close to white so that edge transitions work properly on DX9.
Other
See $surfaceprop.
Defines the texture Hammer will display in the material browser.
Controls fresnel effect of reflections.
Will make the surface both reflective and transparent dependent on the angle and distance of view.
 Bug: Must be set to "1" in Counter-Strike: Global Offensive, or the entity shifts its origin to [0 0 0]. Bug: Must be set to "1" in Counter-Strike: Global Offensive, or the entity shifts its origin to [0 0 0].- [todo tested in ?] Note:Fixed in Note:Fixed in Strata Source Strata Source
 

