|
@@ -12,14 +12,20 @@ public class AvaloniaMainActivity : AvaloniaActivity
|
|
{
|
|
{
|
|
if (Application is IAndroidApplication application && application.Lifetime is { } lifetime)
|
|
if (Application is IAndroidApplication application && application.Lifetime is { } lifetime)
|
|
{
|
|
{
|
|
- initialContent ??= lifetime.MainView;
|
|
|
|
|
|
+ initialContent ??= lifetime.MainViewFactory?.Invoke();
|
|
|
|
|
|
- _view = new AvaloniaView(this) { Content = initialContent };
|
|
|
|
- lifetime.Activity = this;
|
|
|
|
|
|
+ _view = new AvaloniaView(this);
|
|
|
|
+
|
|
|
|
+ Content = initialContent;
|
|
}
|
|
}
|
|
|
|
|
|
if (_view is null)
|
|
if (_view is null)
|
|
throw new InvalidOperationException("Unknown error: AvaloniaView initialization has failed.");
|
|
throw new InvalidOperationException("Unknown error: AvaloniaView initialization has failed.");
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ protected override void OnResume()
|
|
|
|
+ {
|
|
|
|
+ base.OnResume();
|
|
|
|
|
|
if (Avalonia.Application.Current?.TryGetFeature<IActivatableLifetime>()
|
|
if (Avalonia.Application.Current?.TryGetFeature<IActivatableLifetime>()
|
|
is AndroidActivatableLifetime activatableLifetime)
|
|
is AndroidActivatableLifetime activatableLifetime)
|
|
@@ -28,6 +34,17 @@ public class AvaloniaMainActivity : AvaloniaActivity
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+ protected override void OnDestroy()
|
|
|
|
+ {
|
|
|
|
+ base.OnDestroy();
|
|
|
|
+
|
|
|
|
+ if (Avalonia.Application.Current?.TryGetFeature<IActivatableLifetime>()
|
|
|
|
+ is AndroidActivatableLifetime activatableLifetime && activatableLifetime.CurrentMainActivity == this)
|
|
|
|
+ {
|
|
|
|
+ activatableLifetime.CurrentMainActivity = null;
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+
|
|
protected virtual AppBuilder CreateAppBuilder() => AppBuilder.Configure<Application>().UseAndroid();
|
|
protected virtual AppBuilder CreateAppBuilder() => AppBuilder.Configure<Application>().UseAndroid();
|
|
protected virtual AppBuilder CustomizeAppBuilder(AppBuilder builder) => builder;
|
|
protected virtual AppBuilder CustomizeAppBuilder(AppBuilder builder) => builder;
|
|
}
|
|
}
|