Using translations
Unturned Plugin Development #6
MCrow • 6 months ago
MCrow • 6 months ago
Every plugin should have a way to customize messages or translate them to other languages. You probably noticed that every RocketMod plugin generates translations file in its directory, for example: Rocket/Plugins/Example/Example.en.translation.xml
.
Very unpopular feature of RocketMod is that you can specify the language code in the Rocket.config.xml
file. When you change <LanguageCode>en</LanguageCode>
to <LanguageCode>pl</LanguageCode>
for example, RocketMod will generate and use Example.pl.translation.xml
file instead of Example.en.translation.xml
. Still most server owners just leave it as en
and eventually translate this .en
file to their language.
You can only add translations only by overriding the DefaultTranslations
property in your plugin class. The DefaultTranslations
property is a dictionary that contains translations for your plugin. The key is the translation key and the value is the translation text.
Here is an example of default translations for the MaxskillsCommand
command:
public override TranslationList DefaultTranslations => new()
{
{ "PlayerNotFound", "Failed to find any player with the name {0}." },
{ "MaxskillsInvalid", "You must specify a player." },
{ "MaxskillsSuccess", "Maxskills give to you." },
{ "MaxskillsSuccessOther", "Maxskills given to {0}." }
};
To use translations in your plugin you need to use the Translate
method from the plugin class instance. The Translate
method has 2 parameters: the translation key and the parameters. The translation key is the key from the DefaultTranslations
dictionary and the parameters are the values that will replace the {0}
, {1}
, etc. in the translation text.
The {0}
, {1}
etc. are placeholders for the parameters. For example, the MaxskillsSuccessOther
translation has {0}
placeholder. When you call Translate("MaxskillsSuccessOther", "MCrow")
then the {0}
will be replaced with MCrow
.
To access the plugin instance you need to make a singleton in the plugin class. You need to add a static property that will return the instance of the plugin class. You can do that by adding the following code to the plugin class:
Then you can access the plugin instance from anywhere in your plugin by using ExamplePlugin.Instance
.
Here is an example of using translations in the MaxskillsCommand
command:
First at the top of the method we declare pluginInstance
variable to not repeat ExamplePlugin.Instance
multiple times. Then we use pluginInstance.Translate
method to get the translation text.