Skip to content

A simple, efficient and lightweight localization tool for Unity applications.

License

Notifications You must be signed in to change notification settings

SametHope/Rapid-Localization

Repository files navigation

Rapid Localization

Rapid Localization is an efficient and lightweight Unity plugin that simplifies adding localization to applications. It requires minimal setup while offering a comprehensive set of features that absolutely surpass its size.

Features

  • Single Editor Window: Convenient setup and configuration through a single editor window.

  • Automatic Initialization: No need for dummy game objects or manual code calls; the plugin sets up and initializes itself automatically without bloating your project.

  • Automatic Language Detection: Automatically detects, uses, and saves the player's language.

  • Runtime Localization: Switch between different localizations at runtime any time as you need.

  • UI Localization: Localize both TextMeshPro (TMP) and legacy UI components.

  • Dropdown Language Selection: Includes prewritten code for a dropdown language selection UI element.

  • Lightweight: Occupies very little space and contains a handful of scripts. The scripts are contained within assembly definitions and do not clutter the main assembly.

  • Debugging: If something goes wrong or encounters an issue, plugin tries fixing it and provides useful debug messages. These messages contain information about what went wrong and offer probable fixes.

  • Platform Compatibility: Supports all platforms.

  • Version Compatibility: Supports all Unity versions.

  • Clean and Simple Code: Plugin features clean, well-structured and documented code.

  • Open Source: The code is open source, allowing customization.

Setup

  • Setup your translation sheet on the Google Sheets.
  • Add the code into your Unity project, ideally into the Plugins folder. The plugin will automatically create its required files which are a folder called RapidLocalization inside Assets/Resources and RapidLocalizationSettings.asset.
  • Open the editor window that we will use to configure the plugin and download the spreadsheets from Google Sheets: Tools -> SametHope -> Localization Syncronizer.
  • Fill in Localization Syncronizer window with information of your Google Sheet and click 'Syncronize!' button to download, format and save the sheet.
  • You are virtually done, the plugin is ready to be used. Configure it to your liking and remember to syncronize it when you make changes on the Google Sheets.

Usage

To translate UI elements, follow these steps:

  1. Add the 'Localizer' component to the UI element you want to translate.

  2. Set the localization key for the 'Localizer' component. This key will be used to update the translation of the UI element when necessary.

  3. Optionally, you can configure the 'Localizer' component to not automatically translate on the Start method and to not to listen to language change events.

To use the pre-made dropdown language selection, follow these steps:

  1. Add the 'LangSelectorDropdown' component to the dropdown UI element.

  2. Set the dropdown options to the available languages. When the dropdown selection changes, the language will be updated and saved automatically.

How does it work?

Rapid Localization utilizes Google Sheets to create translation sheets, enabling teams of any size and contributors to work on translations for multiple languages simultaneously or asynchronously.

The plugin features the 'Localization Synchronizer' custom editor window, accessed on the 'Tools' section, allowing you to easily download the translation spreadsheet(s) to the resources folder to be used in both editor and the builds. The Localization Synchronizer also offers configuration options to customize some of the plugin's behavior.

When your application starts, the LocalizationManager class reads the spreadsheet(s) and loads the translations into memory for the session.

At this point, the plugin can optionally check if a language has been previously saved. If a language is saved, it will be set as the current language. If no language is saved, the plugin will retrieve the player's system language and check if it is a supported language. If it is supported, the system language will be set as the current language and saved. If the system language is not supported, the plugin will fallback to a default language.

When the language is set or changed, listeners are notified and update their languages accordingly. If a translation key is missing in the current language, the fallback language is used. If the fallback is also missing, the key itself is used for easier debugging. Any unintended or significant behaviour is logged, along with helpful tips to resolve them.

Extras

Toolbar

2023-07-06 02_39_03-Ayarlar

This is the toolbar, everyone knows what a toolbar is.

Localization syncronizer

2023-07-06 00_12_15-Mock Jam Project - MenuScene - WebGL - Unity 2021 3 22f1 Personal DX11

You can and probably should hover over properties to read their tooltips.

Localizer

2023-07-06 02_54_15-Temp Medias

I don't advise changing any default options unless you need to.

Google Sheets

2023-07-06 04_06_41-Mock Localisation - Google E-Tablolar - Opera

You must format your Google Sheet like this for the plugin to work.

Green box contents are Localization Keys
Red box contents are Languages
Blue box contents are Localization entries

2023-07-06 02_36_00-Mock Localisation - Google E-Tablolar - Opera

Ensure that your Google Sheet is public so it can be downloaded.

Long red line is the TableID
Short red line is the SheetID

About

A simple, efficient and lightweight localization tool for Unity applications.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages