Game ui: Difference between revisions
		
		
		
		
		
		Jump to navigation
		Jump to search
		
				
		
 Note:You must have one instance of game_ui per player in multiplayer as each game_ui only activates for one player at a time.
Note:You must have one instance of game_ui per player in multiplayer as each game_ui only activates for one player at a time.
 Note:Bots can use this entity and fire its outputs.
Note:Bots can use this entity and fire its outputs.
 Bug:Due to an oversight, game_ui will disable client prediction causing laggy behavior on multiplayer.  [todo tested in ?]
Bug:Due to an oversight, game_ui will disable client prediction causing laggy behavior on multiplayer.  [todo tested in ?]
		
	
| m (Robot: fixing template case.) | m (Substituted IO templates) | ||
| (24 intermediate revisions by 16 users not shown) | |||
| Line 1: | Line 1: | ||
| {{ | :''Not to be confused with [[GameUI]].'' | ||
| {{ | __NOTOC__ | ||
| {{CD|CGameUI|file1=game_ui.cpp}} | |||
| {{this is a|point entity|name=game_ui|engine=Source}} It redirects important player key presses to a series of outputs, and can be used to make the player control vehicles built in a map. It can be activated with I/O, or by the player looking at it. | |||
| {{note|You must have one instance of game_ui per player in multiplayer as each game_ui only activates for one player at a time.}} | |||
| {{note|Bots can use this entity and fire its outputs.}} | |||
| {{bug|Due to an oversight, game_ui will disable client prediction causing laggy behavior on multiplayer.}} | |||
| == Keyvalues == | == Keyvalues == | ||
| {{KV Targetname}} | |||
| {{KV|FieldOfView|intn=FieldOfView|float|The amount of tolerance in the view checking when determining whether the player's input is still under control.}} | |||
| :*'''1.0''' = '''straight ahead''' | |||
| :*'''0.0''' = '''+/- 90 degrees''' | |||
| :*'''-1.0''' = '''all directions''' | |||
| == Flags == | == Flags == | ||
| {{fl|32|Freeze Player - The player cannot move (they can still crouch though)}} | |||
| {{fl|64|Hide Weapon - Disables all the player's weapons | |||
| ::{{note|This will cause the player to go into their reference (T) pose.}}}} | |||
| {{fl|128|+Use Deactivates}} | |||
| {{fl|256|Jump Deactivates}} | |||
| == Inputs == | == Inputs == | ||
| {{I|Activate|The [[!activator]] will gain control upon this input being fired.}} | |||
| {{I|Deactivate|The entity will only test FieldOfView if it is active.{{bug|The game will crash if the <code>Deactivate</code> input is fired on a game_ui that was activated by a player who has since disconnected. Fixed in {{tf2|2}}}}{{workaround|[[AddOutput]]ing OnUsers to a player and using a [[logic_branch]] together can be sufficient to workaround this. If the game supports it, [[VScript]] can also be used to check if the player entity still exists before firing the input.}}}} | |||
| == Outputs == | == Outputs == | ||
| The player is always the [[!activator]]. | |||
| {{O|PlayerOn}} | |||
| {{O|PlayerOff|Fired when the entity starts or stops controlling the player's input.|since=}} | |||
| {{O|PressedMoveLeft}} | |||
| {{O|UnpressedMoveLeft|Fired on +moveleft/-moveleft|since=EP2}} | |||
| {{O|PressedMoveRight}} | |||
| {{O|UnpressedMoveRight|Fired on +moveright/-moveright|since=EP2}} | |||
| ::{{bug|The left/right movement outputs do not fire when using a controller. {{elaborate|game this was tested in}} }} | |||
| {{O|PressedForward}} | |||
| {{O|UnpressedForward|Fired on +forward/-forward|since=EP2}} | |||
| {{O|PressedBack}} | |||
| {{O|UnpressedBack|Fired on +back/-back|since=EP2}} | |||
| : | {{O|PressedAttack}} | ||
| {{O|UnpressedAttack|Fired on +attack/-attack|since=EP2}} | |||
| {{O|PressedAttack2}} | |||
| {{O|UnpressedAttack2|Fired on +attack2/-attack2|since=EP2}} | |||
| {{O|XAxis|param=float}} | |||
| {{O|YAxis|param=float|Fired whenever the X/Y axis of the player's input changes.}} | |||
| :* -1.0 = +moveleft / +back at 100% speed | |||
| :* 0 = no movement in this axis | |||
| :* +1.0 = +moveright / +forward at 100% speed | |||
| {{O|AttackAxis|param=float}} | |||
| {{O|Attack2Axis|param=float|An output that fires whenever the state of the player's "attack" key changes.}} | |||
| :* 1.0 = trigger is 100% depressed | |||
| :* 0 = trigger is at rest | |||
| ::{{note|These do not actually output analog values, even when using an analog stick; it will only be <code>1</code>, <code>0</code>, or <code>-1</code> depending on which keys are considered pressed. (Because of the above bug, this also means that <code>XAxis</code> never fires when using a controller.) {{elaborate|game this was tested in}} }} | |||
| [[Category:Level Design]] | |||
| : | |||
| * | |||
| : | |||
| :{{ | |||
Latest revision as of 21:44, 19 April 2025
- Not to be confused with GameUI.
|  Class hierarchy | 
|---|
| CGameUI | 
|  game_ui.cpp | 
game_ui  is a   point entity  available in all  Source games. It redirects important player key presses to a series of outputs, and can be used to make the player control vehicles built in a map. It can be activated with I/O, or by the player looking at it.
 Source games. It redirects important player key presses to a series of outputs, and can be used to make the player control vehicles built in a map. It can be activated with I/O, or by the player looking at it.
 Note:You must have one instance of game_ui per player in multiplayer as each game_ui only activates for one player at a time.
Note:You must have one instance of game_ui per player in multiplayer as each game_ui only activates for one player at a time. Note:Bots can use this entity and fire its outputs.
Note:Bots can use this entity and fire its outputs. Bug:Due to an oversight, game_ui will disable client prediction causing laggy behavior on multiplayer.  [todo tested in ?]
Bug:Due to an oversight, game_ui will disable client prediction causing laggy behavior on multiplayer.  [todo tested in ?]Keyvalues
- Name (targetname) <string>[ Edit ]
- The name that other entities refer to this entity by, via Inputs/Outputs or other keyvalues (e.g. parentnameortarget).
 Also displayed in Hammer's 2D views and Entity Report.See also: Generic Keyvalues, Inputs and Outputs available to all entities
- FieldOfView (FieldOfView) <float>
- The amount of tolerance in the view checking when determining whether the player's input is still under control.
- 1.0 = straight ahead
- 0.0 = +/- 90 degrees
- -1.0 = all directions
 
Flags
- Freeze Player - The player cannot move (they can still crouch though) : [32]
- Hide Weapon - Disables all the player's weapons
- 
- : [64] Note:This will cause the player to go into their reference (T) pose. Note:This will cause the player to go into their reference (T) pose.
 
- +Use Deactivates : [128]
- Jump Deactivates : [256]
Inputs
- Activate
- The !activator will gain control upon this input being fired.
- Deactivate
- The entity will only test FieldOfView if it is active. Bug:The game will crash if the Bug:The game will crash if theDeactivateinput is fired on a game_ui that was activated by a player who has since disconnected. Fixed in Team Fortress 2  [todo tested in ?] Team Fortress 2  [todo tested in ?] Workaround:AddOutputing OnUsers to a player and using a logic_branch together can be sufficient to workaround this. If the game supports it, VScript can also be used to check if the player entity still exists before firing the input. Workaround:AddOutputing OnUsers to a player and using a logic_branch together can be sufficient to workaround this. If the game supports it, VScript can also be used to check if the player entity still exists before firing the input.
Outputs
The player is always the !activator.
- PlayerOn
- PlayerOff
- Fired when the entity starts or stops controlling the player's input.
- PressedMoveLeft
- UnpressedMoveLeft   (in all games since  ) )
- Fired on +moveleft/-moveleft
- PressedMoveRight
- UnpressedMoveRight   (in all games since  ) )
- Fired on +moveright/-moveright
 Bug:The left/right movement outputs do not fire when using a controller. Elaborate?: game this was tested in[todo tested in ?] Bug:The left/right movement outputs do not fire when using a controller. Elaborate?: game this was tested in[todo tested in ?]
 
- PressedForward
- UnpressedForward   (in all games since  ) )
- Fired on +forward/-forward
- PressedBack
- UnpressedBack   (in all games since  ) )
- Fired on +back/-back
- PressedAttack
- UnpressedAttack   (in all games since  ) )
- Fired on +attack/-attack
- PressedAttack2
- UnpressedAttack2   (in all games since  ) )
- Fired on +attack2/-attack2
- XAxis <float>
- YAxis <float>
- Fired whenever the X/Y axis of the player's input changes.
- -1.0 = +moveleft / +back at 100% speed
- 0 = no movement in this axis
- +1.0 = +moveright / +forward at 100% speed
 
- AttackAxis <float>
- Attack2Axis <float>
- An output that fires whenever the state of the player's "attack" key changes.
- 1.0 = trigger is 100% depressed
- 0 = trigger is at rest
  Note:These do not actually output analog values, even when using an analog stick; it will only be Note:These do not actually output analog values, even when using an analog stick; it will only be- 1,- 0, or- -1depending on which keys are considered pressed. (Because of the above bug, this also means that- XAxisnever fires when using a controller.)Elaborate?: game this was tested in
 
