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

Env sprite: Difference between revisions

From Valve Developer Community
Jump to navigation Jump to search
(removed spam)
(→‎Inputs: not sure if worth even mention lel but I guess it can be encountered easily during testing where one would set up single output)
 
(68 intermediate revisions by 34 users not shown)
Line 1: Line 1:
{{wrongtitle|title=env_sprite}}
{{LanguageBar}}
==Entity Description==
{{TabsBar|main=gs|base=env_sprite}}
An entity that controls the drawing of a sprite in the world.
{{Preserved entity}}
{{CD|CSprite|file1=Sprite.cpp}}
{{This is a|point entity|name=env_sprite}} It creates a [[sprite]] in the world. Sprites always face the player.
{{note|The only [[render modes]] that render sprite transparency are ''Glow'', ''Additive'', ''Additive Fractional Frame'', ''World Space Glow'' and ''Alpha Add'' {{not in FGD}}.}}
{{bug|Although the sprite preview in [[Hammer]] can find the sprite with any or no file extension, the actual extension of the used material must be used for the engine to be able to find the sprite in-game. In engine versions before {{src09|4}}, when choosing a sprite from the sprite browser, the name it provides does not contain the required <code>.spr</code>/<code>.vmt</code> file extension, so it must be adjusted by hand.}}
{{AltNames|name1=env_glow|misc=This might be useful use in case env_sprite being a preserved entity is undesirable.}}
 
==Flags==
{{fl|1|Start on}}
{{fl|2|Play Once|Used for animated sprites; texture will animate once, then the sprite will turn off.}}
 
==Keyvalues==
==Keyvalues==
* {{kv targetname}}
{{KV Targetname}}
* {{kv parentname}}
:{{warning|If env_sprite given a name, it will start to respect the "Start On" spawnflag and be turned off by default if the flag is not set.}}
* {{kv renderfields}}
 
* {{kv dxlevelchoice}}
{{KV|Sprite Name|intn=model|material|The material to draw, ''including the file extension''.<br>For backwards compatibility reasons, {{code|.[[spr]]}} file extensions are treated like {{code|.[[vmt]]}}.}}
* '''framerate'''
{{KV|Scale|intn=scale|float|Scale multiplier of the sprite.
: <float> Rate at which the sprite should animate, if at all.
:{{bug<!--hammer bug (possibly due to shared code with iconsprite?)-->|Hammer's default sprite scale is <code>0.25</code>, but the engine's is <code>1.0</code>. To synchronise the values, set this keyvalue to something.}}
* '''model'''
:{{warning|The precision of this value is limited in multiplayer. The maximum scale is 64 and the value will be rounded to an upper power of 2 (64, 32, 16, 8, 4, 2, 1, 0.5, 0.25, 0.125...). {{gmod|2}} fixes this and uses full precision. This may lead to desynced scaling, for example, if a map made for another game uses a value of 40, it will get rounded up to 64 in that game but will remain at 40 in {{gmod}}.}}}}
: <sprite> Material of the sprite to be drawn.
{{KV|Framerate|intn=framerate|string|Rate at which the sprite should animate, if at all.}}
* '''scale'''
:{{bug|A sprite will only automatically animate if it has at least 3 frames.|tested={{css}}}}
: <float> Scale multiplier of the sprite.
::{{workaround|Add an [[List of material proxies#Texture manipulation|AnimatedTexture material proxy]]. The proxy's framerate will take precedence over this keyvalue.}}
* '''GlowProxySize'''
 
: <float> Size of the glow to be rendered for visibility testing. Must be larger than the distance from the sprite center to empty space.  So if this glow is inside geometry (like a light bulb), set this value to be bigger than the bulb's radius. Any time a sphere of this radius would be visible (poking through any nearby geometry), the glow will be rendered.
{{KV|Starting Frame|intn=frame|nofgd=1|float|If the sprite is animated, the frame it should start animating on.}}
==Flags==
:{{bug|If the provided material uses the <code>AnimatedTexture</code> material proxy, setting this will not work.{{confirm}}}}
* 1 : Start on
:{{confirm|In {{css}} Starting Frame does not ever work.}}
* 2 : Play Once
{{KV|Size of Glow Proxy Geometry|intn=GlowProxySize|float|Size of the glow to be rendered for visibility testing. Any time a sphere of this radius would be visible (poking through any nearby geometry), the glow will be rendered.}}
{{KV|HDR color scale|intn=HDRColorScale|float|Color multiplier for players using [[HDR]].}}
{{KV RenderFields}}
{{KV DXLevelChoice}}
{{KV SystemLevelChoice}}
 
==Inputs==
==Inputs==
* {{i targetname}}
{{I|SetScale|param=float|Sets {{mono|scale}}.}}
* {{i renderfields}}
{{I|HideSprite|Makes the sprite invisible.}}
* {{i parentname}}
{{I|ShowSprite|Makes sprite visible.}}
* '''SetScale <float>'''
{{I|ToggleSprite|Make sprite invisible or visible depending on the current state.}}
: Set the scale.
{{I|ColorRedValue|param=float|Change the intensity of the red channel (0-255).}}
* '''HideSprite'''
{{I|ColorGreenValue|param=float|Change the intensity of the green channel (0-255).}}
: Hide the sprite. Won't be drawn until the 'ShowSprite' input is received.
{{I|ColorBlueValue|param=float|Change the intensity of the blue channel (0-255).}}
* '''ShowSprite'''
{{I RenderFields}}
: Show the sprite.
{{I|[[Use]]|deprecated=1|param=void|nofgd=1|Acts like {{mono|ToggleSprite}}. (if used by ent_fire acts like {{mono|HideSprite}}, if fired from the first loaded output in the given game session it acts like {{mono|ShowSprite}})}}
* '''ToggleSprite'''
: Toggle the sprite between hidden and shown.


==Outputs==
==See also==
* {{o targetname}}
*{{ent|env_sprite_oriented}}
[[Category:Entities]]
*{{ent|env_sprite_clientside}}
*{{ent|env_lightglow}}
*{{ent|env_lensflare}}

Latest revision as of 10:07, 13 May 2025

English (en)Русский (ru)Translate (Translate)
Recycle-warning.png
This is a preserved entity in Day of Defeat: SourceTeam Fortress 2
If the game has round restart mechanics this entity may not behave as expected.
C++ Class hierarchy
CSprite
CBaseEntity
C++ Sprite.cpp

env_sprite is a point entity available in all Source Source games. It creates a sprite in the world. Sprites always face the player.

Note.pngNote:The only render modes that render sprite transparency are Glow, Additive, Additive Fractional Frame, World Space Glow and Alpha Add !FGD.
Icon-Bug.pngBug:Although the sprite preview in Hammer can find the sprite with any or no file extension, the actual extension of the used material must be used for the engine to be able to find the sprite in-game. In engine versions before Source 2009 Source 2009, when choosing a sprite from the sprite browser, the name it provides does not contain the required .spr/.vmt file extension, so it must be adjusted by hand.  [todo tested in ?]
AltNames.pngAltNames: This entity is also tied to env_glow. This might be useful use in case env_sprite being a preserved entity is undesirable.

Flags

Start on : [1]
Play Once : [2]
Used for animated sprites; texture will animate once, then the sprite will turn off.

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

Warning.pngWarning:If env_sprite given a name, it will start to respect the "Start On" spawnflag and be turned off by default if the flag is not set.


Sprite Name (model) <material>
The material to draw, including the file extension.
For backwards compatibility reasons, .spr file extensions are treated like .vmt.
Scale (scale) <float>
Scale multiplier of the sprite.
Icon-Bug.pngBug:Hammer's default sprite scale is 0.25, but the engine's is 1.0. To synchronise the values, set this keyvalue to something.  [todo tested in ?]
Warning.pngWarning:The precision of this value is limited in multiplayer. The maximum scale is 64 and the value will be rounded to an upper power of 2 (64, 32, 16, 8, 4, 2, 1, 0.5, 0.25, 0.125...). Garry's Mod Garry's Mod fixes this and uses full precision. This may lead to desynced scaling, for example, if a map made for another game uses a value of 40, it will get rounded up to 64 in that game but will remain at 40 in Garry's Mod.
Framerate (framerate) <string>
Rate at which the sprite should animate, if at all.
Icon-Bug.pngBug:A sprite will only automatically animate if it has at least 3 frames.  (tested in: Counter-Strike: Source)
PlacementTip.pngWorkaround:Add an AnimatedTexture material proxy. The proxy's framerate will take precedence over this keyvalue.


Starting Frame (frame) <float> !FGD
If the sprite is animated, the frame it should start animating on.
Icon-Bug.pngBug:If the provided material uses the AnimatedTexture material proxy, setting this will not work.[confirm]  [todo tested in ?]
Confirm:In Counter-Strike: Source Starting Frame does not ever work.
Size of Glow Proxy Geometry (GlowProxySize) <float>
Size of the glow to be rendered for visibility testing. Any time a sphere of this radius would be visible (poking through any nearby geometry), the glow will be rendered.
HDR color scale (HDRColorScale) <float>
Color multiplier for players using HDR.

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.
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

Inputs

SetScale <floatRedirectInput/float>
Sets scale.
HideSprite
Makes the sprite invisible.
ShowSprite
Makes sprite visible.
ToggleSprite
Make sprite invisible or visible depending on the current state.
ColorRedValue <floatRedirectInput/float>
Change the intensity of the red channel (0-255).
ColorGreenValue <floatRedirectInput/float>
Change the intensity of the green channel (0-255).
ColorBlueValue <floatRedirectInput/float>
Change the intensity of the blue channel (0-255).

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.
Use <void> !FGD Obsolete
Deprecated.
Acts like ToggleSprite. (if used by ent_fire acts like HideSprite, if fired from the first loaded output in the given game session it acts like ShowSprite)

See also