What does this script do? Well, it does a lot of things. Which is why it comes with this manual. The primary function of this script is to provide the user with a highly customizable voice chat menu. When first installed, this script is designed to resemble the voice chat menu that comes with Tribes 2. I have done this so that new users may easily transition into it. Unfortunately, it takes users quite some time to "find out" how to use the best stuff in this script because it is commonly mistook for a simple voicepack. Hopefully, with this documentation, users will be able to discover the multitude of features in ECM. This manual will go over all the features of ECM that make it THE voice menu modification script for Tribes 2.
If you're familiar with ECM already (though this version has significant changes from the last version) or you are the kind of person who doesn't like to read long manuals, then all you need to do is follow these instructions to get started.
Note: All file paths are relative to your Tribes 2 installation base folder. This is generally C:\Dynamix\Tribes 2\GameData\base
After all that, you should be able to go into a game and begin owning people with your new voice menu
Before you start sending me T-Mails about how much my sucky script sucks because it is broken, please save us both a bit of trouble by reading through these common questions that users have about this script. If you ask me in game, you'll probably get referred to this.
From here you start on your journey towards fully mastering the capabilities of your script. Sure "Dance Baby Dance" is great at parties, but creating and using your catch phrases in game is really what this script is all about. You create and edit your own voice bind items in the Enhanced Chat Menu using the powerful tools that come with ECM. There are 3 ways to get at the menu editor dialog for ECM:
All 3 methods will bring up the same exact dialog, show below
ECM operates in 3 modes for compatibility reasons. This script can be a very fun tool for expressing yourself, but it may also be abused. People who do abuse it have caused some server admins to feel the need to block the effects of this script and others like it on different levels. The 3 modes allow you to roll back your voice menu in case you need or want to play in servers that block the nullvoice effect or voicepacks.
This feature, new as of version 3.0, acts as an automated recovery system for server that block the effects of this script. The toggle button will turn this system on/off. While on, auto over-ride will use your first voice bind in a server to test for filters. If a filter is detected, you will be prompted to add the server to a list of "filterers". The next time you enter this server, ECM will automatically "roll back" its voice mode according to the severity of the filter. The "AUTO OVER-RIDE OPTIONS" button will present you with a dialog where you may manually add/remove servers from the "filterers" lists. (See The Auto Over-ride Options Dialog)
The biggest thing on this dialog is the Menu Tree. This is a representation of your Enhanced Chat Menu and all of its submenus, displayed in a tree. You edit items in this tree by right-clicking on them. There are 2 types of items in this tree. Commands, which are items that represent a voice bind in your menu and Menus which may contain commands and other menus. The options you get when you right-click on an item depend on what type of item it is you clicked on.
ECM has various input and output filters to help clean up the chat window. This button will bring up a dialog that allows you to activate/deactivate certain filters. (See The Filter Options Dialog)
ECM features an advanced voicepack protocol that allows the user to use multiple voicepacks in the same menu without having to switch. This button will bring up a dialog that will give you information on installed voicepacks using this protocol. (See The Voicepack Manager)
This button brings up a dialog that lets you control the popup menu will behave in game. (See The Behavior Options Dialog)
The import and export buttons will let you import or export your current menu to a file. When you press either button, you will be prompted to supply a file name. When exporting menus, the menu file will be written to base/scripts/TDX/ECM/Menus/. This file may be given to another player for sharing of menu configurations. When importing, you will be putting the file in the same directory. Only files ending in .cs are valid. It is important to note that the file current.mnu.cs is the file being used for your current menu. Importing or exporting to this file is pretty useless. The default.mnu.cs is supplied as a template file. You will notice it is not present in the Menus directory. It is stored in the .vl2 and is used to create a current.mnu.cs file if none is present.
Clicking this button will cause the menu to reload from the last saved menu. All changes made since your last saved will be lost. This is useful if you totally mess up the menu somehow and need to roll back to a saved copy.
This will cause the changes you made to the menu to be saved to the current.mnu.cs file and load them into memory for use in game.
Closes the editor dialog. You may be prompted to save if you have made changes to the menu and not saved them.
The command editor is where a lot of the action takes place. It is where you edit your chat commands and add all kinds of functionality to the menu. Some of this functionality is shown in the default menu, but it does not show all the possibilities. The section will explain the different "pages" of the command editor.
This drop down selects what command page you wish to view. Some commands (Like Console Command) will work simultaneously with others, while others (Like Canned Chat Items) will over-ride other commands.
The most used page of the command editor is this one. It is where you can create a chat bind. It consists of a list of text and sound entries, 2 for each voice set, Nullvoice and Enhanced modes. Next to each sound text field is a button that will launch the Sound Explorer to help you select a sound. There are also Fill buttons that will allow you to fill fields with information. If a field is left completely blank, that bind will not show for that voice/mode.
ECM functions are mini-scripts that can be called on a voice bind. ECM includes an API for creating ECMFunction modules to be used with ECM. ECM comes with a few functions that attempt to fix what nullvoice breaks. They are described below.
This function can issue various tasks on yourself or a "line of sight" entity. If you happen to be looking at a spot on the ground, a player or an object, it is used in the task issued. Client side scripts do not have access (legally) to data needed to discern the difference between these objects.
This function accepts the most recently issued task.
This function completes your currently accepted task.
This function declines the most recently issued task.
This function will create a task to escort whatever is in your line of sight, then accept that command.
This page contains a single line text box for you to enter a console command. This command will be executed when the bind is called along with any voice binds that are part of the command. All commands must end in ';' and you may use multiple commands separated by ';'.
You can use legacy Canned Chat Items in any mode. Tho, in nullvoice, Canned Chat Items are mute. If you have any voice binds in the same scope of the Canned Chat Item, it will be over-ridden by the voice binds.
If you have voicepacks installed, you may select an entry point to a voicepack via this page. By making a bind a "Voicepack Root", all other command data will be over-ridden and the voicepack's submenus will appear instead. You may have multiple Voicepack roots for the same voicepack in the same menu in the same scope if you feel the need.
This text box contains the text that will be displayed in the popup menu for this command.
You can set which key will activate this command by clicking on this button. It will prompt you to press a key. The key you press will be used to activate the command item.
Clicking this will exit the command editor without saving changes. This will cause you to lose any changes you made to the command item.
Clicking this button will reset all fields in the command item to default/blank values. This is good for starting fresh when editing a command item.
Clicking this button will revert the command item's fields the state they were in before the command editor was launched. This is good for a roll back if you make an big mistakes when editing a command item.
Clicking this will make all changes to the command item permanent and close the command editor dialog.
The sound browser is a tool that scans your Tribes 2 installation for all available sounds and then presents them in a organized fashion. The first time you launch the sound explorer in a client session, you will see it scan for sounds. It will popup a dialog when it does this and the game may lock up for a few seconds as it searches for all playable sounds. Once it is completed, you are presented with a list of sounds. This list is organized by directory. You can choose which directory you wish to navigate with a drop down menu. The browser features a labeling system to make ambiguous file names and directories more descriptive. If a label is not available for a resource, the raw file name or directory name is used with square brackets ('[ ]') around it. When picking enhanced mode sounds, the sound browser will only allow you to pick sounds that are in the respective voice directory as those are the only sounds that will be able to be played in that mode.
This pull down allows you to select which directory of sounds you want to view. This can help you narrow down your search for the perfect sound effect.
Here is where you select what you want. The left column is the display label for the sound, while the right column is the actual file name of the sound.
This display shows you the full path to the sound you have selected.
This button will close the dialog and use the sound you have selected in your operation.
This button will cause the selected sound to be played so that you may sample it and decide if it is the right sound for your chat command bind.
You can label unlabeled sounds yourself with this button. You can also change existing labels if you feel the need.
This will cancel the sound selection operation. It will also terminate the action that called the sound browser in the first place, causing nothing to happen.
This dialog displays a list of all installed voicepacks. When voicepacks are first initialized, they attempt to install to a default location on your menu. If they are unsuccessful, or you delete the voicepack root item, you will need to create a voicepack root item yourself to use the voicepack. All this dialog does is let you know that a voicepack is installed properly and ready to go. (See Voicepack Root)
This is the list of installed voicepacks.
Clicking this button will display a dialog with extended information on the selected voicepack.
This dialog displays a list of voicepacks that are not supported by ECM, but can be converted to a format that is. You can convert a voicepack by selecting it and pressing the 'CONVERT' button. The voicepack will then be converted and the utility will spit out 1 or more voicepack definition files for ECM's voicepack protocol. No changes are made to the original voicepack definition file(s) To learn more about ECM's voicepack protocol, see the Developer's documentation.
This is the list of convertible voicepacks.
This button starts the batch conversion of the selected old voicepack to ECM's voicepack protocol.
This is a list of all server IPs that have blocked nullvoice. When joining servers on this list, ECM will roll back to "Enhanced Mode" to prevent being broken by the server's nullvoice filter. You may manually add and remove server IPs with the buttons provided.
This is a list of all server IPs that have blocked voicepacks. When joining servers on this list, ECM will roll back to "Normal Mode" to prevent being broken by the server's voicepack filter. You may manually add and remove server IPs with the buttons provided.
This dialog lets you toggle the status of various filters built into ECM.
This filter, when enabled, will send your voicepack text as colored with a dark color. This will help people know that the text is from a voicepack and should not be taken seriously.
This filter will remove all text from out going voicepack binds.
This filter will make all voicepack items team binds.
This filter will make all incoming voicepack items subdued in color.
This filter will block all voicepacks
This filter will mute all nullvoice users.
When enabled, this will cause the ECM's V-Menu HUD to expand downwards. When disabled, it will cause the hud to expand upwards.
ECM now intercepts the call to the legacy V-Chat Menu. So even if you "forget" to bind ECM to V, you will still see ECM when you press V. You can turn off this "feature" by turning this toggle on.
The following are a list of people and organizations that helped me make this script great, in one way or another.
ECM 3.0 has several features that modularly designed and ready for third party developers to use. One of the most obvious ones in the voicepack protocol, but also, ECM's ECMFunctions system is modular and allows for third party developers to add to it. To learn about these systems without having to swim through the code, see the Developer's Documentation.