mirror of
https://github.com/vcmi/vcmi.git
synced 2025-01-26 03:52:01 +02:00
Updated localization docs
This commit is contained in:
parent
9f894d6ca0
commit
ddda6c0c01
@ -32,6 +32,9 @@
|
|||||||
// Type of mod, list of all possible values:
|
// Type of mod, list of all possible values:
|
||||||
// "Translation", "Town", "Test", "Templates", "Spells", "Music", "Sounds", "Skills", "Other", "Objects",
|
// "Translation", "Town", "Test", "Templates", "Spells", "Music", "Sounds", "Skills", "Other", "Objects",
|
||||||
// "Mechanics", "Interface", "Heroes", "Graphical", "Expansion", "Creatures", "Artifacts", "AI"
|
// "Mechanics", "Interface", "Heroes", "Graphical", "Expansion", "Creatures", "Artifacts", "AI"
|
||||||
|
//
|
||||||
|
// Some mod types have additional effects on your mod:
|
||||||
|
// Translation: mod of this type is only active if player uses base language of this mod. See "language" property.
|
||||||
"modType" : "Graphical",
|
"modType" : "Graphical",
|
||||||
|
|
||||||
// Base language of the mod, before applying localizations. By default vcmi assumes English
|
// Base language of the mod, before applying localizations. By default vcmi assumes English
|
||||||
@ -178,6 +181,22 @@ These are fields that are present only in local mod.json file
|
|||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
|
## Translation fields
|
||||||
|
|
||||||
|
In addition to field listed above, it is possible to add following block for any language supported by VCMI. If such block is present, Launcher will use this information for displaying translated mod information and game will use provided json files to translate mod to specified language.
|
||||||
|
See [Translations](Translations.md) for more information
|
||||||
|
|
||||||
|
```
|
||||||
|
"<language>" : {
|
||||||
|
"name" : "<translated name>",
|
||||||
|
"description" : "<translated description>",
|
||||||
|
"author" : "<translated author>",
|
||||||
|
"translations" : [
|
||||||
|
"config/<modName>/<language>.json"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
```
|
||||||
|
|
||||||
## Mod repository fields
|
## Mod repository fields
|
||||||
|
|
||||||
These are fields that are present only in remote repository and are generally not used in mod.json
|
These are fields that are present only in remote repository and are generally not used in mod.json
|
||||||
|
@ -1,64 +1,131 @@
|
|||||||
< [Documentation](../Readme.md) / [Modding](Readme.md) / Translations
|
< [Documentation](../Readme.md) / [Modding](Readme.md) / Translations
|
||||||
|
|
||||||
## For translators
|
# Translation system
|
||||||
### Adding new languages
|
|
||||||
New languages require minor changes in the source code. Please contact someone from vcmi team if you wish to translate game into a new language
|
|
||||||
|
|
||||||
### Translation of Launcher and Map Editor
|
## List of currently supported languages
|
||||||
TODO: write me
|
|
||||||
|
|
||||||
### Translation of game content
|
This is list of all languages that are currently supported by VCMI. If your languages is missing from the list and you wish to translate VCMI - please contact our team and we'll add support for your language in next release.
|
||||||
TODO: write me
|
|
||||||
|
|
||||||
## For modders
|
- Czech
|
||||||
|
- Chinese (Simplified)
|
||||||
|
- English
|
||||||
|
- Finnish
|
||||||
|
- French
|
||||||
|
- German
|
||||||
|
- Hungarian
|
||||||
|
- Italian
|
||||||
|
- Korean
|
||||||
|
- Polish
|
||||||
|
- Portuguese (Brazilian)
|
||||||
|
- Russian
|
||||||
|
- Spanish
|
||||||
|
- Swedish
|
||||||
|
- Turkish
|
||||||
|
- Ukrainian
|
||||||
|
- Vietnamese
|
||||||
|
|
||||||
### Adding new translation to mod
|
## Translating Heroes III data
|
||||||
TODO: write me
|
|
||||||
|
|
||||||
### Translation of mod information
|
VCMI allows translating game data into languages other than English. In order to translate Heroes III in your language easiest approach is to:
|
||||||
|
|
||||||
|
- Copy existing translation, such as English translation from here: https://github.com/vcmi-mods/h3-for-vcmi-englisation
|
||||||
|
- Rename mod to indicate your language, preferred form is "(language)-translation"
|
||||||
|
- Update mod.json to match your mod
|
||||||
|
- Translate all texts strings from game.json, campaigns.json and maps.json
|
||||||
|
|
||||||
|
If you have already existing Heroes III translation you can:
|
||||||
|
|
||||||
|
- Install VCMI and select your localized Heroes III data files for VCMI data files
|
||||||
|
- Launch VCMI_Client.exe directly from game install directory
|
||||||
|
- In console window, type `convert txt`
|
||||||
|
|
||||||
|
This will export all strings from game into `Documents/My Games/VCMI/VCMI_Client_log.txt` which you can then use to update json files in your translation
|
||||||
|
|
||||||
|
## Translating VCMI data
|
||||||
|
|
||||||
|
VCMI contains several new strings, to cover functionality not existing in Heroes III. It can be roughly split into following parts:
|
||||||
|
|
||||||
|
- In-game texts, most noticeably - in-game settings menu.
|
||||||
|
- Game Launcher
|
||||||
|
- Map Editor
|
||||||
|
|
||||||
|
Before you start, make sure that you have copy of VCMI source code. If you are not familiar with git, you can use Github Desktop to clone VCMI repository.
|
||||||
|
|
||||||
|
### Translation of in-game data
|
||||||
|
|
||||||
|
In order to translate in-game data you need:
|
||||||
|
- Add section with your language to `<VCMI>/Mods/VCMI/mod.json`, similar to other languages
|
||||||
|
- Copy English translation file in `<VCMI>/Mods/VCMI/config/vcmi/english.json` and rename it to name of your language. Note that while you can copy any language other than English, other files might not be up to date and may have missing strings.
|
||||||
|
- Translate copied file to your language.
|
||||||
|
|
||||||
|
After this, you can set language in Launcher to your language and start game. All translated strings should show up in your language.
|
||||||
|
|
||||||
|
### Translation of Launcher and Editor
|
||||||
|
|
||||||
|
VCMI Launcher and Map Editor use translation system provided by Qt framework so it requires slightly different approach than in-game translations:
|
||||||
|
|
||||||
|
- Install Qt Linguist. You can find find standalone version here: https://download.qt.io/linguist_releases/
|
||||||
|
- Open `<VCMI Sources>/launcher/translation/` directory, copy english.ts file and rename it to your language
|
||||||
|
- Launch Qt Linguist, select Open and navigate to your copied file
|
||||||
|
- Select any untranslated string, enter translation in field below, and click "Done and Next" (Ctrl+Return) to navigate to next untranslated string
|
||||||
|
- Once translation has been finished, save resulting file.
|
||||||
|
|
||||||
|
Translation of Map Editor is identical, except for location of translation files. Open `<VCMI Sources>/editor/translation/` instead to translate Map Editor
|
||||||
|
|
||||||
|
### Submitting changes
|
||||||
|
|
||||||
|
Once you have finished with translation you need to submit these changes to vcmi team using git or Github Desktop
|
||||||
|
- Commit all your changed files
|
||||||
|
- Push changes to your forked repository
|
||||||
|
- Create pull request in VCMI repository with your changes
|
||||||
|
|
||||||
|
If everything is OK, your changes will be accepted and will be part of next release.
|
||||||
|
|
||||||
|
## Translating mods
|
||||||
|
|
||||||
|
### Exporting translation
|
||||||
|
|
||||||
|
TODO
|
||||||
|
|
||||||
|
### Translating mod information
|
||||||
In order to display information in Launcher in language selected by user add following block into your mod.json:
|
In order to display information in Launcher in language selected by user add following block into your mod.json:
|
||||||
```
|
```
|
||||||
"<language>" : {
|
"<language>" : {
|
||||||
"name" : "<translated name>",
|
"name" : "<translated name>",
|
||||||
"description" : "<translated description>",
|
"description" : "<translated description>",
|
||||||
"author" : "<translated author>",
|
"author" : "<translated author>",
|
||||||
"modType" : "<translated mod type>",
|
"translations" : [
|
||||||
|
"config/<modName>/<language>.json"
|
||||||
|
]
|
||||||
},
|
},
|
||||||
```
|
```
|
||||||
List of currently supported values for language parameter:
|
|
||||||
- english
|
|
||||||
- german
|
|
||||||
- polish
|
|
||||||
- russian
|
|
||||||
- ukrainian
|
|
||||||
|
|
||||||
However, normally you don't need to use block for English. Instead, English text should remain in root section of your mod.json file, to be used when game can not find translated version.
|
However, normally you don't need to use block for English. Instead, English text should remain in root section of your mod.json file, to be used when game can not find translated version.
|
||||||
|
|
||||||
### Translation of mod content
|
# Developers documentation
|
||||||
TODO: write me
|
|
||||||
|
|
||||||
### Searching for missing translation strings
|
|
||||||
TODO: write me
|
|
||||||
|
|
||||||
## For developers
|
|
||||||
### Adding new languages
|
### Adding new languages
|
||||||
In order to add new language it needs to be added in multiple locations in source code:
|
In order to add new language it needs to be added in multiple locations in source code:
|
||||||
- Generate new .ts files for launcher and map editor, either by running `lupdate` with name of new .ts or by copying english.ts and editing language tag in the header.
|
- Generate new .ts files for launcher and map editor, either by running `lupdate` with name of new .ts or by copying english.ts and editing language tag in the header.
|
||||||
- Add new language into Launcher UI drop-down selector and name new string using such format:
|
- Add new language into lib/Languages.h entry. This will trigger static_assert's in places that needs an update in code
|
||||||
`"<native name for language> (<english name for language>)"`
|
- Add new language into json schemas validation list - settings schema and mod schema
|
||||||
- Add new language into array of possible values for said selector
|
- Add new language into mod json format - in order to allow translation into new language
|
||||||
|
|
||||||
Also, make full search for a name of an existing language to ensure that there are not other places not referenced here
|
Also, make full search for a name of an existing language to ensure that there are not other places not referenced here
|
||||||
|
|
||||||
### Updating translation of Launcher and Map Editor to include new strings
|
### Updating translation of Launcher and Map Editor to include new strings
|
||||||
|
|
||||||
At the moment, build system will generate binary translation files (.qs) that can be opened by Qt.
|
At the moment, build system will generate binary translation files (.qs) that can be opened by Qt.
|
||||||
However, any new or changed lines will not be added into existing .ts files.
|
However, any new or changed lines will not be added into existing .ts files.
|
||||||
In order to update .ts files manually, open command line shell in `mapeditor` or `launcher` source directories and execute command
|
In order to update .ts files manually, open command line shell in `mapeditor` or `launcher` source directories and execute command
|
||||||
```
|
```
|
||||||
lupdate -no-obsolete * -ts translation/*.ts
|
lupdate -no-obsolete * -ts translation/*.ts
|
||||||
```
|
```
|
||||||
This will remove any no longer existing lines from translation and add any new lines for all translations.
|
|
||||||
|
This will remove any no longer existing lines from translation and add any new lines for all translations. If you want to keep old lines, remove `-no-obsolete` key from the command
|
||||||
There *may* be a way to do the same via QtCreator UI or via CMake, if you find one feel free to update this information.
|
There *may* be a way to do the same via QtCreator UI or via CMake, if you find one feel free to update this information.
|
||||||
|
|
||||||
### Updating translation of Launcher and Map Editor using new .ts file from translators
|
### Updating translation of Launcher and Map Editor using new .ts file from translators
|
||||||
|
|
||||||
Generally, this should be as simple as overwriting old files. Things that may be necessary if translation update is not visible in executable:
|
Generally, this should be as simple as overwriting old files. Things that may be necessary if translation update is not visible in executable:
|
||||||
- Rebuild subproject (map editor/launcher).
|
- Rebuild subproject (map editor/launcher).
|
||||||
- Regenerate translations via `lupdate -no-obsolete * -ts translation/*.ts`
|
- Regenerate translations via `lupdate -no-obsolete * -ts translation/*.ts`
|
Loading…
x
Reference in New Issue
Block a user