GameMenu.res
game or mod/resource/GameMenu.res
is the file that controls the menu buttons that will appear in the in-game menu. Mods can use this for adding new command buttons to their main menu.
They are simply a text document saved with a .res extension.
Example
Example: from Half-Life 2:
"GameMenu" { "1" { "label" "#GameUI_GameMenu_ResumeGame" "InGameOrder" "10" "OnlyInGame" "1" } "2" { "label" "#GameUI_GameMenu_Disconnect" "command" "Disconnect" "OnlyInGame" "1" "notsingle" "1" } // "3" [$WIN32] // from portal // { // "label" "#GameUI_GameMenu_BonusMaps" // "command" "OpenBonusMapsDialog" // "InGameOrder" "50" // "notmulti" "1" // } "3" { "label" "#GameUI_GameMenu_PlayerList" "command" "OpenPlayerListDialog" "OnlyInGame" "1" "notsingle" "1" } "4" //devider { "label" "" "command" "" "OnlyInGame" "1" } "5" { "label" "#GameUI_GameMenu_NewGame" "command" "OpenNewGameDialog" "notmulti" "1" //nomulti will make this button not appear when in MP mode } "6" { "label" "#GameUI_GameMenu_LoadGame" "command" "OpenLoadGameDialog" "notmulti" "1" } "7" { "label" "#GameUI_GameMenu_SaveGame" "command" "OpenSaveGameDialog" "notmulti" "1" "OnlyInGame" "1" } "8" { "label" "#GameUI_GameMenu_Achievements" "command" "OpenAchievementsDialog" "InGameOrder" "70" } // "8" // { // "label" "#GameUI_Controller" // "command" "OpenControllerDialog" // "InGameOrder" "80" // "ConsoleOnly" "1" // } "9" { "label" "" "command" "" "notmulti" "1" } "10" { "label" "#GameUI_GameMenu_FindServers" "command" "OpenServerBrowser" "notsingle" "1" } "11" { "label" "#GameUI_GameMenu_CreateServer" "command" "OpenCreateMultiplayerGameDialog" "notsingle" "1" } "12" { "label" "#GameUI_GameMenu_Friends" "command" "OpenFriendsDialog" } // "13" // not needed // { // "name" "LoadDemo" // "label" "#GameUI_GameMenu_PlayDemo" // "command" "OpenLoadDemoDialog" // } "14" { "label" "" "command" "" "notsingle" "1" } "15" { "label" "#GameUI_GameMenu_Options" "command" "OpenOptionsDialog" } "16" { "label" "#GameUI_GameMenu_Quit" "command" "Quit" } }
File format
Parameters
Parameter | Purpose |
---|---|
name | |
label | The display text of the button. If appended with a pound symbol, it will correspond to the corresponding key-value pair in gameui_<LANGUAGE>.txt. |
command | The command to run when the button is clicked, not to be confused with a console command (although console commands can be run using engine <command> ). See List of commands for a list.
|
notsingle | If set to "1", will not display in singleplayer. |
notmulti | If set to "1", will not display in multiplayer. |
InGameOrder | |
OnlyInGame | If set to "1", will only display if the user is currently ingame. |
ConsoleOnly | If set to "1", will only display on consoles, such as the Xbox 360. |
Commands
This is the list of commands that can be assigned to a GameMenu button. You can try these in the console with gamemenucommand
. Some of these only work on multiplayer mods, some command can't be issued in the main menu and some only works on the Xbox 360 platform.
There are several undocumented commands and those are not shown here.
Command | What it does | Notes |
---|---|---|
OpenPlayerListDialog | Players can mute other players here | Non-functional on singleplayer branch |
OpenNewGameDialog | Shows the chapter selection window | |
OpenLoadGameDialog | Shows the load game window | X360 has a different dialog. |
OpenSaveGameDialog | Shows the save game window | X360 has a different dialog. |
OpenBonusMapsDialog | Shows the "Bonus Maps" dialog | |
OpenOptionsDialog | Shows the options dialog | X360 has a different dialog. |
OpenControllerDialog | Shows controller settings | Only works on console UI. |
OpenBenchmarkDialog | Opens the Lost Coast benchmark dialog | |
OpenServerBrowser | Shows a list of game servers | Also opens on singleplayer. |
OpenFriendsDialog | Shows a list of Steam friends | Non-functional. |
OpenLoadDemoDialog | Does nothing (maybe it's supposed to show demoui) | |
OpenCreateMultiplayerGameDialog | Shows the listen server creation dialog | First page works on singleplayer. |
OpenChangeGameDialog | Non-functional, players can load other games/mods here | (Leftover from GoldSrc?) |
OpenLoadCommentaryDialog | Shows a dialog with a list of commentaries | This is for multiplayer games |
OpenLoadSingleplayerCommentaryDialog | Shows the new game dialog, but this one starts the game in commentary mode | This is for singleplayer games |
OpenMatchmakingBasePanel | Unknown, maybe used for Team Fortress 2 | On Source 2013 this opens an transparent panel covering the whole screen, effectively making the menu unusable |
OpenAchievementsDialog | Shows the achievements dialog | Shows a message if the player is not using Steam or is logged off. On X360 the native dialog is shown. |
Quit | Shows the quit confirmation dialog | |
QuitNoConfirm | Closes the game without confirmation | |
ResumeGame | Hides the menu when in-game | |
Disconnect | Disconnects from the game | Shows a confirmation dialog on X360 |
DisconnectNoConfirm | Disconnects from the game without confirmation | Also closes all dialogs if the Matchmaking Base Panel is open |
engine <concommand> | Executes console command <concommand>. Some creative examples include engine connect.2341 | |
RestartWithNewLanguage | Closes the game and makes it start in a new language next time. | Only works on PC. Used when the spoken language is modified in the Audio options. Works by setting a string value called a "Relaunch URL" in regedit with value steam://run/<appid>/<language> . This makes Steam execute this URL after the current game exits. (doesn't work with mods)
|
Files
Inside the game or mod/resource
folder.
References
GameMenu.res by massivegod https://gamebanana.com/scripts/2341
This article or section needs to be cleaned up to conform to a higher standard of quality because:
1. Sections are more useful than tables here because they are easier to link.
For help, see the VDC Editing Help and Wikipedia cleanup process. Also, remember to check for any notes left by the tagger at this article's talk page.