UnlitTwoTexture: Difference between revisions
| Zeldaboy14 (talk | contribs) No edit summary | |||
| (One intermediate revision by the same user not shown) | |||
| Line 9: | Line 9: | ||
| == Parameters == | == Parameters == | ||
| {{ | {{MatParamDef|$basetexture|texture|}} | ||
| The first Texture that is used, how it is used depends on the effects which are enabled. | |||
| By default <code>$basetexture</code> will be multiplied with <code>$texture2</code>. | The first Texture that is used, how it is used depends on the effects which are enabled. By default <code>$basetexture</code> will be multiplied with <code>$texture2</code>. | ||
| {{ | |||
| {{ | {{MatParamDef|$frame|int|The frame to start an animated <code>$texture2</code> on.}} | ||
| {{ | {{MatParamDef|$basetexturetransform|matrix|Transforms the texture before use in the material. {{VMT UVtransform}} }} | ||
| Second Texture that is used in different ways depending on which effects are used. | |||
| By default <code>$basetexture</code> will be multiplied with <code>$texture2</code>. | {{MatParamDef|$texture2|texture|}} | ||
| Second Texture that is used in different ways depending on which effects are used. By default <code>$basetexture</code> will be multiplied with <code>$texture2</code>. | |||
| {{note|First texture is applied via {{ent|$basetexture}}.}} | {{note|First texture is applied via {{ent|$basetexture}}.}} | ||
| {{ | |||
| {{ | {{MatParamDef|$frame2|int|The frame to start an animated <code>$texture2</code> on.}} | ||
| {{ | {{MatParamDef|$texture2transform|matrix|Transforms the texture before use in the material. {{VMT UVtransform}} }} | ||
| {{ | |||
| {{MatParamDef|$color|RGB matrix|tints the result, on brushes.}} | |||
| {{ | |||
| {{MatParamDef|$color2|RGB matrix|tints the result, on models.}} | |||
| {{MatParamDef|$beachfoam|bool|Introduced with Dangerzone, adds animated wave-like effects using a special texture|only={{csgo}}}} | |||
| {{important|This parameter is intended to be used with {{ent|$additive}}.}} | {{important|This parameter is intended to be used with {{ent|$additive}}.}} | ||
| On the Dangerzone Wave Model, both <code>$texture2</code> and <code>$basetexture</code> use the 'Beachwaves' Texture. | On the Dangerzone Wave Model, both <code>$texture2</code> and <code>$basetexture</code> use the 'Beachwaves' Texture. | ||
| {{todo|Do both Parameters need to use the same Texture?}} | {{todo|Do both Parameters need to use the same Texture?}} | ||
| The 'Beachwaves' Texture uses the RGB channels for different purposes. | The 'Beachwaves' Texture uses the RGB channels for different purposes. | ||
| <small>{{todo|Find a better Name for the Texture...}}</small> | <small>{{todo|Find a better Name for the Texture...}}</small> | ||
| * Red Channel : Waves Albedo Texture | * Red Channel : Waves Albedo Texture | ||
| {{todo|Can this be tinted using $color/$color2?}} | {{todo|Can this be tinted using $color/$color2?}} | ||
| Line 36: | Line 48: | ||
| * Blue Channel : Distortion/Noise for the Red Channel | * Blue Channel : Distortion/Noise for the Red Channel | ||
| {{todo|Further documentation required.}} | {{todo|Further documentation required.}} | ||
| {{MatParamDef|$CrosshairMode|bool| Enables "Crosshair mode" using <code>$basetexture</code> for the Crosshair|only={{csgo}}}} | |||
| {{ | |||
| <code>$texture2</code> is used for a framebuffer texture. | <code>$texture2</code> is used for a framebuffer texture. | ||
| The result will be blended between <code>Crosshair Texture + CrosshairTint</code> and <code>Crosshair Texture * CrosshairTint</code> using <code>Average Luminance of $texture2 * $CrosshairColorAdapt</code> | The result will be blended between <code>Crosshair Texture + CrosshairTint</code> and <code>Crosshair Texture * CrosshairTint</code> using <code>Average Luminance of $texture2 * $CrosshairColorAdapt</code> | ||
| {{ | |||
| {{ | {{MatParamDef|$CrosshairTint|RGB matrix| Tints the <code>$basetexture</code> when using <code>$CrosshairMode</code>|only={{csgo}}}} | ||
| {{ | |||
| {{MatParamDef|$CrosshairColorAdapt|float|Used for multiplying the average Luminance of <code>$texture2</code> <br>{{note|Default Value <code>"0.4"</code>}}|only={{csgo}}}} | |||
| ===Example=== | {{MatParamDef|$translucent|bool|[[$translucent]] is a [[Expensive|expensive]] translucency using a full [[Alpha]] mask, for very fine gradients. Uses [[$basetexture]] as the source alpha, and blends [[$texture2]]'s alpha over whatever is opaque.</code>|since={{l4d}}}} | ||
| === Example === | |||
| Stock .vmt | Stock .vmt | ||
| {{path|hl2/materials/models/props_combine/portalball001_sheet|vmt}} | {{path|hl2/materials/models/props_combine/portalball001_sheet|vmt}} | ||
Latest revision as of 23:10, 14 September 2025
- Two base textures are multiplied together and can be transformed independently. (Just like the Multiply blending mode in typical image editors.)
- Unrelated to WorldVertexTransition, which is used for making alpha fading transitions between two base textures on displacements.
 Note:This Shader works on both Brushes and Models
Note:This Shader works on both Brushes and Models Confirm: Do models require $model in branches before
 Confirm: Do models require $model in branches before  ?
? Tip:The same effect can be created using
Tip:The same effect can be created using $detailblendmode 8 on UnlitGeneric.Parameters
The first Texture that is used, how it is used depends on the effects which are enabled. By default $basetexture will be multiplied with $texture2.
- 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 ?]
 
Second Texture that is used in different ways depending on which effects are used. By default $basetexture will be multiplied with $texture2.
 Note:First texture is applied via $basetexture.
Note:First texture is applied via $basetexture.- 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 ?]
 
 Important:This parameter is intended to be used with $additive.
Important:This parameter is intended to be used with $additive.On the Dangerzone Wave Model, both $texture2 and $basetexture use the 'Beachwaves' Texture.
The 'Beachwaves' Texture uses the RGB channels for different purposes.
- Red Channel : Waves Albedo Texture
- Green Channel : Distortion/Noise for the Red Channel
- Blue Channel : Distortion/Noise for the Red Channel
$basetexture for the Crosshair$texture2 is used for a framebuffer texture.
The result will be blended between Crosshair Texture + CrosshairTint and Crosshair Texture * CrosshairTint using Average Luminance of $texture2 * $CrosshairColorAdapt
$basetexture when using $CrosshairMode$texture2  Note:Default Value
Note:Default Value "0.4"Example
Stock .vmt

hl2/materials/models/props_combine/portalball001_sheet.vmt
"UnlitTwoTexture"
{
	"$basetexture" "models/props_combine/portalball001_sheet"
	"$texture2" "models/props_combine/portalball001b_sheet"
 	"$model" 1
	"$nocull" "1"
	"$additive" "1"
	"Proxies"
	{
		"TextureScroll"
		{
			"texturescrollvar" "$texture2transform"
			"texturescrollrate" -.2
			"texturescrollangle" 60
		}
	}
} 
 
models/props/hr_massive/beachwaves/beachwaves.vmt
UnlitTwoTexture
{
    "$beachfoam"   "1"
    "$basetexture" "models/props/hr_massive/beachwaves/beachwaves"
    "$texture2"    "models/props/hr_massive/beachwaves/beachwaves"
    "$additive"    "1"
} 
 
effects/smoke_plumes_anim.vmt
UnLitTwoTexture
{
"%tooltexture" "effects/smoke_plumes_00"
$basetexture "effects/smoke_plumes_scroll"
$texture2 "effects/smoke_plumes_00"
$translucent 1
$nocull 1
$no_fullbright 1
$nofog 1
$scale "[1 1]"
$scroll "[2 2]"
Proxies
{
LinearRamp
{
resultVar "$scroll[0]"
rate -.01
}
LinearRamp
{
resultVar "$scroll[1]"
rate .035
}
TextureTransform
{
scaleVar $scale
translateVar $scroll
resultVar $basetexturetransform
}
}
}