3. Internationalization (i18n) - Lightweight Internationalization Solution
- JLGames.RocketDriver.Actions.i18n provides full functional support for the internationalization module.
- BabelEdit is recommended for authoring management datasets.
- Use internationalization (i18n) in three steps:
- Prepare the data.
- Initialize (Initialize by registering information or Initialize by configuring assets).
- Use.
3.1 Preparation
Understand the internationalization requirements of the project and prepare data files.
3.1.1 Clarify the types of international languages that the project needs to support
Here are English[English], Chinese[Simplified], Chinese[Traditional] as examples.
3.1.2 Prepare internationalization data files
Multiple file sets are supported, here are two file sets unity, rider for example.
data:image/s3,"s3://crabby-images/f2f86/f2f86dce6b8d763a6c87b781d92c6129946695e7" alt="image"
The data format is in the form of Key-Value:
data:image/s3,"s3://crabby-images/92a6e/92a6e4169d074155f24221121c9243ff109cba40" alt="image"
The current test dataset is authored using Jetbrains’ [BabelEdit] (https://www.codeandweb.com/babeledit), which is a nice tool.
3.2.1 Register languages with the registry.
Call the RegisterLang function in the I18NRegister instance:
data:image/s3,"s3://crabby-images/b0df8/b0df8f1387e68ac8334d446079ccd872e465fd6b" alt="image"
- langName as langSuffix suggests.
- default=true sets the current language as the default language.
Call the RegisterFile function in the I18NRegister instance:
data:image/s3,"s3://crabby-images/9e2cd/9e2cd9b89958ce33f586f5b764372f02ae6bfdc2" alt="image"
- fileKey is used to identify the currently set fileset.
- default=truej Set the current fileset as the default fileset.
3.2.3 According to the registry, load data into the manager
Call the LoadData function in the II18NManager instance:
I18NManagerShared.Manager.LoadData();
data:image/s3,"s3://crabby-images/11941/11941f377697a1798f61b53bc22bcc79b51dd0b9" alt="image"
NOTE: If you have performed load data in the past, you should clear the old data first:
I18NManagerShared.Manager.ClearData();
data:image/s3,"s3://crabby-images/ec0e9/ec0e98a5fe2f8df7fc84bdabc54565879083b846" alt="image"
3.3 Initialize by configuring asset
- Select the generation directory of the configuration assets, click the menu “Tools -> RocketDriver -> Project -> Gen I18NSettings”.
- The generated asset file is named “I18NSettings.asset”.
- Set the extension name of the fileset: Asset Extension. “json” is suggested here.
- Add the fileset to the Assets configuration list. Or set one of them as default (only the last default takes effect).
data:image/s3,"s3://crabby-images/eddbe/eddbeaba2c0af0f66bf9941f9ba5efe3cc06283c" alt="image"
3.3.3 Initializing data by configuring assets
Call the LoadDataFromSettings function in the II18NManager instance:
I18NManagerShared.Manager.LoadDataFromSettings(settings);
data:image/s3,"s3://crabby-images/5c12a/5c12a7898775740321ea1b2726b3a60de5810d91" alt="image"
3.4 Use
3.4.1 Use the I18NTMPText component to add internationalization support to TMP_Text.
Add I18NTMPText component to TMP_Text node
data:image/s3,"s3://crabby-images/e8991/e89915923d95fc9b90dcd3d4618aec2dce1574ee" alt="image"
- File Key is the fileKey parameter when registering a file set.
- Auto Refresh When checked, the manager will refresh itself after reloading the data.
3.4.2 Use the I18NText component to add internationalization support to Text.
Add I18NText component to Text node
data:image/s3,"s3://crabby-images/f4bb0/f4bb079580defa3f3e390afd7d02a7b2f8594292" alt="image"
- File Key is the fileKey parameter when registering a file set.
- Auto Refresh When checked, the manager will refresh itself after reloading the data.
3.4.3 Reading internationalized data in code.
I18NManagerShared.Manager.GetValue(id, fileKey, lang);
data:image/s3,"s3://crabby-images/515e3/515e397f389c4b174b09973e01f7079d9411cbd1" alt="image"
3.4.4 Internationalize the text content in the code.
Support script format in the file content: ``
I18NManagerShared.Manager.GetContent(content, fileKey, lang);
data:image/s3,"s3://crabby-images/81167/811670a154e4d6dd23c77a622f5e3b21ce55b4a6" alt="image"
3.5 Example
JLGames/RocketDriver/Samples/i18n
data:image/s3,"s3://crabby-images/13aa1/13aa1141d7aa3bb405fefd0e9363fd394e0d179b" alt="image"