AddOutput: Difference between revisions
| ThaiGrocer (talk | contribs) m (Needs a format change) | Gtamike TSGK (talk | contribs)   (Added Advanced Examples origin and basevelocity Outputs) | ||
| (66 intermediate revisions by 23 users not shown) | |||
| Line 1: | Line 1: | ||
| {{ | {{LanguageBar}} | ||
| {{ | {{TabsBar|main=s2|base=AddOutput}} | ||
| {{This is a|[[input]]|name=AddOutput}} Its primary purpose is registering additional actions for when entity's chosen [[output]] fires. In other words, it "adds" an output. | |||
| ==Examples== | Syntax: <syntaxhighlight lang=text><output> <target>:[input]:[parameter_override]:[delay]:[times to fire (-1 or 0 = infinity, 1 = once, 2 = twice ...)]</syntaxhighlight> | ||
| * < > = mandatory parameter | |||
| * [ ] = optional parameter, if left unspecified the preceding <code>:</code> symbol can be left out if no latter optional parameters need to be specified | |||
| * output - existing output on the given entity | |||
| * target - [[targetname]] of the targeted entity (special targetnames like !caller, !activator, !self etc. are also supported) | |||
| * input - input to be used on targeted entity (if left blank then the <code>Use</code> input is used, imitating GoldSrc targeting) | |||
| * parameter_override - parameter (if left blank and the given output holds a value then that will be automatically filled in) | |||
| * delay - delay in seconds (left blank means 0) | |||
| * times to fire - number of times this output can fire this action (left blank means -1) | |||
| == Example == | |||
| We have a {{ent|math_counter}} named <code>counter</code>. | |||
| The following shows an output that could be setup on a {{ent|trigger_once}} in Hammer: | |||
| <pre> | |||
| My output named:                OnStartTouch | |||
| Target entities named:          counter | |||
| Via this input:                 AddOutput | |||
| With a parameter override of:   OutValue car:skin | |||
| </pre> | |||
| The following are equivalent | |||
| * <code>OutValue car:skin</code> | |||
| * <code>OutValue car:skin:::</code> | |||
| * <code>OutValue car:skin::0:-1</code> | |||
| The parameter_override is left blank which means it will be filled with value of math_counter's OutValue. | |||
| {{Warning|In Hammer don't use quotation characters (") in any of the fields (not even <code>\"</code> characters). It will cause fatal errors with opening and/or compiling your map and may need to be fixed by manually editing the [[VMF]] in a text editor. Instead, use detailed quotes (i.e. <code>“</code> and <code>”</code>) or two apostrophes ( <nowiki>''</nowiki> ).}} | |||
| == Using AddOutput to change keyvalues == | |||
| Because of the way outputs work, AddOutput also allows changing any entity's keyvalues. This includes <kbd>targetname</kbd>, <kbd>origin</kbd>, <kbd>angles</kbd>, <kbd>mins/maxs</kbd>, <kbd>solid</kbd> and more. As this is not something AddOutput was designed for, not all keys will work as expected when changed this way. | |||
| Syntax: <code><key> <value></code> | |||
| Due to how much AddOutput lets you manipulate entities properties it might be therefore a way to optimize maps which utilize {{ent|env_entity_maker}}, {{ent|point_teleport}}, {{ent|game_text}} and more which count as [[edict]]. | |||
| {{Tip|Abusing AddOutput too much makes your map harder to understand. Avoid abusing it unless necessary for your use case.}} | |||
| {{codenote|If simply changing some keyvalue should be intended feature of an entity it should be defined using [[Data_Descriptions#DEFINE_INPUT|DEFINE_INPUT]]. That way the key is both keyvalue and input at once so the parameter_override can be utilized by outputs. Examples of such keyvalues: <kbd>skin</kbd>, <kbd>fademindist</kbd>, <kbd>fademaxdist</kbd>. (potential confusion: these "input keys" aren't auto completed when using {{cmd|ent_fire}}) }} | |||
| === Examples of keyvalues whose change might not have desired effect === | |||
| ;classname | |||
| :<kbd>classname</kbd> is first key read from a map file and determines what C++ class to use to spawn an entity, therefore changing this later via AddOutput will not truly change an entity into a different one. But there are sometimes checks in code that determine some behavior purely on the value of <code>classname</code> for example see [[Preserved entities]]. ({{todo}} some more example) | |||
| :{{Warning|Doing this in games with save files is not advised, as saving an entity with the wrong classname means it won't be recreated properly (or at all).}} | |||
| :{{Warning|Changing the classname of a player causes problems and should be avoided at all costs.}} | |||
| :{{Note|Certain entities rely upon classname, so this is generally discouraged.}} | |||
| ;parentname | |||
| :Won't have an effect when changed via AddOutput as parent/child hierarchy is setup when all entities are being spawned and not later. | |||
| ;SourceEntityName of {{ent|ambient_generic}} | |||
| :ambient_generic searches for the entity named <kbd>SourceEntityName</kbd> when it spawns so changing it later via AddOutput won't have an effect.  | |||
| {{note|Whenever changing a keyvalue via AddOutput doesn't do what's expected, the usual reason is that the entity only is working with the given keyvalue during spawning process.}} | |||
| == Limitations == | |||
| * It's not possible to add an output with this that uses [[Context|AddContext]] input because AddContext also uses ':' in its syntax. | |||
| * Colons ({{code|<nowiki>:</nowiki>}}) are automatically converted to commas when parsed by AddOutput. As such, standard colons are unavailable to be used by values set by AddOutput, which mainly impacts entities such as {{ent|game_text}} which let the mapper set some custom text. | |||
| * Since AddOutput uses a space in its syntax, outputs and keyvalues which have spaces cannot be modified. Fortunately, this is unlikely to ever be an issue, as no vanilla entities use spaces for these. | |||
| == Firing AddOutput via <code>[[ent_fire]]</code> == | |||
| Because AddOutput uses a space in its syntax, it's required to enclose the ent_fire parameter in quotes. | |||
| To add output: {{pre|ent_fire <entity name> addoutput "<output> <target>:[input]:[parameter_override]:[delay]:[times to fire]"}} | |||
| To change keyvalue: {{pre|ent_fire <entity name> addoutput "<key> <value>"}} | |||
| == Examples == | |||
| :Format: <code><key> <value></code> | :Format: <code><key> <value></code> | ||
|   { |   { | ||
|   "classname" " |   "classname" "trigger_once" | ||
|   . |   . | ||
|   . |   . | ||
|   . |   . | ||
|   ''' |   ''''OnStartTouch" "game_text,AddOutput,message There is a fire ahead. Go the other way!,0,1''' | ||
|  ''''OnStartTouch" "game_text,Display,,0.02,1''' | |||
|   }   |   }   | ||
| This changes the  | This changes the text of a game_text and then displays it. This is useful as to prevent having an unneccesary amount of game_text which counts as [[edict]] | ||
| :Format: <code><output  | :Format: <code><output> <targetname>:<input>:<parameter>:<delay>:<refire></code> | ||
|   { |   { | ||
|   "classname" " |   "classname" "logic_auto" | ||
|   . |   . | ||
|   . |   . | ||
|   . |   . | ||
|   ''' |   ''''OnMapSpawn" "team_round_timer_red,AddOutput,OnFinished game_round_win:RoundWin::0:-1,0,-1''' | ||
|   } |   } | ||
| This adds an output to an entity with the targetname "team_round_timer_red". | This adds an output to an entity with the targetname "team_round_timer_red". | ||
| Line 50: | Line 115: | ||
| :With a parameter override of: ''120'' | :With a parameter override of: ''120'' | ||
| :After a delay in seconds: ''0.00'' | :After a delay in seconds: ''0.00'' | ||
| Results in translucent player when standing in the trigger_multiple (OnStartTouch) and visible again when not in the trigger_multiple (OnEndTouch). | Results in translucent player when standing in the trigger_multiple (OnStartTouch) and visible again when not in the trigger_multiple (OnEndTouch). | ||
| == Advanced Examples == | |||
| * Description: Forces player to jump (Quake Jump Pad Style) possible left over Quake Engine code.  | |||
| * Notes: The effect can take affect after the player has completely left the trigger if you add a longer time delay. (Or Add multiple small delays like delay:0.05, delay:0.10, to mimic Double Jump.) | |||
| * Tips: 250 is a small jump (set any higher value) you can set -250 to do increase player fall speed too. | |||
| <pre> | |||
| :func_button - You can use trigger_multiple etc button is unique but for Jump Pads use trigger_multiple. | |||
| My output named:                OnPressed | |||
| Target entities named:          !activator | |||
| Via this input:                 AddOutput | |||
| With a parameter override of:   basevelocity 0 0 250 | |||
| delay:                          0.00 | |||
| </pre> | |||
| * Description: Forces a player to be pushed hard (Different to trigger_push) | |||
| * Notes: The push effect can trigger after the player has completely left the trigger but only if you add a longer time delay. This is something trigger_push can't do as the player as to be touching for push effects to happen.   | |||
| <pre> | |||
| :trigger_multiple - You can use func_button too. | |||
| My output named:                Ontrigger | |||
| Target entities named:          !activator | |||
| Via this input:                 AddOutput | |||
| With a parameter override of:   basevelocity 0 500 0 | |||
| delay:                          0.00 | |||
| </pre> | |||
| * Description: A Special way to teleport nealry anything that has a name. (No extra teleport entities needed) | |||
| * Notes: To quickly work out the teleport origin just make a func_brush place it anywhere you want your object to be teleported in the map and copy the origin numbers from Object Properties and then delete the func_brush. | |||
| <pre> | |||
| :func_button - You can use trigger_multiple etc. | |||
| My output named:                OnPressed | |||
| Target entities named:          !activator | |||
| Via this input:                 AddOutput | |||
| With a parameter override of:   origin -927 706 469 | |||
| delay:                          0.00 | |||
| </pre> | |||
| == See alsо == | |||
| * [https://rafuron.wordpress.com/2011/05/19/2nd-mapping-trick-templates-and-ent-limits/ Optimizing Edict's & Mapping Tricks] - Using AddOutput to reduce mapspawn [[edicts]] on really large maps | |||
| [[Category:IO System]] | |||
Latest revision as of 06:51, 31 August 2025
AddOutput  is an   input  available in all  Source games. Its primary purpose is registering additional actions for when entity's chosen output fires. In other words, it "adds" an output.
 Source games. Its primary purpose is registering additional actions for when entity's chosen output fires. In other words, it "adds" an output.
Syntax:
<output> <target>:[input]:[parameter_override]:[delay]:[times to fire (-1 or 0 = infinity, 1 = once, 2 = twice ...)]
- < > = mandatory parameter
- [ ] = optional parameter, if left unspecified the preceding :symbol can be left out if no latter optional parameters need to be specified
- output - existing output on the given entity
- target - targetname of the targeted entity (special targetnames like !caller, !activator, !self etc. are also supported)
- input - input to be used on targeted entity (if left blank then the Useinput is used, imitating GoldSrc targeting)
- parameter_override - parameter (if left blank and the given output holds a value then that will be automatically filled in)
- delay - delay in seconds (left blank means 0)
- times to fire - number of times this output can fire this action (left blank means -1)
Example
We have a math_counter named counter.
The following shows an output that could be setup on a trigger_once in Hammer:
My output named: OnStartTouch Target entities named: counter Via this input: AddOutput With a parameter override of: OutValue car:skin
The following are equivalent
- OutValue car:skin
- OutValue car:skin:::
- OutValue car:skin::0:-1
The parameter_override is left blank which means it will be filled with value of math_counter's OutValue.
 Warning:In Hammer don't use quotation characters (") in any of the fields (not even
Warning:In Hammer don't use quotation characters (") in any of the fields (not even \" characters). It will cause fatal errors with opening and/or compiling your map and may need to be fixed by manually editing the VMF in a text editor. Instead, use detailed quotes (i.e. “ and ”) or two apostrophes ( '' ).Using AddOutput to change keyvalues
Because of the way outputs work, AddOutput also allows changing any entity's keyvalues. This includes targetname, origin, angles, mins/maxs, solid and more. As this is not something AddOutput was designed for, not all keys will work as expected when changed this way.
Syntax: <key> <value>
Due to how much AddOutput lets you manipulate entities properties it might be therefore a way to optimize maps which utilize env_entity_maker, point_teleport, game_text and more which count as edict.
 Tip:Abusing AddOutput too much makes your map harder to understand. Avoid abusing it unless necessary for your use case.
Tip:Abusing AddOutput too much makes your map harder to understand. Avoid abusing it unless necessary for your use case. Code:If simply changing some keyvalue should be intended feature of an entity it should be defined using DEFINE_INPUT. That way the key is both keyvalue and input at once so the parameter_override can be utilized by outputs. Examples of such keyvalues: skin, fademindist, fademaxdist. (potential confusion: these "input keys" aren't auto completed when using
Code:If simply changing some keyvalue should be intended feature of an entity it should be defined using DEFINE_INPUT. That way the key is both keyvalue and input at once so the parameter_override can be utilized by outputs. Examples of such keyvalues: skin, fademindist, fademaxdist. (potential confusion: these "input keys" aren't auto completed when using ent_fire) Examples of keyvalues whose change might not have desired effect
- classname
- classname is first key read from a map file and determines what C++ class to use to spawn an entity, therefore changing this later via AddOutput will not truly change an entity into a different one. But there are sometimes checks in code that determine some behavior purely on the value of classnamefor example see Preserved entities. ([Todo] some more example)
 Warning:Doing this in games with save files is not advised, as saving an entity with the wrong classname means it won't be recreated properly (or at all). Warning:Doing this in games with save files is not advised, as saving an entity with the wrong classname means it won't be recreated properly (or at all).
 Warning:Changing the classname of a player causes problems and should be avoided at all costs. Warning:Changing the classname of a player causes problems and should be avoided at all costs.
 Note:Certain entities rely upon classname, so this is generally discouraged. Note:Certain entities rely upon classname, so this is generally discouraged.
- parentname
- Won't have an effect when changed via AddOutput as parent/child hierarchy is setup when all entities are being spawned and not later.
- SourceEntityName of ambient_generic
- ambient_generic searches for the entity named SourceEntityName when it spawns so changing it later via AddOutput won't have an effect.
 Note:Whenever changing a keyvalue via AddOutput doesn't do what's expected, the usual reason is that the entity only is working with the given keyvalue during spawning process.
Note:Whenever changing a keyvalue via AddOutput doesn't do what's expected, the usual reason is that the entity only is working with the given keyvalue during spawning process.Limitations
- It's not possible to add an output with this that uses AddContext input because AddContext also uses ':' in its syntax.
- Colons (:) are automatically converted to commas when parsed by AddOutput. As such, standard colons are unavailable to be used by values set by AddOutput, which mainly impacts entities such as game_text which let the mapper set some custom text.
- Since AddOutput uses a space in its syntax, outputs and keyvalues which have spaces cannot be modified. Fortunately, this is unlikely to ever be an issue, as no vanilla entities use spaces for these.
Firing AddOutput via ent_fire
Because AddOutput uses a space in its syntax, it's required to enclose the ent_fire parameter in quotes.
To add output:
ent_fire <entity name> addoutput "<output> <target>:[input]:[parameter_override]:[delay]:[times to fire]"
To change keyvalue:
ent_fire <entity name> addoutput "<key> <value>"
Examples
- Format: <key> <value>
{
"classname" "trigger_once"
.
.
.
'OnStartTouch" "game_text,AddOutput,message There is a fire ahead. Go the other way!,0,1
'OnStartTouch" "game_text,Display,,0.02,1
} 
This changes the text of a game_text and then displays it. This is useful as to prevent having an unneccesary amount of game_text which counts as edict
- Format: <output> <targetname>:<input>:<parameter>:<delay>:<refire>
{
"classname" "logic_auto"
.
.
.
'OnMapSpawn" "team_round_timer_red,AddOutput,OnFinished game_round_win:RoundWin::0:-1,0,-1
}
This adds an output to an entity with the targetname "team_round_timer_red".
- Trigger_Multiple
- Name: Ghost
- Outputs
- My Output Named: OnEndTouch
- Targets entities named: !activator
- Via this input: Alpha
- With a parameter override of: 255
- After a delay in seconds: 0.10
- My Output Named: OnStartTouch
- Targets entities named: !activator
- Via this input: AddOutput
- With a parameter override of: rendermode 1
- After a delay in seconds: 0.00
- My Output Named: OnStartTouch
- Targets entities named: !activator
- Via this input: Alpha
- With a parameter override of: 120
- After a delay in seconds: 0.00
Results in translucent player when standing in the trigger_multiple (OnStartTouch) and visible again when not in the trigger_multiple (OnEndTouch).
Advanced Examples
- Description: Forces player to jump (Quake Jump Pad Style) possible left over Quake Engine code.
- Notes: The effect can take affect after the player has completely left the trigger if you add a longer time delay. (Or Add multiple small delays like delay:0.05, delay:0.10, to mimic Double Jump.)
- Tips: 250 is a small jump (set any higher value) you can set -250 to do increase player fall speed too.
:func_button - You can use trigger_multiple etc button is unique but for Jump Pads use trigger_multiple. My output named: OnPressed Target entities named: !activator Via this input: AddOutput With a parameter override of: basevelocity 0 0 250 delay: 0.00
- Description: Forces a player to be pushed hard (Different to trigger_push)
- Notes: The push effect can trigger after the player has completely left the trigger but only if you add a longer time delay. This is something trigger_push can't do as the player as to be touching for push effects to happen.
:trigger_multiple - You can use func_button too. My output named: Ontrigger Target entities named: !activator Via this input: AddOutput With a parameter override of: basevelocity 0 500 0 delay: 0.00
- Description: A Special way to teleport nealry anything that has a name. (No extra teleport entities needed)
- Notes: To quickly work out the teleport origin just make a func_brush place it anywhere you want your object to be teleported in the map and copy the origin numbers from Object Properties and then delete the func_brush.
:func_button - You can use trigger_multiple etc. My output named: OnPressed Target entities named: !activator Via this input: AddOutput With a parameter override of: origin -927 706 469 delay: 0.00
See alsо
- Optimizing Edict's & Mapping Tricks - Using AddOutput to reduce mapspawn edicts on really large maps


























