Game text: Difference between revisions
|  (Added warning about incorrect scale for players with big monitor resolutions) | No edit summary | ||
| (41 intermediate revisions by 25 users not shown) | |||
| Line 1: | Line 1: | ||
| {{ | {{LanguageBar}} | ||
| [[Category:GUI Entities]] | |||
| {{CD|CGameText|file1=maprules.cpp}}  | |||
| {{tabs|game_text|goldsrc=1|source=2|main=source}} | |||
| [[File:Game text.png|left|link=]] | |||
| {{This is a|logical entity|name=game_text|except-multi={{L4d2|4}}}}{{cite|1}} | |||
| This entity displays text on player's screens. This text can be defined directly in the Hammer editor (unlike the similar {{ent|env_message}} entity, which uses the <code>[[titles.txt]]</code> file). In multiplayer games, the text will normally only display for the activator of the "Display" input. The "All Players" flag can be ticked in order to display on the screens of all players. | |||
| {{ | {{note|If you are creating a mod with its own files and scripts, it's recommended to use the aforementioned <tt>env_message</tt> entity, which uses the <code>titles.txt</code> script for text parameters instead of keyvalues, allowing the text to be changed without having to recompile any maps. It also supports newlines and quotation marks, unlike regular <code>game_text</code>.}} | ||
| {{tip|Despite comments stating otherwise, <code>game_text</code> supports localized strings (e.g., <tt>#HL2_Chapter4_Title</tt>) in most or all Source games.}} | |||
| {{Warning|VMFs can become corrupted when using quotation marks (<tt>"</tt>) in any entity's keyvalues or I/O, so quotation marks cannot be used in the ''Text Message'' field (not even <tt>\"</tt> characters). You can use two apostrophes (<tt><nowiki>''</nowiki></tt>) or detailed quotes (i.e., <tt>“</tt> and <tt>”</tt>) instead.}} | |||
| __TOC__ | |||
| == Caveats == | |||
| <code>Game_text</code> works as a [[HUD]] element, specifically, a {{code|HudMessage}} element, defined in {{path|<nowiki>/scripts/HudLayout</nowiki>|txt}}.  | |||
| Because it was created aiming at low-resolution monitors (owing to Source's age), it is by default restricted to scaling based on 640x480 resolution. | |||
| This causes it to scale incorrectly at resolutions higher than 1920x1080. Text will be much larger and some text will be hidden. | |||
| It also causes it to only use a limited region of the screen for drawing, and long lines of text, or text near the edges, get cropped on widescreen. This affects other text that uses {{code|HudMessage}}, such as the infamous "A. I. Disabled" message.  | |||
| {{ | {{fix|Go to {{path|<nowiki>/scripts/HudLayout</nowiki>|txt}} and find the section "HudMessage". Change its <code>"wide"</code> and <code>"tall"</code> values (default: 640 and 480) to "f0" (full size of the viewport). This will increase the maximum size of the invisible VGUI screen that text appears on, making it scale above 1920x1080 resolutions.{{inline note|name=Tested on 2k, 4k, and ultrawide resolutions. Does this work on all resolutions?}}}} | ||
| == Flags == | |||
| {{Fl|1|All Players|If this is not set, the message will only show to [[!activator]].}} | |||
| {{ | |||
| == Keyvalues == | == Keyvalues == | ||
| {{KV Targetname}} | {{KV Targetname}} | ||
| {{KV|Message Text|intn=message|string|Message to display onscreen. <tt>\n</tt> signifies a new line in the text.}} | |||
| ==  | :{{bug|Hammer will automatically change backslashes to forward slashes, making <tt>\n</tt> impossible to enter.<!-- | ||
| * 1 :  | -->{{workaround|<ul><!-- | ||
| --><li> Edit the VMF with a text editor, although this will need to be reapplied after each save<!-- | |||
| --><li> Edit the BSP entity lump with a hex editor, although this will need to be reapplied after each compile<!-- | |||
| --><li> Use [[AddOutput]] to set the message, as outputs are not affected</ul>}}<!-- | |||
| -->{{tip|{{hammerpp|2}} does not do this.}} }} | |||
| {{KV|X (0 - 1.0 {{=}} left to right) (-1 centers)|intn=x|string|Horizontal position on the player's screens to draw the text. The value should be between 0 and 1, where 0 is the far left of the screen and 1 is the far right. -1 centers the text.}} | |||
| {{KV|Y (0 - 1.0 {{=}} top to bottom) (-1 centers)|intn=y|string|Vertical position on the player's screens to draw the text. The value should be between 0 and 1, where 0 is the top of the screen and 1 is the bottom. -1 centers the text.}} | |||
| {{KV|Text Effect|intn=effect|choices|Text scan effect}} | |||
| :*0: Fade In/Out. The whole text is faded in, and then faded out. | |||
| :*1: Credits {{todo|Unknown—seems to act like Fade In/Out. Provide description.}} | |||
| :*2: Scan Out. The text is scanned in letter by letter, and the whole text is then faded out. | |||
| {{KV|Color1|intn=color|color255|The primary color used by all the text effects. {{note|The color values seem to be added to the background, so either a bright white background or black text will cause the message to be invisible.}} {{note|This keyvalue will default to black for entities not created in Hammer.}} }} | |||
| {{KV|Color2|intn=color2|color255|The scanning color for the letter being scanned if the ''Text Effect'' keyvalue is set to ''Scan Out''—usually a different shade of Color1.}} | |||
| {{KV|Fade in Time (or character scan time)|intn=fadein|string|The time it should take for the text to fully fade in.}} | |||
| {{KV|Fade Out Time|intn=fadeout|string|The time it should take for the text to fade out, after the hold time has expired.}} | |||
| {{KV|Hold Time|intn=holdtime|string|The time the text should stay onscreen, after fading in, before it begins to fade out.{{note|This value defaults to zero for entities not created in Hammer.}}}} | |||
| {{KV|Scan time (scan effect only)|intn=fxtime|string|If the 'Text Effect' is set to Scan Out, this is the time it should take to scan out all the letters in the text.}} | |||
| {{KV|Text Channel|intn=channel|choices|You can have up to six individual <tt>game_text</tt> messages onscreen at once, stored in channels. Select which channel this text should be placed in, which will overwrite any active message already in that channel.}} | |||
| :*0: Channel 0 (may be used by some HUD elements) {{Not in FGD}} | |||
| :*1: Channel 1 | |||
| :*2: Channel 2 ({{portal2}} Small text size) | |||
| :*3: Channel 3 ({{portal2}} Large text size) | |||
| :*4: Channel 4 | |||
| :*5: Channel 5 (may be used by some HUD elements) {{Not in FGD}} | |||
| {{warning|Some HUDs may use Channel 0 and/or Channel 5.}} | |||
| {{KV|Master|intn=master|string|Legacy support: The name of a master entity. If the master hasn't been activated, this entity will not activate.}} | |||
| == Inputs == | == Inputs == | ||
| {{ | {{I|Display|Display the message text.{{note|If the All Players flag is not set, the player must be the [[!activator]] of this input in order for the text to be shown.}}}} | ||
| {{ | {{I|SetText|Set the text to display.|param=string|since={{as}}}} | ||
| {{tip| | {{tip|<code>[[AddOutput]] message</code>can be used to change text at runtime in older games which do not support <tt>SetText</tt>, although the <code>Display</code> input must be fired again.}} | ||
| {{ | {{I|SetPosX|Set the X position of the text. (0 - 1.0 {{=}} left to right) (-1 centers)|param=float|since={{portal2}}}} | ||
| {{ | {{I|SetPosY|Set the Y position of the text. (0 - 1.0 {{=}} top to bottom) (-1 centers)|param=float|since={{portal2}}}} | ||
| {{ | {{I|SetTextColor|Set color of the front text.|param=color255|since={{portal2}}}} | ||
| {{ | {{I|SetTextColor2|Set color of the transition text.|param=color255|since={{portal2}}}} | ||
| {{ | |||
| == See also == | == See also == | ||
| *  | * {{ent|game_text_tf}} - {{tf2}} Displays a custom HUD message with icons on a specified team's screen. | ||
| * [[Customizable triggered HUD-message]] - How to create a new entity that is similar to  | * {{ent|point_worldtext}} - {{tf2}}{{csgo}} A similar entity that displays a custom message in the world with far more flexibility. | ||
| * {{ent|training_annotation}} - {{tf2}} A similar entity that points to a specified location in the world. | |||
| * {{ent|env_hudhint}} - Displays a custom HUD message.  Commonly used to show key-binds.  | |||
| * {{ent|env_message}} - Displays a pre-defined message on the players screen. | |||
| * {{ent|point_message}} - A similar entity that displays a small custom message at a specific position in the game world. | |||
| * [[Customizable triggered HUD-message]] - How to create a new entity that is similar to <tt>game_text</tt> but can receive the message string via a triggered input. | |||
| [ | {{References| 1 = | ||
| {{ref2|cite id=1|author=BHaType|url=https://forums.alliedmods.net/showthread.php?t=340355|title = <nowiki>[L4D2]</nowiki> Why game_text doesn't work and what can we do?|website = AlliedModders.net|date=13 November, 2022|}} | |||
| }} | |||
Latest revision as of 16:31, 25 August 2025
|  Class hierarchy | 
|---|
| CGameText | 
|  maprules.cpp | 

game_text  is a   logical entity  available in all  Source games except
 Source games except  Left 4 Dead 2.[1]
This entity displays text on player's screens. This text can be defined directly in the Hammer editor (unlike the similar env_message entity, which uses the
 Left 4 Dead 2.[1]
This entity displays text on player's screens. This text can be defined directly in the Hammer editor (unlike the similar env_message entity, which uses the titles.txt file). In multiplayer games, the text will normally only display for the activator of the "Display" input. The "All Players" flag can be ticked in order to display on the screens of all players.
 Note:If you are creating a mod with its own files and scripts, it's recommended to use the aforementioned env_message entity, which uses the
Note:If you are creating a mod with its own files and scripts, it's recommended to use the aforementioned env_message entity, which uses the titles.txt script for text parameters instead of keyvalues, allowing the text to be changed without having to recompile any maps. It also supports newlines and quotation marks, unlike regular game_text. Tip:Despite comments stating otherwise,
Tip:Despite comments stating otherwise, game_text supports localized strings (e.g., #HL2_Chapter4_Title) in most or all Source games. Warning:VMFs can become corrupted when using quotation marks (") in any entity's keyvalues or I/O, so quotation marks cannot be used in the Text Message field (not even \" characters). You can use two apostrophes ('') or detailed quotes (i.e., “ and ”) instead.
Warning:VMFs can become corrupted when using quotation marks (") in any entity's keyvalues or I/O, so quotation marks cannot be used in the Text Message field (not even \" characters). You can use two apostrophes ('') or detailed quotes (i.e., “ and ”) instead.Caveats
Game_text works as a HUD element, specifically, a HudMessage element, defined in 
/scripts/HudLayout.txt. 
Because it was created aiming at low-resolution monitors (owing to Source's age), it is by default restricted to scaling based on 640x480 resolution.
This causes it to scale incorrectly at resolutions higher than 1920x1080. Text will be much larger and some text will be hidden.
It also causes it to only use a limited region of the screen for drawing, and long lines of text, or text near the edges, get cropped on widescreen. This affects other text that uses HudMessage, such as the infamous "A. I. Disabled" message. 
 Fix:Go to
Fix:Go to 
/scripts/HudLayout.txt and find the section "HudMessage". Change its "wide" and "tall" values (default: 640 and 480) to "f0" (full size of the viewport). This will increase the maximum size of the invisible VGUI screen that text appears on, making it scale above 1920x1080 resolutions.[Tested on 2k, 4k, and ultrawide resolutions. Does this work on all resolutions?]Flags
- All Players : [1]
- If this is not set, the message will only show to !activator.
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
- Message Text (message) <string>
- Message to display onscreen. \n signifies a new line in the text.
 Bug:Hammer will automatically change backslashes to forward slashes, making \n impossible to enter. Bug:Hammer will automatically change backslashes to forward slashes, making \n impossible to enter. Workaround: Workaround:- Edit the VMF with a text editor, although this will need to be reapplied after each save
- Edit the BSP entity lump with a hex editor, although this will need to be reapplied after each compile
- Use AddOutput to set the message, as outputs are not affected
 [todo tested in ?] Tip: Tip: Hammer++ does not do this. Hammer++ does not do this.
- X (0 - 1.0 = left to right) (-1 centers) (x) <string>
- Horizontal position on the player's screens to draw the text. The value should be between 0 and 1, where 0 is the far left of the screen and 1 is the far right. -1 centers the text.
- Y (0 - 1.0 = top to bottom) (-1 centers) (y) <string>
- Vertical position on the player's screens to draw the text. The value should be between 0 and 1, where 0 is the top of the screen and 1 is the bottom. -1 centers the text.
- Text Effect (effect) <choices>
- Text scan effect
- 0: Fade In/Out. The whole text is faded in, and then faded out.
- 1: Credits Todo: Unknown—seems to act like Fade In/Out. Provide description.
- 2: Scan Out. The text is scanned in letter by letter, and the whole text is then faded out.
 
- Color1 (color) <color255>
- The primary color used by all the text effects.  Note:The color values seem to be added to the background, so either a bright white background or black text will cause the message to be invisible. Note:The color values seem to be added to the background, so either a bright white background or black text will cause the message to be invisible. Note:This keyvalue will default to black for entities not created in Hammer. Note:This keyvalue will default to black for entities not created in Hammer.
- Color2 (color2) <color255>
- The scanning color for the letter being scanned if the Text Effect keyvalue is set to Scan Out—usually a different shade of Color1.
- Fade in Time (or character scan time) (fadein) <string>
- The time it should take for the text to fully fade in.
- Fade Out Time (fadeout) <string>
- The time it should take for the text to fade out, after the hold time has expired.
- Hold Time (holdtime) <string>
- The time the text should stay onscreen, after fading in, before it begins to fade out. Note:This value defaults to zero for entities not created in Hammer. Note:This value defaults to zero for entities not created in Hammer.
- Scan time (scan effect only) (fxtime) <string>
- If the 'Text Effect' is set to Scan Out, this is the time it should take to scan out all the letters in the text.
- Text Channel (channel) <choices>
- You can have up to six individual game_text messages onscreen at once, stored in channels. Select which channel this text should be placed in, which will overwrite any active message already in that channel.
 Warning:Some HUDs may use Channel 0 and/or Channel 5.
Warning:Some HUDs may use Channel 0 and/or Channel 5.- Master (master) <string>
- Legacy support: The name of a master entity. If the master hasn't been activated, this entity will not activate.
Inputs
- Display
- Display the message text. Note:If the All Players flag is not set, the player must be the !activator of this input in order for the text to be shown. Note:If the All Players flag is not set, the player must be the !activator of this input in order for the text to be shown.
 Tip:
Tip:AddOutput messagecan be used to change text at runtime in older games which do not support SetText, although the Display input must be fired again.- SetPosX  <float> (in all games since  ) )
- Set the X position of the text. (0 - 1.0 = left to right) (-1 centers)
- SetPosY  <float> (in all games since  ) )
- Set the Y position of the text. (0 - 1.0 = top to bottom) (-1 centers)
See also
- game_text_tf -  Displays a custom HUD message with icons on a specified team's screen. Displays a custom HUD message with icons on a specified team's screen.
- point_worldtext -   A similar entity that displays a custom message in the world with far more flexibility. A similar entity that displays a custom message in the world with far more flexibility.
- training_annotation -  A similar entity that points to a specified location in the world. A similar entity that points to a specified location in the world.
- env_hudhint - Displays a custom HUD message. Commonly used to show key-binds.
- env_message - Displays a pre-defined message on the players screen.
- point_message - A similar entity that displays a small custom message at a specific position in the game world.
- Customizable triggered HUD-message - How to create a new entity that is similar to game_text but can receive the message string via a triggered input.
References
| References | ||
|---|---|---|
| 
 | 



























