
Еще одна библиотека локализации с собственными абстракциями дает возможность создавать инфраструктуру локализации с примерами. Он содержит базовую реализацию поставщика локализации JSON (другие типы будут добавлены в будущем).
Перед использованием библиотеки установите следующие пакеты Nuget:
| Имя | Описание | Версия |
|---|---|---|
| Tekdeq.localization.core | Основная библиотека | |
| Tekdeq.localization.EpectendencyInction | Microsoft Di расширения | |
| Tekdeq.localization.avalonia | Авалония локализация и расширения |
Чтобы создать дополнительных поставщиков локализации, пожалуйста, посмотрите на абстракции IlocalizationProvider и локализации. В качестве примера использования, пожалуйста, посмотрите на реализацию jsonlocalizationprovider и avaloniajsonlocalizationprovider. Если вы используете инъекцию зависимостей в своем проекте, пример использования можно найти в app.axaml.cs демонстрационного проекта.
public override void OnFrameworkInitializationCompleted ( )
{
var host = Host . CreateDefaultBuilder ( )
. ConfigureServices ( ( context , services ) =>
{
services . UseMicrosoftDependencyResolver ( ) ;
// Initialize Splat
var resolver = Locator . CurrentMutable ;
resolver . InitializeSplat ( ) ;
resolver . InitializeReactiveUI ( ) ;
// Register Views and ViewModels
services . AddTransient < MainWindow > ( ) ;
services . AddTransient < MainWindowViewModel > ( ) ;
// Register Localization
services . AddLocalization < AvaloniaJsonLocalizationProvider > ( ( ) =>
{
var options = new AvaloniaLocalizationOptions (
// cultures support localization
new List < CultureInfo >
{
new ( "en-US" ) ,
new ( "uk-UA" )
} ,
// defaultCulture, it uses for setting if currentCulture is not in cultures list
// and as fallback culture mor missing localization entries.
new CultureInfo ( "en-US" ) ,
// currentCulture sets when infrastructure loads,
// could be received from app settings or so.
Thread . CurrentThread . CurrentCulture ,
// path to assets with json files of localization.
$ " { typeof ( App ) . Namespace } /Assets/i18n" ) ;
return options ;
} ) ;
} ) . Build ( ) ;
if ( ApplicationLifetime is IClassicDesktopStyleApplicationLifetime desktop )
{
desktop . MainWindow = new MainWindow
{
DataContext = host . Services . GetRequiredService < MainWindowViewModel > ( )
} ;
}
base . OnFrameworkInitializationCompleted ( ) ;
}Для начала использования локализации разметки в Avalonia путем локализации расширения наценки ему нужно добавлять пространство имен в разметку.
<Window xmlns="https://github.com/avaloniaui"
...
xmlns:i18n="clr-namespace:TekDeq.Localization.Avalonia.Extensions;assembly=TekDeq.Localization.Avalonia"
...
>
После этого он может быть использован для локализации пользовательского интерфейса
<StackPanel
...
<TextBlock Text="{i18n:Localize Greeting}" />
...
</StackPanel>
Демо -проект включен в репозиторий, просто откройте и запустите его в Visual Studio.
Этот проект лицензирован в соответствии с условиями лицензии MIT.
Взносы приветствуются. Просто откройте проблему или отправьте новый PR.
Вы можете связаться со мной по моей электронной почте.