#
Localizer
The Localizer component configures and manages LocalizationMethods.
#
Interface
public interface ILocalizer
{
ILocalizationMethod[] AvailableLocalizationMethods { get; }
Task<ILocalizerConfigurationResult> ConfigureLocalizer(ILocalizerConfiguration configuration);
Task<ILocalizationResults> Localize(ICameraData cameraData);
Task<List<LocalizationTask>> CreateLocalizationTasks(ICameraData cameraData);
Task<ILocalizationResults> LocalizeAllMethods(ICameraData cameraData);
Task StopAndCleanUp();
Task StopLocalizationForMethod(ILocalizationMethod localizationMethod);
bool TryGetLocalizationTask(ILocalizationMethod localizationMethod, out LocalizationTask task);
}
#
ConfigureLocalization
Implementations of this method are expected to set up the Localizer.
Implementations receive ILocalizationConfiguration which includes a Dictionary mapping XRMaps to their associated ILocalizationMethods.
The implementation should return a simple result describing success.
public interface ILocalizationConfiguration
{
Dictionary<ILocalizationMethod, XRMap[]> LocalizationMethodXRMapMapping { get; }
}
public interface ILocalizationConfigurationResult
{
public bool Success { get; }
}
The SDK will call this in the beginning of runtime, after PlatformSupport has been configured.
#
Localize
Implementations of this method return a collection of localization results:
public interface ILocalizationResults
{
ILocalizationResult[] results { get; }
}
ILocalizationResult is declared together with ILocalizationMethod.
ImmersalSession calls this after getting data from PlatformSupport update as part of it's pipeline cycle.
#
StopAndCleanUp
Implementations of this method are expected to stop any running processes tied to the Localizer in a graceful manner. The Localizer should take care of removing any event subscriptions and cancel any asynchronous tasks etc. The Localizer should be ready for a new call to ConfigureLocalization some time after this method has run.
This is called by the SDK when a full reset is requested.
#
Implementation
The SDK comes with a ready to use implementation of a Localizer with the following features:
- Management and configuration of ILocalizationMethods
- Parallel localization with each configured ILocalizationMethod.
- Events based on localization results