Env message: Difference between revisions
| No edit summary |  (position in the world irrelevant so it's logical entity) | ||
| Line 3: | Line 3: | ||
| [[File:env_message.png|left|link=]] | [[File:env_message.png|left|link=]] | ||
| {{CD|CMessage|file1=EnvMessage.cpp}} | {{CD|CMessage|file1=EnvMessage.cpp}} | ||
| {{ | {{This is a|logical entity|name=env_message}} It draws a text message on player HUDs, predefined in the <code>/scripts/titles.txt</code> file. | ||
| {{bug|hidetested=1|Does not function in {{css}} and {{l4d2}}.}} | {{bug|hidetested=1|Does not function in {{css}} and {{l4d2}}.}} | ||
| {{toc-right}} | {{toc-right}} | ||
Latest revision as of 04:26, 29 April 2025

|  Class hierarchy | 
|---|
| CMessage | 
|  EnvMessage.cpp | 
env_message  is a   logical entity  available in all  Source games. It draws a text message on player HUDs, predefined in the
 Source games. It draws a text message on player HUDs, predefined in the /scripts/titles.txt file.
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 be shown. See above.
- Sound Effect (messagesound) <sound>
- When the message is shown, this sound effect will be played, originating from this entity.
- Volume 0-10 (messagevolume) <string>
- Volume of the sound effect.
- Sound Radius (messageattenuation) <choices>
- How big the radius of the sound is.
- 0: Small Radius
- 1: Medium Radius
- 2: Large Radius
- 3: Play Everywhere
 
Flags
- Play Once : [1]
- All Clients : [2]
Inputs
- ShowMessage
- Shows the message and plays the sound.
Outputs
- OnShowMessage
- Fired when the message is activated.
File format
Each message entry in titles.txt follows a similar structure as other Valve text files. Example: Title { Text Value }. The message can reference a localized string prefixed with #.
This text can be formatted in many different ways, according to the syntax provided. The resource/clientscheme.res is responsible for the font family, size and weight of the message. To change the size find CenterPrintText in the res file.
Variables can be defined which will affect all the messages below them, until overwritten with another value.
| Varaible | Parameters | Description | 
|---|---|---|
| $position | float, float | Position of the text onscreen, represented as a range from 0-1. The first float is horizontal, with 0 being the left; the second is vertical, with 0 being the top. -1 is centered.  Bug:In most games, messages are constrained to being displayed in a 4:3 area aligned to the left side of the screen, making approximately the entire right third of the screen in widescreen mode unusable.  [todo tested in ?]  Fix:This is fixed in newer versions of  Half-Life 2 and  Portal, and can be fixed in mods for other games by increasing the width of the HudMessagepanel inscripts/hudlayout.res. | 
| $effect | integer | How it is displayed. 0 is fade in/fade out, 1 is flickery credits, 2 is write out | 
| $fxtime | float | When using the write out effect, this is the amount of time the highlight lags behind the leading edge of the text | 
| $color | R G B | Color of the text as red-green-blue between 0-255 | 
| $color2 | R G B | Highlight color used for the write out effect as characters are appearing | 
| $fadein | float | Fade in time of message or each character in seconds | 
| $fadeout | float | Fade out time in seconds | 
| $holdtime | float | How long to wait after fade in before fade out | 
| $boxsize | float | If non-zero, adds a background behind the text (like the HL2 'Saved' message). The size of the border is calculated as this value multiplied by the font height. | 
| $boxcolor | R G B A | Color and opacity of the text background | 
| $clearmessage | string | Clears any existing message of the given name upon display. Set to 0 to disable. | 
If you make a standalone modification you can alter this file with your own entries. The default titles from HL2 are listed below:
| Message Value | Printed Text | 
|---|---|
| CR1 | Testing 1 | 
| CR2 | Testing 2 | 
| CR3 | Testing 3 | 
| GAMEOVER_ALLY | ASSIGNMENT: TERMINATED SUBJECT: FREEMAN REASON: FAILURE TO PRESERVE MISSION-CRITICAL PERSONNEL | 
| GAMEOVER_OBJECT | ASSIGNMENT: TERMINATED SUBJECT: FREEMAN REASON: FAILURE TO PRESERVE MISSION-CRITICAL RESOURCES | 
| GAMEOVER_TIMER | ASSIGNMENT: TERMINATED SUBJECT: FREEMAN REASON: FAILURE TO PREVENT TIME-CRITICAL SEQUENCE | 
| GAMEOVER_STUCK | ASSIGNMENT: TERMINATED SUBJECT: FREEMAN REASON: DEMONSTRATION OF EXCEEDINGLY POOR JUDGMENT | 
| CHAPTER1_TITLE | POINT INSERTION | 
| CHAPTER2_TITLE | "A RED LETTER DAY" | 
| CHAPTER3_TITLE | ROUTE KANAL | 
| CHAPTER4_TITLE | WATER HAZARD | 
| CHAPTER5_TITLE | BLACK MESA EAST | 
| CHAPTER6_TITLE | "WE DON'T GO TO RAVENHOLM..." | 
| CHAPTER7_TITLE | HIGHWAY 17 | 
| CHAPTER8_TITLE | SANDTRAPS | 
| CHAPTER9_TITLE | NOVA PROSPEKT | 
| CHAPTER9A_TITLE | ENTANGLEMENT | 
| CHAPTER10_TITLE | ANTICITIZEN ONE | 
| CHAPTER11_TITLE | "FOLLOW FREEMAN!" | 
| CHAPTER12_TITLE | OUR BENEFACTORS | 
| CHAPTER13_TITLE | DARK ENERGY | 
| GAMESAVED | Saved... | 
| GAMETITLE | Half-Life | 
Files
- scripts/titles.txt
See also
- game_text - Similar entity that lets you define a text directly in the Hammer editor.
- env_hudhint - Similar entity that displays predefined HUD hints about controls and other things.




























