$detail: Difference between revisions
|  (The effect is useable in all Source Engine based games.) | |||
| Line 4: | Line 4: | ||
| [[Image:Detail.jpg|frame|right|A detail texture (noise_detail_01), and its effect when applied to a material (left).]] | [[Image:Detail.jpg|frame|right|A detail texture (noise_detail_01), and its effect when applied to a material (left).]] | ||
| '''$detail''' specifies a [[texture]] with which Source will add high-resolution detail when the material is viewed up close, by darkening the [[albedo]] appropriately. It is very effective for increasing the apparent resolution of a texture, and was used extensively in [[Episode Two]]. | '''$detail''' specifies a [[texture]] with which Source will add high-resolution detail when the material is viewed up close, by darkening the [[albedo]] appropriately. It is very effective for increasing the apparent resolution of a texture, and was used extensively in [[Episode Two]]. The effect is useable in all Source Engine based games. | ||
Revision as of 04:09, 20 January 2013
$detail specifies a texture with which Source will add high-resolution detail when the material is viewed up close, by darkening the albedo appropriately. It is very effective for increasing the apparent resolution of a texture, and was used extensively in Episode Two. The effect is useable in all Source Engine based games.
 Bug:Detail textures do not currently work in conjunction with $seamless_scale. Enabling them to work together would require a programmer to edit the used shader.  [todo tested in ?]
Bug:Detail textures do not currently work in conjunction with $seamless_scale. Enabling them to work together would require a programmer to edit the used shader.  [todo tested in ?]Syntax
$detail <texture>
You will probably want to use at least $detailscale (see below) as well.
Additional parameters
- $detailtexturetransform <matrix>
- Rotates, scales, etc. the detail texture. Requires DX9.
- 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 ?]
 
- $detailscale <float>
- Fits the detail texture onto the material the given number of times (default = 4). Generally used instead of $detailtexturetransformwith a value of around 7 or 8 for a 128px detail texture.
- $detailblendfactor <normal>
- Effectively an $alphavalue for the detail texture.
- $detailblendmode <int>
- How to combine the detail material with the albedo.
- 0 = normal (darken)
- 1 = additive (lighten)
- 2 = alpha blend detail over base
- 3 = crossfade
- 4 = overlays over alpha map
 
- $detailtint "<RGB matrix>"
- Modifies the colour of the detail texture.
- $detailframe <int>
- The frame to start animated detail texture on. Requires DX9.
- $detail_alpha_mask_base_texture <bool>
- WorldVertexTransitiononly. When enabled, causes the level of detail alpha to determine "base texture blending".Todo: Which base texture?
Valve's detail textures
Valve's stock detail textures (available in OB only) are best used with the following pre-configured values:
$detail detail\noise_detail_01 // e.g. for brickwork, concrete... $detailscale 7.74 $detailblendfactor 0.8 $detailblendmode 0
$detail detail\metal_detail_01 $detailscale 4.283 $detailblendfactor .65 $detailblendmode 0
$detail detail\rock_detail_01 $detailscale 11 $detailblendfactor 1 $detailblendmode 0
$detail detail\plaster_detail_01 $detailscale 6.783 $detailblendfactor .8 $detailblendmode 0
The below parameters come from models\props_forest\LadderWood.vmt
It is the only Valve Stock texture VMT file to use this particular detail texture. 
Because the detail texture (detail\wood_detail_01) is a high resolution (1024x1024), the $detailscale is lower than the others. With the exception of rock_detail_01.
$detail detail\wood_detail_01 $detailscale 2.563 $detailblendfactor .8 $detailblendmode 0
Additionally, there are 2 other stock detail textures. detail\detailash001a and detail\detaildirt001a.
These files were used in the "leaked" version of Half-Life 2 & in Half-Life 2: Episode One using the following parameters;
(Concrete/concretefloor009a in Episode One materials)
$detail detail/detaildirt001a $detailscale 0.27
(Metal/metalfloor005a in Episode One materials)
$detail detail/detailash001a $detailscale 0.50

