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

Infodecal: Difference between revisions

From Valve Developer Community
Jump to navigation Jump to search
m (Add missing kv pair ApplyEntity)
(I found this by accident. I have info decals in my map which stop showing up after the player has died but only when the map is downloaded from the workshop, so this doesn't happen when the map is loaded normally and something with the workshop messes with how this entity is treated.)
 
(35 intermediate revisions by 14 users not shown)
Line 1: Line 1:
[[Image:Infodecal.jpg|thumb|right|300px|Infodecal with Cubemap decaltexture]]
{{LanguageBar}}
{{TabsBar|main=gs|base=Infodecal}}
[[File:Infodecal.jpg|thumb|right|300px|Infodecal with Cubemap decaltexture]]
{{CD|CDecal|file1=world.cpp}}
{{preserved entity}}
{{this is a|point entity|name=infodecal}} It is used to place a static [[decal]] in a map.
It is the entity created when the [[Hammer Decal Tool|Decal tool]] is used. It places a texture on any surface, with transparency if the texture being applied supports transparency. In {{gldsrc|4.1}}, these textures were indicated by being in [[Decals (GoldSrc)|decals.wad]], while in {{src|4.1}}, they are indicated by the {{ent|$decal}} material parameter and typically placed in the <code>decals/</code> texture folder. On world geometry, an [[info overlay | overlay]] should be used for more control over the applied texture. For example, an <code>infodecal</code> cannot be resized, or rotated, while an overlay can; however, overlays cannot be applied dynamically, nor can they be applied to entities.


{{base point|infodecal}} It is used to place a [[decal]] in a map.
{{Confusion|Unlike most entities with the prefix {{mono|info}}, {{ent|infodecal}} does ''not'' have an underscore!}} <!-- notable because it's an easy mistake to make; even info_projecteddecal has an underscore -->
 
{{bug*|In games where this entity is not [[S_PreserveEnts|preserved]], such as {{tf2|2}} and {{dods|2}}, large amounts of this entity present may overflow the decal limit after round restarts and not allow any more decals to be spawned. This can be worked around by spawning the decals once-off via [[VScript]] or [[point_template]]s instead. Alternatively, use [[info_overlay]] instead.}}
==Entity description==
{{bug|Placing this entity near brush entities may cause the game to crash with a fatal error randomly on map load: <code>Bad inline model number N, worldmodel not yet setup</code>.{{workaround|Create a {{ent|func_brush}} with the desired decal instead. {{cmd|$decal}} will prevent the coplanar face from z-fighting.}} {{confirm|Does this still occur when the infodecal activation is delayed with a {{ent|logic_auto}}?}}}}
 
{{bug|tested={{hammer4}}{{hammer++}}{{dods}}{{css}}|The projection displayed for decals in Hammer is inaccurate to the projection in-game.}}
It is the entity created when the [[Hammer Decal Tool|Decal tool]] is used. It places a texture on any surface, with transparency if the texture being applied supports transparency. In Half-Life 1, these textures were indicated with a <nowiki>{</nowiki>, in Half-Life 2 they are placed in the decals/ texture folder. When needed, an [[info overlay | overlay]] can be used for more control over the applied texture. For example, an infodecal cannot be applied to a displacement, resized or rotated, while an overlay can.
{{bug|tested={{p2}}|This entity will stop rendering after the player dies, but only if the map is a workshop map}}
 
{{note|Naming this entity will make it count towards the [[Entity limit]] and make it more expensive, similar to a [[light]] entity.}}
== Keyvalues ==
== Keyvalues ==
{{KV|texture|intn=texture|decal|The image to apply as a decal.}}
{{KV Targetname}}
:{{note|Unnamed infodecal applies the decal right after spawning and then removes itself. If named, <code>Activate</code> input needs to be fired to spawn the decal. The entity counts towards [[edict limit]] in both cases, though in the first case, it's only for a fraction of second.}}
{{KV|Texture|intn=texture|decal|The image to apply as a decal.}}
{{KV|Low Priority (can be replaced)|intn=LowPriority|boolean|If true, allows the decal to be removed to accommodate newly-placed decals. Default behavior is false (high priority), meaning it is always present.}}
{{KV|Low Priority (can be replaced)|intn=LowPriority|boolean|If true, allows the decal to be removed to accommodate newly-placed decals. Default behavior is false (high priority), meaning it is always present.}}
{{KV|Apply Entity|intn=ApplyEntity|target_destination|An optional entity to apply the decal to.  If this is empty, the decal will locate the entity by tracing.}}
{{KV|Apply Entity|intn=ApplyEntity|target_destination|An optional entity to apply the decal to.  If this is empty, the decal will locate the entity by tracing.
{{KV Targetname}}
:{{note|Mainly present in {{l4ds}} FGDs, but is still implemented in future branches.}}|since={{l4d}}}}


== Inputs ==
== Inputs ==
{{IO|Activate|Force the decal to apply itself to the world.}}
{{I|Activate|Force the decal to apply itself to the world and removes itself.}}
{{I Targetname}}


== Outputs ==
== Flags ==
{{O Targetname}}
{{fl|2048|Not in Deathmatch|{{confirm|Is this controlled by the {{cmd|deathmatch}} cvar?}}}}


== See also ==
== See also ==
* [[Decals|Creating Decals]]
* [[Decals|Creating Decals]]
* [[Hammer Decal Tool]] and [[Hammer Overlay Tool]]
* [[Hammer Decal Tool]] and [[Hammer Overlay Tool]]
* [[Info_projecteddecal]]
* {{ent|info_overlay}}
* {{ent|info_projecteddecal}}

Latest revision as of 05:35, 21 September 2025

English (en)Translate (Translate)
Infodecal with Cubemap decaltexture
C++ Class hierarchy
CDecal
CPointEntity
CBaseEntity
C++ world.cpp
Recycle-warning.png
This is a preserved entity in Counter-Strike: SourceHalf-Life 2: DeathmatchLeft 4 DeadLeft 4 Dead 2Alien Swarm: Reactive DropPortal 2Counter-Strike: Global Offensive
If the game has round restart mechanics this entity may not behave as expected.

infodecal is a point entity available in all Source Source games. It is used to place a static decal in a map. It is the entity created when the Decal tool is used. It places a texture on any surface, with transparency if the texture being applied supports transparency. In GoldSrc GoldSrc, these textures were indicated by being in decals.wad, while in Source Source, they are indicated by the $decal material parameter and typically placed in the decals/ texture folder. On world geometry, an overlay should be used for more control over the applied texture. For example, an infodecal cannot be resized, or rotated, while an overlay can; however, overlays cannot be applied dynamically, nor can they be applied to entities.

Warning.pngRisk of Confusion:Unlike most entities with the prefix info, infodecal does not have an underscore!
Icon-Bug.pngBug*:In games where this entity is not preserved, such as Team Fortress 2 Team Fortress 2 and Day of Defeat: Source Day of Defeat: Source, large amounts of this entity present may overflow the decal limit after round restarts and not allow any more decals to be spawned. This can be worked around by spawning the decals once-off via VScript or point_templates instead. Alternatively, use info_overlay instead.
Icon-Bug.pngBug:Placing this entity near brush entities may cause the game to crash with a fatal error randomly on map load: Bad inline model number N, worldmodel not yet setup.
PlacementTip.pngWorkaround:Create a func_brush with the desired decal instead. $decal will prevent the coplanar face from z-fighting.
Confirm:Does this still occur when the infodecal activation is delayed with a logic_auto?
  [todo tested in ?]
Icon-Bug.pngBug:The projection displayed for decals in Hammer is inaccurate to the projection in-game.  (tested in: HammerHammer++Day of Defeat: SourceCounter-Strike: Source)
Icon-Bug.pngBug:This entity will stop rendering after the player dies, but only if the map is a workshop map  (tested in: Portal 2)

Keyvalues

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

Note.pngNote:Unnamed infodecal applies the decal right after spawning and then removes itself. If named, Activate input needs to be fired to spawn the decal. The entity counts towards edict limit in both cases, though in the first case, it's only for a fraction of second.
Texture (texture) <decal>
The image to apply as a decal.
Low Priority (can be replaced) (LowPriority) <boolean>
If true, allows the decal to be removed to accommodate newly-placed decals. Default behavior is false (high priority), meaning it is always present.
Apply Entity (ApplyEntity) <targetname> (in all games since Left 4 Dead)
An optional entity to apply the decal to. If this is empty, the decal will locate the entity by tracing.
Note.pngNote:Mainly present in Left 4 Dead seriesLeft 4 Dead series FGDs, but is still implemented in future branches.

Inputs

Activate
Force the decal to apply itself to the world and removes itself.

Flags

Not in Deathmatch : [2048]
Confirm:Is this controlled by the deathmatch cvar?

See also