This article's documentation is for anything that uses the Source engine. Click here for more information.

Point spotlight: Difference between revisions

From Valve Developer Community
Jump to navigation Jump to search
No edit summary
(Specify that point_spotlight is a server-only entity not only in Team Fortress 2, but also in Garry's Mod as well.)
Line 8: Line 8:
{{note|This entity creates an {{ent|env_beam}} and a <code>spotlight_end</code> to accomplish its sprite effects. This means a single <code>point_spotlight</code> actually represents three different entities, including the <code>point_spotlight</code> itself. All of these contribute to the [[entity limit]].}}
{{note|This entity creates an {{ent|env_beam}} and a <code>spotlight_end</code> to accomplish its sprite effects. This means a single <code>point_spotlight</code> actually represents three different entities, including the <code>point_spotlight</code> itself. All of these contribute to the [[entity limit]].}}
{{TODO|Define a way to set a custom materials through this ents keyvalues}}
{{TODO|Define a way to set a custom materials through this ents keyvalues}}
{{warning|This entity generates 3 [[edict]]s (for itself, the beam visual and beam target respectively: <code>point_spotlight, beam, spotlight_end</code>! In {{tf2|2}}, the <code>point_spotlight</code> itself has been converted to a server-only edict (does not take up an edict), and when no targetname and parentname is assigned, the <code>point_spotlight</code> and <code>spotlight_end</code> entity is also killed, thus consuming 1 edict in total for a static spotlight.}}
{{warning|This entity generates 3 [[edict]]s (for itself, the beam visual and beam target respectively: <code>point_spotlight, beam, spotlight_end</code>! In {{tf2|4}} and {{gmod|4}}, the <code>point_spotlight</code> itself has been converted to a server-only edict (does not take up an edict), and in {{tf2|4}}, when no targetname and parentname is assigned, the <code>point_spotlight</code> and <code>spotlight_end</code> entity is also killed, thus consuming 1 edict in total for a static spotlight.}}
{{warning|In {{bms|4}} if this entity does not use the <code>No Dynamic Light</code> spawnflag then it will create dynamic {{wiki|Deferred lighting}} instead of using [[lightmap]]s.}}
{{warning|In {{bms|4}} if this entity does not use the <code>No Dynamic Light</code> spawnflag then it will create dynamic {{wiki|Deferred lighting}} instead of using [[lightmap]]s.}}
{{note|{{ent|env_beam}} collides only with [[prop_static]] and world geometry, this means that beam of [[point_spotlight]] and dynamic light will ignore any dynamic objects (with the exception of [[func_physbox]]), [[NPC]]s, [[physics objects]], e.t.c.}}
{{note|{{ent|env_beam}} collides only with [[prop_static]] and world geometry, this means that beam of [[point_spotlight]] and dynamic light will ignore any dynamic objects (with the exception of [[func_physbox]]), [[NPC]]s, [[physics objects]], e.t.c.}}

Revision as of 13:11, 4 March 2024

A point_spotlight.

point_spotlight is an e0 available in all Source Source games. It is a light_dynamic with two glow sprite effects: a beam effect for viewers outside the light cone and a halo effect for viewers inside the cone.

The light_dynamic functionality can be disabled with the 'No Dynamic Light' spawnflag. In that state, the spotlight will not actually illuminate other objects on its own and can be used with an accompanying light_spot or env_projectedtexture(newLight_Spot if Black Mesa Black Mesa) instead.

Icon-Bug.pngBug:It doesn't spawn light_dynamic even if you disabled 'No Dynamic Light' spawnflag in Left 4 Dead 2.  [todo tested in ?]
Cpp.pngCode:By default, point_spotlight uses the material sprites/glow_test02.vmt. You can change this if you are shipping your own binaries by going into point_spotlight.cpp in the server project, navigating to line 351 and replacing the file path with your own material.
Note.pngNote:This entity creates an env_beam and a spotlight_end to accomplish its sprite effects. This means a single point_spotlight actually represents three different entities, including the point_spotlight itself. All of these contribute to the entity limit.
Todo: Define a way to set a custom materials through this ents keyvalues
Warning.pngWarning:This entity generates 3 edicts (for itself, the beam visual and beam target respectively: point_spotlight, beam, spotlight_end! In Team Fortress 2 Team Fortress 2 and Garry's Mod Garry's Mod, the point_spotlight itself has been converted to a server-only edict (does not take up an edict), and in Team Fortress 2 Team Fortress 2, when no targetname and parentname is assigned, the point_spotlight and spotlight_end entity is also killed, thus consuming 1 edict in total for a static spotlight.
Warning.pngWarning:In Black Mesa Black Mesa if this entity does not use the No Dynamic Light spawnflag then it will create dynamic Wikipedia icon Deferred lighting instead of using lightmaps.
Note.pngNote:env_beam collides only with prop_static and world geometry, this means that beam of point_spotlight and dynamic light will ignore any dynamic objects (with the exception of func_physbox), NPCs, physics objects, e.t.c.
Icon-Bug.pngBug:In Black Mesa Black Mesa keyvalue Render FX / Transparency (0 - 255) not functional at all, use HDR color scale. instead.  [todo tested in ?]
Note.pngNote:In Alien Swarm Deferred Alien Swarm Deferred this entity is not supported and on loading a map all point_spotlight entities will be converted to Light deferred!

Keyvalues

Ignore Solid (IgnoreSolid) ([todo internal name (i)]) <boolean> !FGD
If set, this spotlight won't trace for solids.
Spotlight Length (spotlight_length) ([todo internal name (i)]) <integer>
Length of the spotlight beam.
Spotlight Width (spotlight_width) ([todo internal name (i)]) <integer>
Width of the spotlight beam.
Color (R G B) (rendercolor) ([todo internal name (i)]) <color255>
Spotlight color.
HDR color scale. (HDRColorScale) ([todo internal name (i)]) <float>
Float value to multiply sprite color by when running in HDR mode.
Halo size scale. (HaloScale) ([todo internal name (i)]) <float> (in all games since Left 4 Dead 2)
Float value to determine the size of the halo.
Name (targetname) <string>[ Edit ]
The name that other entities refer to this entity by, via Inputs/Outputs or other keyvalues (e.g. parentname or target).
Also displayed in Hammer's 2D views and Entity Report.
See also:  Generic Keyvalues, Inputs and Outputs available to all entities

Parentname:
Parent (parentname) <targetname>
Specifies a movement parent. An entity will maintain its initial offset from its parent. An attachment point can be added to the end of the name, separated by a comma.

RenderFields:

Render Mode (rendermode) <byte choices>
Set a non-standard rendering mode on this entity.
Render Modes
  • 0: Normal
  • 1: Color
  • 2: Texture
  • 3: Glow
  • 4: Solid/Alphatest Obsolete
  • 5: Additive
  • 6: Removed, does nothing Obsolete
  • 7: Additive Fractional Frame
  • 8: Alpha Add
  • 9: World Space Glow
  • 10: Don't Render
Render FX (renderfx) <byte choices>
Various somewhat legacy alpha effects. See render effects.
Render Amount / Transparency (renderamt) <byte>
Transparency amount, requires a Render Mode other than Normal. 0 is invisible, 255 is fully visible.
Render Color (R G B) (rendercolor) <color255>
Color tint.
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.
Minimum / Maximum DX Level (mindxlevel / maxdxlevel) <integer choices> (removed since Left 4 Dead)
The entity will not exist if the engine is running outside the given range of DirectX Versions.
Choices
Warning.pngWarning:If these are used, the object may break when the user switches their DirectX settings.[missing string]
Minimum / Maximum Effect Details Level (mincpulevel / maxcpulevel) <integer choices> (in all games since Left 4 Dead)
Don't render for players with Effect Details levels that exceed the minimum or maximum.
Choices
  • 0: Default ("Low" for mincpulevel, "High" for maxcpulevel)
  • 1: Low
  • 2: Medium
  • 3: High
Minimum / Maximum Shader Details Level (mingpulevel / maxgpulevel) <integer choices> (in all games since Left 4 Dead)
Don't render for players with Shader Details levels that exceed the minimum or maximum.
Choices
  • 0: Default ("Low" for mingpulevel, "Very High" for maxgpulevel)
  • 1: Low
  • 2: Medium
  • 3: High
  • 4: Very High
See also:  cpu_level / gpu_level convars

Flags

Start On : [1]
No Dynamic Light : [2]

Inputs

LightOn
Turn the spotlight on.
LightOff
Turn the spotlight off.
SetColor <color255RedirectInput/color32> (in all games since Alien Swarm) (also in Garry's Mod)
Change the color of the spotlight. Light must be turned off then back on for dynamic light to update.
Note.pngNote:Functionally identical to the Color input. A delay of at least 0.01 is required before the spotlight is turned back on, or else it will remain off.
ForceUpdate  (in all games since Alien Swarm) (also in Garry's Mod)
Force an update of the spotlight position and orientation.


Parentname:
SetParent <stringRedirectInput/string>
Move with this entity. See Entity Hierarchy (parenting).
SetParentAttachment <stringRedirectInput/string>
Change this entity to attach to a specific attachment point on its parent. The entity will teleport so that the position of its root bone matches that of the attachment. Entities must be parented before being sent this input.
SetParentAttachmentMaintainOffset <stringRedirectInput/string>
As above, but without teleporting. The entity retains its position relative to the attachment at the time of the input being received.
ClearParent
Removes this entity from the the movement hierarchy, leaving it free to move independently.

RenderFields:

Alpha <integer 0–255>
Sets the entity's transparency to a number from 0 (invisible) to 255 (fully visible). Requires the entity to have its rendermode set to a number other than 0.
Color <color255RedirectInput/color32>
Sets an RGB color for the entity.

Outputs

OnLightOn
Fires when light turns on.
OnLightOff
Fires when light turns off.


See also