
Outra biblioteca de localização com suas próprias abstrações oferece a possibilidade de criar infraestrutura de localização com exemplos. Ele contém a implementação básica do provedor de localização JSON (outros tipos serão adicionados no futuro).
Antes de usar a biblioteca, instale os seguintes pacotes do NUGET:
| Nome | Descrição | Versão |
|---|---|---|
| Tekdeq.localization.core | Biblioteca Core | |
| Tekdeq.localization.dependencyInjection | Extensões Microsoft DI | |
| Tekdeq.localization.avalonia | Avalonia Localização e extensões |
Para criar provedores de localização adicionais, consulte as abstrações IlocalizationProvider e LocalizationProviderBase. Como exemplo de uso, consulte a implementação JSONLocalizationProvider e AvaloniajsonlocalizationProvider. Se você estiver usando a injeção de dependência em seu projeto, um exemplo do uso poderá ser encontrado no app.axaml.cs do projeto Demo.
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 ( ) ;
}Para começar a usar a localização de marcação em Avalonia, localizando a extensão de marcação, ele precisa que o espaço para nome seja adicionado à marcação.
<Window xmlns="https://github.com/avaloniaui"
...
xmlns:i18n="clr-namespace:TekDeq.Localization.Avalonia.Extensions;assembly=TekDeq.Localization.Avalonia"
...
>
Depois disso, poderia ser usado para localização da interface do usuário
<StackPanel
...
<TextBlock Text="{i18n:Localize Greeting}" />
...
</StackPanel>
O projeto demo incluído no repositório, basta abrir e executá -lo no Visual Studio.
Este projeto está licenciado nos termos da licença do MIT.
Contribuições são bem -vindas. Basta abrir um problema ou enviar um novo PR.
Você pode me alcançar através do meu e -mail.