Template:KV Light: Difference between revisions

From Valve Developer Community
Jump to navigation Jump to search
(L C and Q. Converted to DL.)
(Appearance should not be used due to performance degradation)
 
(55 intermediate revisions by 20 users not shown)
Line 1: Line 1:
;_light
<onlyinclude>{{KV|Appearance ([[lightstyle]])|intn=style|integer choices|Various lightstyle presets. Cannot be used on named lights.
: <[[color255]] & integer> The color and brightness of the light. RGB colors need to be between 0 and 255. Brightness can be higher.
:{{warning|On modern drivers this will degrade performance by causing frequent stutters. There is no workaround for this other than not using styled lights. The symptoms of this are high spikes in <code>Dynamic Light Rendering</code> when using [[+showbudget]]. When toggling <code>r_dynamiclighting</code> off, these spikes will disappear. [[DXVK]] is not affected by this problem.}}
;style
{{lightstyle presets|underwater not in FGD=1}}}}
:<choices> A preset pattern of diverse flicker effects.
{{KV|Custom Appearance|intn=pattern|string|A string of english letters, like a sequence of piano keys, that define a pattern of brightness. '''a''' is 0%, '''m''' is 100%, and '''z''' is 200%. Updates at 10 Hz. Requires light to have a [[targetname]].}}
:{|
{{minititle|Internal keyvalues used only by [[VRAD]]}}
! Literal Value || Description
{{KV|Brightness|intn=_light|color255 + int|The RGB color of the light, and a multiplicative scalar for brightness (applied after gamma correction). Colors should be between 0 and 255; brightness can be anything (even absent). If only one value is provided, light will be greyscale.}}
|-
:{{note|Brightness values below zero are clamped; this can be fixed by modifying VRAD.{{code fix|In {{file|utils/vrad/lightmap|cpp}}, look for the comment saying "{{code|// make sure light is legal}}", then remove the following if statement, including all its contents.}}}}
| 0 || Normal
{{KV|BrightnessHDR|intn=_lightHDR|color255 + int|RGB color and brightness override used in [[HDR]] mode. Default is <code>-1 -1 -1 1</code>, which means no change.
|-
:{{warning|The fourth digit must be positive. Otherwise all light will be sucked out of your map!}}}}
| 1 || Flicker A
{{KV|BrightnessScaleHDR|intn=_lightHDRscale|float|A simple intensity multiplier used when compiling HDR lighting.}}
|-
:{{note|Unlike {{code|_light}} and {{code|_lightHDR}}, negative values are supported. Negative brightness will suck out the amount of lighting that the equivalent positive brightness would cast. Use sparingly; set falloff to linear instead of quadratic to make it more like an ordinary shadow and less like a black hole. Since this only applies to [[HDR]] mode, it should be reserved for games that don't officially support disabling HDR.}}
| 2 || Slow, strong pulse
{{KV|Constant|intn=_constant_attn|float}}
|-
{{KV|Linear|intn=_linear_attn|float}}
| 3 || Candle A
{{KV|Quadratic|intn=_quadratic_attn|float|These three values determine how the intensity of the emitted light falls off over distance. See [[Constant-Linear-Quadratic Falloff]].}}
|-
{{KV|50 percent falloff distance|intn=_fifty_percent_distance|float}}
| 4 || Fast strobe
{{KV|0 percent falloff distance|intn=_zero_percent_distance|float|Distances at which brightness should have fallen to 50% and (1/256)% respectively. Overrides Linear/Constant/Quadratic parameters if non-zero.
|-
: {{bug|hidetested=1|Using this setting will sometimes not work, which may or may not be related to using the light inside of an [[instance]]. Collapsing the instance and messing with the light's falloff values seems to help.}}}}
| 5 || Gentle pulse
{{KV|Hard falloff|intn=_hardfalloff|bool|Causes lights to fall to exactly zero beyond the 0% distance. May cause unrealistic lighting if not used carefully.}}
|-
{{KV|Cast entity shadows|intn=_castentityshadow|bool|Allows the light to modify the direction of nearby render-to-texture shadows so that they always point away from its origin. See also {{ent|shadow_control}}.
| 6 || Flicker B
: {{Note|This keyvalue may not be available in some [[FGD]]s.}}|since=L4D|also={{GMOD}}}}
|-
{{KV|Shadow cast offset|intn=_shadoworiginoffset|vector|A world-space offset that gets applied to the light origin when casting entity shadows. Useful for dealing with funny-looking shadows from very low lights: Just offset up the z axis. Default <code>0 0 0</code>.
| 7 || Candle B
: {{Note|This keyvalue may not be available in some [[FGD]]s.}}|since=L4D}}</onlyinclude>
|-
 
| 8 || Candle C
[[Category:Keyvalue Templates|Light]]
|-
| 9 || Slow strobe
|-
| 10 || Fluorescent flicker
|-
| 11 || Slow pulse, noblack
|}
:{{note|Applies only to light entities with a [[targetname]].}}
;pattern
: <string> A string of characters defining a custom pattern, '''a''' being most dark and '''z''' being most bright. Think of it as a sequence of Piano keys.
:{{note|Applies only to light entities with a [[targetname]].}}
;_constant_attn
:<float> Influences the light spread to be more constant, by dimming near the source and brightening at the edges. Used in equation with Linear and Quadratic.
;_linear_attn
:<float> Influences the light spread to decrease at a fixed rate. Used in equation with Constant and Quadratic.
;_quadratic_attn
:<float> Influences the light spread to decrease logarithmically, i.e. faster as one moves away from the source. Used in equation with Constant and Linear.
;_distance
:<integer> Stops the light emitted from reaching beyond this distance. Useful in cutting down compiling time by not making lights extend infinitely.
;{{ep1 add|_lightHDR}}
:{{color}} BrightnessHDR. Defaults to <code>-1 -1 -1 1</code>, which tells the compiler to inherit from <code>_light</code>.
:{{warning|The final digit in the default string is positive. Entering four negative numbers will suck the light out of your entire map!}}
;{{ep1 add|_fifty_percent_distance}}
:<float> 50 percent falloff distance
:Distance at which brightness should fall off to 50%. If set, overrides the Linear, Constant and Quadratic parameters.
;{{ep1 add|_zero_percent_distance}}
:<float> 0 percent falloff distance
:Distance at which brightness should fall off to negligible (1/256)%. Must set _fifty_percent_distance to use.

Latest revision as of 10:41, 16 September 2025

Appearance (lightstyle) (style) <integer choices>
Various lightstyle presets. Cannot be used on named lights.
Warning.pngWarning:On modern drivers this will degrade performance by causing frequent stutters. There is no workaround for this other than not using styled lights. The symptoms of this are high spikes in Dynamic Light Rendering when using +showbudget. When toggling r_dynamiclighting off, these spikes will disappear. DXVK is not affected by this problem.
Lightstyle presets (epilepsy warning)
Literal Value Description Sequence Preview
0 Normal m Lightstyle 0.png
10 Fluorescent flicker mmamammmmammamamaaamammma Lightstyle 10.gif
2 Slow, strong pulse abcdefghijklmnopqrstuvwxyzyxwvutsrqponmlkjihgfedcba Lightstyle 2.gif
11 Slow pulse, noblack abcdefghijklmnopqrrqponmlkjihgfedcba Lightstyle 11.gif
5 Gentle pulse jklmnopqrstuvwxyzyxwvutsrqponmlkj Lightstyle 5.gif
1 Flicker A mmnmmommommnonmmonqnmmo Lightstyle 1.gif
6 Flicker B nmonqnmomnmomomno Lightstyle 6.gif
3 Candle A mmmmmaaaaammmmmaaaaaabcdefgabcdefg Lightstyle 3.gif
7 Candle B mmmaaaabcdefgmmmmaaaammmaamm Lightstyle 7.gif
8 Candle C mmmaaammmaaammmabcdefaaaammmmabcdefmmmaaaa Lightstyle 8.gif
4 Fast strobe mamamamamama Lightstyle 4.gif
9 Slow strobe aaaaaaaazzzzzzzz Lightstyle 9.gif
12 !FGD Underwater light mutation mmnnmmnnnmmnn Lightstyle 12.gif
Custom Appearance (pattern) <string>
A string of english letters, like a sequence of piano keys, that define a pattern of brightness. a is 0%, m is 100%, and z is 200%. Updates at 10 Hz. Requires light to have a targetname.

Internal keyvalues used only by VRAD:

Brightness (_light) <color255 + int>
The RGB color of the light, and a multiplicative scalar for brightness (applied after gamma correction). Colors should be between 0 and 255; brightness can be anything (even absent). If only one value is provided, light will be greyscale.
Note.pngNote:Brightness values below zero are clamped; this can be fixed by modifying VRAD.
Cpp.pngCode Fix:In 🖿utils/vrad/lightmap.cpp, look for the comment saying "// make sure light is legal", then remove the following if statement, including all its contents.
BrightnessHDR (_lightHDR) <color255 + int>
RGB color and brightness override used in HDR mode. Default is -1 -1 -1 1, which means no change.
Warning.pngWarning:The fourth digit must be positive. Otherwise all light will be sucked out of your map!
BrightnessScaleHDR (_lightHDRscale) <float>
A simple intensity multiplier used when compiling HDR lighting.
Note.pngNote:Unlike _light and _lightHDR, negative values are supported. Negative brightness will suck out the amount of lighting that the equivalent positive brightness would cast. Use sparingly; set falloff to linear instead of quadratic to make it more like an ordinary shadow and less like a black hole. Since this only applies to HDR mode, it should be reserved for games that don't officially support disabling HDR.
Constant (_constant_attn) <float>
Linear (_linear_attn) <float>
Quadratic (_quadratic_attn) <float>
These three values determine how the intensity of the emitted light falls off over distance. See Constant-Linear-Quadratic Falloff.
50 percent falloff distance (_fifty_percent_distance) <float>
0 percent falloff distance (_zero_percent_distance) <float>
Distances at which brightness should have fallen to 50% and (1/256)% respectively. Overrides Linear/Constant/Quadratic parameters if non-zero.
Icon-Bug.pngBug:Using this setting will sometimes not work, which may or may not be related to using the light inside of an instance. Collapsing the instance and messing with the light's falloff values seems to help.
Hard falloff (_hardfalloff) <boolean>
Causes lights to fall to exactly zero beyond the 0% distance. May cause unrealistic lighting if not used carefully.
Cast entity shadows (_castentityshadow) <boolean> (in all games since Left 4 Dead) (also in Garry's Mod)
Allows the light to modify the direction of nearby render-to-texture shadows so that they always point away from its origin. See also shadow_control.
Note.pngNote:This keyvalue may not be available in some FGDs.
Shadow cast offset (_shadoworiginoffset) <vector> (in all games since Left 4 Dead)
A world-space offset that gets applied to the light origin when casting entity shadows. Useful for dealing with funny-looking shadows from very low lights: Just offset up the z axis. Default 0 0 0.
Note.pngNote:This keyvalue may not be available in some FGDs.