Info gamemode: Difference between revisions

From Valve Developer Community
Jump to navigation Jump to search
mNo edit summary
 
(43 intermediate revisions by 14 users not shown)
Line 1: Line 1:
== Entity description ==
{{LanguageBar}}
{{CD|CInfoGameMode}}
{{this is a|logical entity|sprite=1|name=info_gamemode|series=Left 4 Dead}} When a map is loaded, this entity can fire outputs depending on the current base [[mode file|game mode]]. This allows the main base game modes to be available in a single map instead of having separate maps for each base game mode.{{clr}}
{{Note|This entity counts as an [[edict]]. There is also not much reason to use more than one per map as the entity can hold any number of outputs.}}


When a map is loaded, this entity can fire outputs depending on the current game mode.
== Outputs ==
{{O|OnCoop}}
{{O|OnVersus}}
{{O|OnSurvival}}
{{O|OnScavenge|Fired when the map spawns in the respective base mode.<!--
-->{{Note|OnCoop fires in realism too.}}<!--
-->{{Confusion|The base game mode is not necessarily the 'root' game mode. For example, OnCoop won't fire for a mutation that inherits from ({{code|base}} is) a derived game mode, like mutation5 (Four Swordsmen), as expected.}}<!--
-->{{Bug|Killing the info_gamemode itself in one of these outputs with 0 delay crashes the game.|tested=l4d2}}}}


== Keyvalues ==
{{O|OnCoopPostIO|only={{l4d2}}}}
* {{KV Targetname}}
{{O|OnVersusPostIO|only={{l4d2}}}}
* {{KV Angles}}
{{O|OnSurvivalPostIO|only={{l4d2}}}}
{{O|OnScavengePostIO|Fired shortly after all scavenge items have been populated.<!--
-->{{Note|This doesn't mean item populating causes the output to be fired, mentioning item being populated just as a frame of reference.}}<!--
-->{{Tip|Useful when wanting to spawn templated weapon_* entities and not have it affected by info_map_parameters densities. {{confirm}}}}<!--
-->{{Confusion|Description in FGD is not correct. This output does fire later than On<Mode> outputs but it doesn't wait until IO generated by it finishes. Doesn't even wait for the delays specified in On<Mode> outputs to expire.}}|only={{l4d2}}}}
 
{{Note|If the base game mode of the played mode is something other than coop, realism, versus, scavenge or survival (for example, in mutations like dash, holdout or shootzones), no output will fire.}}
 
{{O|OnScavengeMatchStart|Fired on the first map load of a scavenge match. Doesn't fire on round restarts.<!--
-->{{Note|Fires shortly after OnGameplayStart of info_director is fired.}}|only={{l4d2}}}}
{{O|OnNavAnalyze|Fired when the map is loaded with -navanalyze on the command line.|only={{l4d2}}}}


== Inputs ==
== Inputs ==
* {{I Targetname}}
{{I|PostSpawnActivate|Called internally and causes On<Mode> output to fire.<!--
-->{{Warning|Crashes the game via infinite recursion if used by [[I/O]] system. Internally, it's called using the AcceptInput function which isn't exposed to vscript.}}|nofgd=1}}
{{I|PreRoundActivate|Called internally and causes On<Mode>PostIO output to fire.|nofgd=1}}
{{I|FireScavengeMatchStart|Called internally and causes OnScavengeMapStart output to fire.|nofgd=1}}


== Outputs - omit if none exist ==
{{Idea|Vscripts [[Left 4 Dead 2/Script Functions#Hooks|Input{{!(}}InputName{{)!}}]] hook can be used on these.<!--
* {{O Targetname}}
-->{{Todo|What happens when preventing these to fire by returning false?}}}}
* '''OnCoop'''
: Fired when the map spawns in coop games.
* '''OnVersus'''
: Fired when the map spawns in versus games.
* '''OnSurvival'''
: Fired when the map spawns in survival games.


== See also ==
== See also ==
* {{ent|logic_auto}}
* [[Left 4 Dead Level Creation]]
* [[Left 4 Dead Level Creation]]
* [[Left 4 Dead 2 Level Creation]]
* [[Left 4 Dead 2 Level Creation]]
* [[L4D Level Design/Versus Maps]]
* [[L4D2 Level Design]]
* [[L4D2 Level Design/Multi-Gamemode Support]]
* [[L4D2 Level Design/VMF Instances]]
* [[L4D2 Level Design/Scavenge Maps]]
* [[Survival Gametype (L4D)]]
* [[Survival Gametype (L4D)]]
[[Category:Left 4 Dead Entities]]
[[Category:Left 4 Dead 2 Entities]]

Latest revision as of 22:35, 12 October 2025

English (en)Translate (Translate)
C++ Class hierarchy
CInfoGameMode
CBaseEntity
Info gamemode.png

info_gamemode is a logical entity available in Left 4 Dead seriesLeft 4 Dead series Left 4 Dead series. When a map is loaded, this entity can fire outputs depending on the current base game mode. This allows the main base game modes to be available in a single map instead of having separate maps for each base game mode.

Note.pngNote:This entity counts as an edict. There is also not much reason to use more than one per map as the entity can hold any number of outputs.

Outputs

OnCoop
OnVersus
OnSurvival
OnScavenge
Fired when the map spawns in the respective base mode.
Note.pngNote:OnCoop fires in realism too.
Warning.pngRisk of Confusion:The base game mode is not necessarily the 'root' game mode. For example, OnCoop won't fire for a mutation that inherits from (base is) a derived game mode, like mutation5 (Four Swordsmen), as expected.
Icon-Bug.pngBug:Killing the info_gamemode itself in one of these outputs with 0 delay crashes the game.  (tested in: l4d2)


OnCoopPostIO  (only in Left 4 Dead 2)
OnVersusPostIO  (only in Left 4 Dead 2)
OnSurvivalPostIO  (only in Left 4 Dead 2)
OnScavengePostIO  (only in Left 4 Dead 2)
Fired shortly after all scavenge items have been populated.
Note.pngNote:This doesn't mean item populating causes the output to be fired, mentioning item being populated just as a frame of reference.
Tip.pngTip:Useful when wanting to spawn templated weapon_* entities and not have it affected by info_map_parameters densities. [confirm]
Warning.pngRisk of Confusion:Description in FGD is not correct. This output does fire later than On<Mode> outputs but it doesn't wait until IO generated by it finishes. Doesn't even wait for the delays specified in On<Mode> outputs to expire.
Note.pngNote:If the base game mode of the played mode is something other than coop, realism, versus, scavenge or survival (for example, in mutations like dash, holdout or shootzones), no output will fire.


OnScavengeMatchStart  (only in Left 4 Dead 2)
Fired on the first map load of a scavenge match. Doesn't fire on round restarts.
Note.pngNote:Fires shortly after OnGameplayStart of info_director is fired.
OnNavAnalyze  (only in Left 4 Dead 2)
Fired when the map is loaded with -navanalyze on the command line.

Inputs

PostSpawnActivate  !FGD
Called internally and causes On<Mode> output to fire.
Warning.pngWarning:Crashes the game via infinite recursion if used by I/O system. Internally, it's called using the AcceptInput function which isn't exposed to vscript.
PreRoundActivate  !FGD
Called internally and causes On<Mode>PostIO output to fire.
FireScavengeMatchStart  !FGD
Called internally and causes OnScavengeMapStart output to fire.
Tip.pngIdea:Vscripts Input[InputName] hook can be used on these.
Todo: What happens when preventing these to fire by returning false?

See also