Point worldtext: Difference between revisions
|  (Created page with "point_worldtext  An entity in CSGO that allows players to put messages in game  You can use the addoutput command to send messages directly to the point_worldtext to update it...") | m (→Inputs:   SetMessage is indeed fixed in JBEP3) | ||
| (63 intermediate revisions by 24 users not shown) | |||
| Line 1: | Line 1: | ||
| point_worldtext | {{LanguageBar}} | ||
| {{ent not in fgd}} | |||
| {{CD|CPointWorldText|base=CBaseEntity|file1=1}} | |||
| {{this is a|point entity|name=point_worldtext|since=Counter-Strike: Global Offensive}} {{also|{{tf2branch}}{{gmod}}}} | |||
| [[File:Point worldtext csgo example.jpg|thumb|right|Example text generated by two point_worldtext entities]] It is an entity that displays a text message oriented in the world, at its origin. | |||
| == Usage == | |||
| {{todo|Update this description for {{tf2branch|2}} games, which has a completely different implementation.}} | |||
| You can use the  | '''point_worldtext''' displays a specified text message in a set position in the world. It can be of any size and color, but the text outline cannot be changed. You can change the text message in-game by firing [[AddOutput]] with the parameter "message" and then the message you want to display. One downside of this text type is that it's stationary in the world and it is not part of the HUD, so you can't ensure that all players see it at all times. If you want to display important information that the player(s) must be constantly aware of, then it is better to use a [[game_text]]. | ||
| {{Tip|The texture sheet has a bone icon assigned to the "~" character.}} | |||
| {{Note| '''Text''', '''size''' and '''color''' can be edited real time via [[AddOutput]], making this entity very flexible and useful.}} | |||
| == FGD Code == | |||
| <syntaxhighlight lang=js> | |||
| @PointClass base(Targetname, Parentname, Angles) worldtext() = point_worldtext :  | |||
|     "An entity that displays a text message oriented in the world, at its origin." | |||
| [ | |||
|     message(string) : "Entity Message" : "" : "Text Message. Newline characters are accepted" | |||
|     textsize(float) : "Text Size" : 10 : "Text Size." | |||
|     textspacingX(float) : "Text Spacing X" : 0 : "Spacing between each letter along X axis" | |||
|     textspacingY(float) : "Text Spacing Y" : 0 : "Spacing between each letter along Y axis" | |||
|     color(color255) : "Color" : "255 255 255 255" | |||
|     font(choices) : "Font" : "0" = | |||
|     [ | |||
|         0: "TF2 Build" | |||
|         1: "TF2 Build (no outline/shadow)" | |||
|         2: "TF2" | |||
|         3: "TF2 (no outline/shadow)" | |||
|         4: "Liberation Sans" | |||
|         5: "Liberation Sans (no outline/shadow)" | |||
|         6: "TF2 Professor" | |||
|         7: "TF2 Professor (no outline/shadow)" | |||
|         8: "Roboto Mono" | |||
|         9: "Roboto Mono (no outline/shadow)" | |||
|         10: "Roboto Mono (shadow only)" | |||
|         11: "Roboto Mono (green glow, soft edges)" | |||
|         12: "TF2 Build (soft edges)" | |||
|     ] | |||
|     orientation(choices) : "Orientation" : "0" = | |||
|     [ | |||
|         0: "Stationary" | |||
|         1: "Face player" | |||
|         2: "Ignore pitch" | |||
|     ] | |||
|     rainbow(choices) : "Rainbow" : 0 = | |||
|     [ | |||
|         0 : "No" | |||
|         1 : "Yes" | |||
|     ] | |||
|     // Inputs | |||
|     input SetText(string) : "Set the message text." | |||
|     input SetTextSize(float) : "Set the message text size." | |||
|     input SetTextSpacingX(float) : "Set the spacing between letters along the X axis." | |||
|     input SetTextSpacingY(float) : "Set the spacing between letters along the Y axis." | |||
|     input SetColor(string) : "Set the message color." | |||
|     input SetFont(integer) : "Set the font." | |||
|     input SetOrientation(integer) : "Set the orientation." | |||
|     input SetRainbow(integer) : "Enable rainbow text." | |||
| ] | |||
| </syntaxhighlight> | |||
| == Keyvalues == | |||
| {{KV Angles}} | |||
| {{KV Targetname}} | |||
| {{minititle|Text Options}} | |||
| [[File:Point worldtext TF2 fonts.png|thumb|right|Available font varieties in TF2. With the exception of the two noted smaller typefaces, each entity is using the default size of 10.]] | |||
| {{KV|Entity Message|intn=message|string|Text that should be displayed. In {{tf2branch}}, line breaks can be inserted into the text via the newline character ''\n'', but Hammer will automatically change this to ''/n'', so this is only possible through other means such as VScript, manually editing the .vmf file or through {{hammerpp|4}}.}} | |||
| :{{Hammer quote warning}} | |||
| {{KV|Text Size|intn=textsize|float|Size of the text. Setting this to 0 will display nothing. Negative values will flip the text upside down.}} | |||
| {{KV|Color|intn=color|Color255|Color of the text. {{tf2branch}} Alpha is also parsed if R G B A format is specified. Otherwise, alpha defaults to 255.}} | |||
| {{KV|Font|intn=font|material|Path to the font material sheet|only={{strata}}}} | |||
| {{KV|Font|intn=font|integer choices |Selects from a preset list of fonts: | |||
| *0: TF2 Build | |||
| *1: TF2 Build (no outline/shadow) | |||
| *2: TF2 | |||
| *3: TF2 (no outline/shadow) | |||
| *4: Liberation Sans | |||
| *5: Liberation Sans (no outline/shadow) | |||
| *6: TF2 Professor | |||
| *7: TF2 Professor (no outline/shadow) | |||
| *8: Roboto Mono | |||
| *9: Roboto Mono (no outline/shadow) | |||
| *10: Roboto Mono (shadow only) | |||
| *11: Roboto Mono (green glow, soft edges) | |||
| *12: TF2 Build (soft edges) | |||
| Higher values will repeat font 12 indefinitely.|only={{tf2branch}}}} | |||
| :{{todo|Add font 12 to the gallery image.}} | |||
| {{KV|Orientation|intn=orientation|integer choices |*0: stationary text | |||
| *1: always face the player.   | |||
| *2: ignores pitch (looking up/down)|only={{tf2branch}}}} | |||
| {{warning|Stationary text (aka <code>orientation 0</code>) is left aligned relative to the origin, while the rotating modes are center aligned. This will cause your text to "shift" if switching to/from 0.}} | |||
| {{KV|Text Spacing X|intn=textspacingx|float|Spacing between each letter along the X axis. Negative values will invert the text.|only={{tf2}}}} | |||
| {{KV|Text Spacing Y|intn=textspacingy|float|Spacing between each letter along the Y axis. Only used when newlines are inserted into the text.|only={{tf2}}}} | |||
| {{KV|Rainbow|intn=rainbow|bool|Enables rainbow text, overriding the <code>color</code> keyvalue and <code>SetColor</code> input.|only={{tf2}}}} | |||
| == Flags == | |||
| *1: Start Disabled {{not|{{tf2branch}}}} | |||
| ::{{workaround|Set the alpha to 0 via ''SetColor''.}} | |||
| == Inputs == | |||
| {{I|Enable|Start displaying the message text.|not={{tf2branch}}}} | |||
| {{I|Disable|Stop displaying the message text.|not={{tf2branch}}}} | |||
| {{I|SetMessage|Set the message text.|param=string|not={{tf2branch}}}} | |||
| {{Bug|tested=JBEP3 v172|Does not work, use '''<code>[[AddOutput]] Message <string></code>''' instead. {{fixed|{{jbep3}}}} }} | |||
| {{I|SetText|only={{tf2branch}}|param=string|Set the message text.}} | |||
| {{I|SetTextSize|only={{tf2branch}}|param=float|Set the message text size.  Setting this to 0 will hide the text.  Negative values will flip the text upside down.}} | |||
| {{I|SetTextSpacingX|only={{tf2branch}}|param=float|Set the spacing between letters along the X axis.  Negative values will invert the text.}} | |||
| {{I|SetTextSpacingY|only={{tf2branch}}|param=float|Set the spacing between letters along the Y axis. Only used when newlines are inserted into the text.}} | |||
| {{I|SetColor|only={{tf2branch}}|param=color255|Set the message color.}} | |||
| {{I|SetFont|only={{tf2branch}}|param=int|Set the message font.   Accepts values 0 - 11}} | |||
| {{I|SetOrientation|only={{tf2branch}}|param=int| Set the message orientation}} | |||
| {{I|SetRainbow|only={{tf2branch}}|param=int| Enables Rainbow Text}} | |||
| == See also == | |||
| * [[point_message]] - A similar entity which displays a small custom message at a specific position in the game world. | |||
| * [[editor_text]] - An similar entity which renders in the map editor, but not in-game (due to not actually existing). | |||
| [[Category:GUI Entities]] | |||
| <!-- TF2 branch games, since they aren't added by this is a --> | |||
| [[Category:Counter-Strike: Source entities]] | |||
| [[Category:Counter-Strike: Source point entities]] | |||
| [[Category:Day of Defeat: Source entities]] | |||
| [[Category:Day of Defeat: Source point entities]] | |||
| [[Category:Half-Life Deathmatch: Source entities]] | |||
| [[Category:Half-Life Deathmatch: Source point entities]] | |||
| [[Category:Half-Life 2: Deathmatch entities]] | |||
| [[Category:Half-Life 2: Deathmatch point entities]] | |||
| [[Category:Team Fortress 2 entities]] | |||
| [[Category:Team Fortress 2 point entities]] | |||
Latest revision as of 13:54, 18 October 2025
|  Class hierarchy | 
|---|
| CPointWorldText | 
|  point_worldtext.cpp | 
point_worldtext  is a   point entity  available in all  Source games since
 Source games since  Counter-Strike: Global Offensive. (also in
 Counter-Strike: Global Offensive. (also in 
 )
)
It is an entity that displays a text message oriented in the world, at its origin.
Usage
 Team Fortress 2 branch games, which has a completely different implementation.
 Team Fortress 2 branch games, which has a completely different implementation.point_worldtext displays a specified text message in a set position in the world. It can be of any size and color, but the text outline cannot be changed. You can change the text message in-game by firing AddOutput with the parameter "message" and then the message you want to display. One downside of this text type is that it's stationary in the world and it is not part of the HUD, so you can't ensure that all players see it at all times. If you want to display important information that the player(s) must be constantly aware of, then it is better to use a game_text.
 Tip:The texture sheet has a bone icon assigned to the "~" character.
Tip:The texture sheet has a bone icon assigned to the "~" character. Note: Text, size and color can be edited real time via AddOutput, making this entity very flexible and useful.
Note: Text, size and color can be edited real time via AddOutput, making this entity very flexible and useful.FGD Code
@PointClass base(Targetname, Parentname, Angles) worldtext() = point_worldtext : 
    "An entity that displays a text message oriented in the world, at its origin."
[
    message(string) : "Entity Message" : "" : "Text Message. Newline characters are accepted"
    textsize(float) : "Text Size" : 10 : "Text Size."
    textspacingX(float) : "Text Spacing X" : 0 : "Spacing between each letter along X axis"
    textspacingY(float) : "Text Spacing Y" : 0 : "Spacing between each letter along Y axis"
    color(color255) : "Color" : "255 255 255 255"
    font(choices) : "Font" : "0" =
    [
        0: "TF2 Build"
        1: "TF2 Build (no outline/shadow)"
        2: "TF2"
        3: "TF2 (no outline/shadow)"
        4: "Liberation Sans"
        5: "Liberation Sans (no outline/shadow)"
        6: "TF2 Professor"
        7: "TF2 Professor (no outline/shadow)"
        8: "Roboto Mono"
        9: "Roboto Mono (no outline/shadow)"
        10: "Roboto Mono (shadow only)"
        11: "Roboto Mono (green glow, soft edges)"
        12: "TF2 Build (soft edges)"
    ]
    orientation(choices) : "Orientation" : "0" =
    [
        0: "Stationary"
        1: "Face player"
        2: "Ignore pitch"
    ]
    rainbow(choices) : "Rainbow" : 0 =
    [
        0 : "No"
        1 : "Yes"
    ]
    // Inputs
    input SetText(string) : "Set the message text."
    input SetTextSize(float) : "Set the message text size."
    input SetTextSpacingX(float) : "Set the spacing between letters along the X axis."
    input SetTextSpacingY(float) : "Set the spacing between letters along the Y axis."
    input SetColor(string) : "Set the message color."
    input SetFont(integer) : "Set the font."
    input SetOrientation(integer) : "Set the orientation."
    input SetRainbow(integer) : "Enable rainbow text."
]
Keyvalues
- Pitch Yaw Roll (Y Z X) (angles) <QAngle>
- This entity's orientation in the world. Pitch is rotation around the Y axis, yaw is the rotation around the Z axis, roll is the rotation around the X axis.
- 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
Text Options:
- Entity Message (message) <string>
- Text that should be displayed. In  , line breaks can be inserted into the text via the newline character \n, but Hammer will automatically change this to /n, so this is only possible through other means such as VScript, manually editing the .vmf file or through , line breaks can be inserted into the text via the newline character \n, but Hammer will automatically change this to /n, so this is only possible through other means such as VScript, manually editing the .vmf file or through Hammer++. Hammer++.
 Warning:Using the quote symbol Warning:Using the quote symbol- "in any text field of a Hammer Object Properties Dialog will lead to VMF corruption, fixable only by editing the VMF directly with a text editor and removing the added quote symbol.
- Text Size (textsize) <float>
- Size of the text. Setting this to 0 will display nothing. Negative values will flip the text upside down.
- Color (color) <color255>
- Color of the text.  Alpha is also parsed if R G B A format is specified. Otherwise, alpha defaults to 255. Alpha is also parsed if R G B A format is specified. Otherwise, alpha defaults to 255.
- Font (font)  <material> (only in  ) )
- Path to the font material sheet
- Font (font)  <integer choices> (only in  ) )
- Selects from a preset list of fonts:
- 0: TF2 Build
- 1: TF2 Build (no outline/shadow)
- 2: TF2
- 3: TF2 (no outline/shadow)
- 4: Liberation Sans
- 5: Liberation Sans (no outline/shadow)
- 6: TF2 Professor
- 7: TF2 Professor (no outline/shadow)
- 8: Roboto Mono
- 9: Roboto Mono (no outline/shadow)
- 10: Roboto Mono (shadow only)
- 11: Roboto Mono (green glow, soft edges)
- 12: TF2 Build (soft edges)
Higher values will repeat font 12 indefinitely.
- Todo: Add font 12 to the gallery image.
- Orientation (orientation)  <integer choices> (only in  ) )
- 0: stationary text
- 1: always face the player.
- 2: ignores pitch (looking up/down)
 Warning:Stationary text (aka
Warning:Stationary text (aka orientation 0) is left aligned relative to the origin, while the rotating modes are center aligned. This will cause your text to "shift" if switching to/from 0.- Text Spacing X (textspacingx)  <float> (only in  ) )
- Spacing between each letter along the X axis. Negative values will invert the text.
- Text Spacing Y (textspacingy)  <float> (only in  ) )
- Spacing between each letter along the Y axis. Only used when newlines are inserted into the text.
- Rainbow (rainbow)  <boolean> (only in  ) )
- Enables rainbow text, overriding the colorkeyvalue andSetColorinput.
Flags
 Workaround:Set the alpha to 0 via SetColor. Workaround:Set the alpha to 0 via SetColor.
 
Inputs
- SetMessage  <string> (not in  ) )
- Set the message text.
 Bug:Does not work, use
Bug:Does not work, use AddOutput Message <string> instead. (fixed in  )   (tested in: JBEP3 v172)
)   (tested in: JBEP3 v172)- SetText  <string> (only in  ) )
- Set the message text.
- SetTextSize  <float> (only in  ) )
- Set the message text size. Setting this to 0 will hide the text. Negative values will flip the text upside down.
- SetTextSpacingX  <float> (only in  ) )
- Set the spacing between letters along the X axis. Negative values will invert the text.
- SetTextSpacingY  <float> (only in  ) )
- Set the spacing between letters along the Y axis. Only used when newlines are inserted into the text.
- SetColor  <color255> (only in  ) )
- Set the message color.
- SetFont  <integer> (only in  ) )
- Set the message font. Accepts values 0 - 11
- SetOrientation  <integer> (only in  ) )
- Set the message orientation
- SetRainbow  <integer> (only in  ) )
- Enables Rainbow Text
See also
- point_message - A similar entity which displays a small custom message at a specific position in the game world.
- editor_text - An similar entity which renders in the map editor, but not in-game (due to not actually existing).
- Point entities
- Source base entities
- Pages with uncategorized bugs
- GUI Entities
- Counter-Strike: Source entities
- Counter-Strike: Source point entities
- Day of Defeat: Source entities
- Day of Defeat: Source point entities
- Half-Life Deathmatch: Source entities
- Half-Life Deathmatch: Source point entities
- Half-Life 2: Deathmatch entities
- Half-Life 2: Deathmatch point entities
- Team Fortress 2 entities
- Team Fortress 2 point entities





























