Skip to content

ProConcept Localization

UmaHarano edited this page Nov 6, 2024 · 22 revisions
Language:      C#
Subject:       Framework
Contributor:   ArcGIS Pro SDK Team <[email protected]>
Organization:  Esri, http://www.esri.com
Date:          10/06/2024
ArcGIS Pro:    3.4
Visual Studio: 2022

ProConcept Localizing add-ins

Localization of an add-in is the translation of add-in resources into localized versions for the specific cultures and locale the add-in has to support. Globalization is the process of designing and developing add-ins that function for multiple cultures and locales. In addition to the translation into the target language, the add-in also has to support number, currency, date formats, and sorting rules for each specific region or locale.

The settings for these regional options are not driven by the language but instead by user settings such as the User Locale (CurrentCulture). The globalization process described in this section addresses both: translation into a target language and supporting a target region or locale.

Globalizing an ArcGIS Pro add-in follows Microsoft's standards for .NET globalization and WPF globalization as defined by Microsoft.

The declarative portion of an add-in extension is defined within a DAML file containing a collection of framework elements including those elements' captions and other attributes. Similar to resource files and XAML files in .NET/WPF, DAML files are directly translated. In a Visual Studio project file for an ArcGIS Pro add-in, this results in the following additional resource and DAML files that hold the translated text: In .NET translation of resource files, adds a translation for each supported language, for example, Resources.resx (default translation) and Resources.de.resx (German Translation). For DAML files, direct translations result in the following translation files: Config.daml (default translation) and Config.de.daml (German translation).

General WPF design guidelines for globalization

When designing WPF based user interfaces ready for globalization, consider these best practices:

Write your UI in XAML and avoid creating UI in code. When you create your UI by using XAML, you expose it through built-in localization APIs. Avoid using absolute positions and fixed sizes to lay out content; instead, use relative or automatic sizing. Use SizeToContent and and keep widths and heights set to Auto. Avoid using Canvas to lay out UIs. Use Grid and its size sharing feature. Provide extra space in margins because localized text often requires more space. Extra space allows for possible overhanging characters. Enable TextWrapping on TextBlock to avoid clipping. Use standard numeric and date/time formats instead of custom formatting. For example:

 //Currency ‘C’
 double amount = 123.456;
 amount.ToString("C", CultureInfo.CreateSpecificCulture("en-US")) ---> $123.46
 amount.ToString("C", CultureInfo.CreateSpecificCulture("fr-FR")) ---> 123,46//Date "d"
 DateTime dt = new DateTime(2017, 3, 9, 16, 5, 7, 123);
 dt.ToString("{0:d}") //---> 3/9/2017 (en-US)
 dt.ToString("{0:d}") //---> 9/3/2017 (fr-FR)
 // date separator in german culture is "." (so "/" changes to ".")
 dt.ToString("{0:d}") //---> 9.3.2017 (de-DE)
 ...

There are various ways to implement localization in WPF (see Globalization and Localization in WPF – Some thoughts for a detailed discussion on some of the methods).

However, since ArcGIS Pro add-ins are utilizing the MVVM (Model-View-ViewModel) pattern, the recommended method for localization is to use resource files with static references to the resource properties. Using the resource file methods means that both code and XAML need to reference a string property in your resource files using a code reference like Properties.Resources.[the string’s name] or a static XAML reference like {x:Static prop:Resources.[the string’s name]} with prop defined as ‘xmlns:prop="clr-namespace:Localization.Properties"’. A Localization sample is also available.

Deployment of localized add-ins

If you deploy a globalized add-in that contains multiple languages, ArcGIS Pro utilizes the language matching the Microsoft Windows setting and if there is no matching language in the add-in, the system reverts to the default resources. For example, if the add-in has these translations: Resources.resx (default translation) and Resources.de.resx (German translation), Resources.de.resx is utilized by Windows installations using the German language preference; whereas, all other Windows language configurations utilize the default translation, Resources.resx. ArcGIS Pro also has an overwrite option that allows changing the default language for ArcGIS Pro:

language-options.png

Determining the current culture

Add-ins needing to programmatically determine which locale/current culture Pro is running under can use System.Globalization.CultureInfo.CurrentUICulture

More information can be found here: https://community.esri.com/t5/arcgis-pro-sdk-questions/how-to-get-the-current-language-used-if-more-thant/td-p/1101455/jump-to/first-unread-message

Developing with ArcGIS Pro

    Migration


Framework

    Add-ins

    Configurations

    Customization

    Styling


Arcade


Content


CoreHost


DataReviewer


Editing


Geodatabase

    3D Analyst Data

    Plugin Datasources

    Topology

    Linear Referencing

    Object Model Diagram


Geometry

    Relational Operations


Geoprocessing


Knowledge Graph


Layouts

    Reports


Map Authoring

    3D Analyst

    CIM

    Graphics

    Scene

    Stream

    Voxel


Map Exploration

    Map Tools


Networks

    Network Diagrams


Parcel Fabric


Raster


Sharing


Tasks


Workflow Manager Classic


Workflow Manager


Reference

Clone this wiki locally