This article's documentation is for anything that uses the Source engine. Click here for more information.

Point worldtext: Difference between revisions

From Valve Developer Community
Jump to navigation Jump to search
(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}}}}


An entity in CSGO that allows players to put messages in game
[[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 addoutput command to send messages directly to the point_worldtext to update it in game.
'''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

English (en)Español (es)Translate (Translate)
Icon-NotInFGD.png
This entity is not in the Team Fortress 2 FGD by default.
See below for instructions on making it available.
C++ Class hierarchy
CPointWorldText
CBaseEntity
C++ point_worldtext.cpp

point_worldtext is a point entity available in all Source Source games since Counter-Strike: Global Offensive Counter-Strike: Global Offensive. (also in Team Fortress 2 branchGarry's Mod)

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 Team Fortress 2 branch 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.pngTip:The texture sheet has a bone icon assigned to the "~" character.
Note.pngNote: 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. parentname or target).
Also displayed in Hammer's 2D views and Entity Report.
See also:  Generic Keyvalues, Inputs and Outputs available to all entities

Text Options:

Available font varieties in TF2. With the exception of the two noted smaller typefaces, each entity is using the default size of 10.
Entity Message (message) <string>
Text that should be displayed. In Team Fortress 2 branch, 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.pngWarning: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. Team Fortress 2 branch Alpha is also parsed if R G B A format is specified. Otherwise, alpha defaults to 255.
Font (font) <material> (only in Strata Source)
Path to the font material sheet
Font (font) <integer choices> (only in Team Fortress 2 branch)
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 Team Fortress 2 branch)
  • 0: stationary text
  • 1: always face the player.
  • 2: ignores pitch (looking up/down)
Warning.pngWarning: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 Team Fortress 2)
Spacing between each letter along the X axis. Negative values will invert the text.
Text Spacing Y (textspacingy) <float> (only in Team Fortress 2)
Spacing between each letter along the Y axis. Only used when newlines are inserted into the text.
Rainbow (rainbow) <boolean> (only in Team Fortress 2)
Enables rainbow text, overriding the color keyvalue and SetColor input.

Flags

  • 1: Start Disabled (not in Team Fortress 2 branch)
PlacementTip.pngWorkaround:Set the alpha to 0 via SetColor.

Inputs

Enable  (not in Team Fortress 2 branch)
Start displaying the message text.
Disable  (not in Team Fortress 2 branch)
Stop displaying the message text.
SetMessage <stringRedirectInput/string> (not in Team Fortress 2 branch)
Set the message text.
Icon-Bug.pngBug:Does not work, use AddOutput Message <string> instead. (fixed in Jabroni Brawl: Episode 3)   (tested in: JBEP3 v172)
SetText <stringRedirectInput/string> (only in Team Fortress 2 branch)
Set the message text.
SetTextSize <floatRedirectInput/float> (only in Team Fortress 2 branch)
Set the message text size. Setting this to 0 will hide the text. Negative values will flip the text upside down.
SetTextSpacingX <floatRedirectInput/float> (only in Team Fortress 2 branch)
Set the spacing between letters along the X axis. Negative values will invert the text.
SetTextSpacingY <floatRedirectInput/float> (only in Team Fortress 2 branch)
Set the spacing between letters along the Y axis. Only used when newlines are inserted into the text.
SetColor <color255RedirectInput/color32> (only in Team Fortress 2 branch)
Set the message color.
SetFont <integerRedirectInput/integer> (only in Team Fortress 2 branch)
Set the message font. Accepts values 0 - 11
SetOrientation <integerRedirectInput/integer> (only in Team Fortress 2 branch)
Set the message orientation
SetRainbow <integerRedirectInput/integer> (only in Team Fortress 2 branch)
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).