Light spot: Difference between revisions
		
		
		
		
		
		Jump to navigation
		Jump to search
		
				
		
 
 Note:When using this entity it is often necessary to turn the brightness value up significantly for the effects of the light to be visible compared to other lighting entities. Values of 3000-4000 are sometimes necessary for light sources like streetlights.
Note:When using this entity it is often necessary to turn the brightness value up significantly for the effects of the light to be visible compared to other lighting entities. Values of 3000-4000 are sometimes necessary for light sources like streetlights.
 AltNames:light, light_spot, light_glspot, and (in all games since
AltNames:light, light_spot, light_glspot, and (in all games since  ) light_directional are all tied to the same C++ class in game, and only differ in VRAD.
) light_directional are all tied to the same C++ class in game, and only differ in VRAD.
		
	
| No edit summary | No edit summary | ||
| (26 intermediate revisions by 10 users not shown) | |||
| Line 1: | Line 1: | ||
| {{ | {{TabsBar|main=Light spot}} | ||
| {{CD|CLight|file1=lights.cpp}} | |||
| [[File:Light spot.gif|left|link=]] | [[File:Light spot.gif|left|link=]] | ||
| {{ | {{This is a|semi-internal=1|point entity|name=light_spot}} It is a cone-shaped, invisible light source. Can be turned on and off through inputs, though switchable lights may cause lightmap errors. This is a static spotlight that can be pointed at another entity.   | ||
| {{note|When using this entity it is often necessary to turn the brightness value up significantly for the effects of the light to be visible. Values of 3000-4000 are sometimes necessary for light sources like streetlights.}} | {{note|When using this entity it is often necessary to turn the brightness value up significantly for the effects of the light to be visible compared to other lighting entities. Values of 3000-4000 are sometimes necessary for light sources like streetlights.}} | ||
| {{ | {{altnames|{{mono|[[light]]}}, {{mono|light_spot}}, {{mono|[[light_glspot]]}}, and {{l4d|since}} {{mono|[[light_directional]]}} are all tied to the same C++ class in game, and only differ in VRAD.}} | ||
| {{ | |||
| ==Keyvalues== | ==Keyvalues== | ||
| {{KV|Entity to point at|intn=target|target_destination|The name of  | {{KV Targetname}} | ||
| {{KV|Inner (bright) angle|intn=_inner_cone|integer|The angles of the inner spotlight beam | :{{Light NameWarning}} | ||
| {{KV|Outer (fading) angle|intn=_cone|integer|The angles of the outer spotlight beam.}}{{note| | {{KV|Entity to point at|intn=target|target_destination|The name of a ([[non-internal entity|non-internal]]) entity in the map that the spotlight will point at. This will override the spotlight's angles.}} | ||
| {{KV|Inner (bright) angle|intn=_inner_cone|integer|The angles of the inner spotlight beam.}} | |||
| {{KV|Outer (fading) angle|intn=_cone|integer|The angles of the outer spotlight beam.}}{{note|Values for {{mono|_cone}} and {{mono|_inner_cone}} larger than 90 are clamped to 90; this can be circumvented with a custom RAD compiler, but lighting on dynamically-lit models may behave unexpectedly.}} | |||
| {{KV|Focus|intn=_exponent|integer|Changes the distance between the umbra and penumbra cone. (higher values make the edge of the light more blurred.{{tip|When increasing the Focus value to for example 5 you can use the spotlight as a directional fill light.}}}} | {{KV|Focus|intn=_exponent|integer|Changes the distance between the umbra and penumbra cone. (higher values make the edge of the light more blurred.{{tip|When increasing the Focus value to for example 5 you can use the spotlight as a directional fill light.}}}} | ||
| {{KV|Maximum distance|intn=_distance|integer|This is the distance that light is allowed to cast, in inches. {{ | {{KV|Maximum distance|intn=_distance|integer|This is the distance that light is allowed to cast, in inches. Non-functional in {{src13|1}} and later, use 50 and 0 percent falloff instead.}} | ||
| {{KV|Pitch|intn=pitch|integer|Used instead of  | {{KV Angles}} | ||
| {{bug|Pitch has unexpected behavior if the <code>light_spot</code> is inside of a rotated [[instance]]. This is solved by collapsing the instance, or by using the "Entity to point at" keyvalue.}} | {{KV|Pitch|intn=pitch|integer|Used instead of {{code|angles}} value for reasons unknown. | ||
| :{{bug|Pitch has unexpected behavior if the <code>light_spot</code> is inside of a rotated [[instance]]. This is solved by collapsing the instance, or by using the "Entity to point at" ({{mono|target}}) keyvalue.}}}} | |||
| {{KV Light}} | {{KV Light}} | ||
| ==Flags== | ==Flags== | ||
| Line 23: | Line 24: | ||
| ==Inputs== | ==Inputs== | ||
| {{I Light}} | {{I Light}} | ||
| ==See  | ==See also== | ||
| * [[light]] and [[point_spotlight]] | * [[light]] and [[point_spotlight]] | ||
| * [[light_deferred]] | |||
| * [[Lighting]] | * [[Lighting]] | ||
| * [[Adding Light]] | * [[Adding Light]] | ||
Latest revision as of 11:02, 23 September 2025
|  Class hierarchy | 
|---|
| CLight | 
|  lights.cpp | 

light_spot  is a  semi-internal point entity  available in all  Source games. It is a cone-shaped, invisible light source. Can be turned on and off through inputs, though switchable lights may cause lightmap errors. This is a static spotlight that can be pointed at another entity.
 Source games. It is a cone-shaped, invisible light source. Can be turned on and off through inputs, though switchable lights may cause lightmap errors. This is a static spotlight that can be pointed at another entity. 
 Note:When using this entity it is often necessary to turn the brightness value up significantly for the effects of the light to be visible compared to other lighting entities. Values of 3000-4000 are sometimes necessary for light sources like streetlights.
Note:When using this entity it is often necessary to turn the brightness value up significantly for the effects of the light to be visible compared to other lighting entities. Values of 3000-4000 are sometimes necessary for light sources like streetlights. AltNames:light, light_spot, light_glspot, and (in all games since
AltNames:light, light_spot, light_glspot, and (in all games since  ) light_directional are all tied to the same C++ class in game, and only differ in VRAD.
) light_directional are all tied to the same C++ class in game, and only differ in VRAD.Keyvalues
- Name (targetname) <string>[ Edit ]
- The name that other entities refer to this entity by, via Inputs/Outputs or other keyvalues (e.g. parentnameortarget).
 Also displayed in Hammer's 2D views and Entity Report.See also: Generic Keyvalues, Inputs and Outputs available to all entities
 Important:Naming a static light radically changes its behavior. See Naming Lights for details. Important:Naming a static light radically changes its behavior. See Naming Lights for details.
- Entity to point at (target) <targetname>
- The name of a (non-internal) entity in the map that the spotlight will point at. This will override the spotlight's angles.
- Inner (bright) angle (_inner_cone) <integer>
- The angles of the inner spotlight beam.
- Outer (fading) angle (_cone) <integer>
- The angles of the outer spotlight beam. Note:Values for _cone and _inner_cone larger than 90 are clamped to 90; this can be circumvented with a custom RAD compiler, but lighting on dynamically-lit models may behave unexpectedly. Note:Values for _cone and _inner_cone larger than 90 are clamped to 90; this can be circumvented with a custom RAD compiler, but lighting on dynamically-lit models may behave unexpectedly.
- Focus (_exponent) <integer>
- Changes the distance between the umbra and penumbra cone. (higher values make the edge of the light more blurred. Tip:When increasing the Focus value to for example 5 you can use the spotlight as a directional fill light. Tip:When increasing the Focus value to for example 5 you can use the spotlight as a directional fill light.
- Maximum distance (_distance) <integer>
- This is the distance that light is allowed to cast, in inches. Non-functional in Source 2013 and later, use 50 and 0 percent falloff instead.
- Pitch Yaw Roll (Y Z X) (angles) <QAngle>
- This entity's orientation in the world. Pitch is rotation around the Y axis, yaw is the rotation around the Z axis, roll is the rotation around the X axis.
- Pitch (pitch) <integer>
- Used instead of anglesvalue for reasons unknown.
- Appearance (lightstyle) (style) <integer choices>
- Various lightstyle presets. Cannot be used on named lights.
 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 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- Dynamic Light Renderingwhen using +showbudget. When toggling- r_dynamiclightingoff, these spikes will disappear. DXVK is not affected by this problem.
- Lightstyle presets (epilepsy warning) - Literal Value - Description - Sequence - Preview - 0 - Normal - m   - 10 - Fluorescent flicker - mmamammmmammamamaaamammma   - 2 - Slow, strong pulse - abcdefghijklmnopqrstuvwxyzyxwvutsrqponmlkjihgfedcba   - 11 - Slow pulse, noblack - abcdefghijklmnopqrrqponmlkjihgfedcba   - 5 - Gentle pulse - jklmnopqrstuvwxyzyxwvutsrqponmlkj   - 1 - Flicker A - mmnmmommommnonmmonqnmmo   - 6 - Flicker B - nmonqnmomnmomomno   - 3 - Candle A - mmmmmaaaaammmmmaaaaaabcdefgabcdefg   - 7 - Candle B - mmmaaaabcdefgmmmmaaaammmaamm   - 8 - Candle C - mmmaaammmaaammmabcdefaaaammmmabcdefmmmaaaa   - 4 - Fast strobe - mamamamamama   - 9 - Slow strobe - aaaaaaaazzzzzzzz   - 12 !FGD - Underwater light mutation - mmnnmmnnnmmnn   
- 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:Brightness values below zero are clamped; this can be fixed by modifying VRAD. Note:Brightness values below zero are clamped; this can be fixed by modifying VRAD. Code Fix:In Code 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:The fourth digit must be positive. Otherwise all light will be sucked out of your map! Warning: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:Unlike Note:Unlike- _lightand- _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.
 Bug: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. Bug: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  ) (also in ) (also in ) )
- 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:This keyvalue may not be available in some FGDs. Note:This keyvalue may not be available in some FGDs.
- Shadow cast offset (_shadoworiginoffset)  <vector> (in all games since  ) )
- 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:This keyvalue may not be available in some FGDs. Note:This keyvalue may not be available in some FGDs.
Flags
- Initially dark : [1]
- Spawns with the light turned off, so a light switch or similar can turn it on.
Inputs
- TurnOn
- Turn the light on.
- TurnOff
- The the light off.
- Toggle
- Toggle the light's current state.
- SetPattern <string>
- Set a custom pattern of light brightness for this light. If the Light is off, then this input appears to turn it on.
- FadeToPattern <string>
- Fades from first value in old pattern, to first value in the new given pattern. If the Light is off, then this input appears to turn it on.
See also
- light and point_spotlight
- light_deferred
- Lighting
- Adding Light
- Intermediate Lighting
- Advanced Lighting
- Tool textures (for Block light)
