Permalink
Cannot retrieve contributors at this time
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
142 lines (128 sloc)
5.59 KB
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
using System; | |
using System.Collections.Generic; | |
using System.IO; | |
using System.Linq; | |
using System.Runtime.InteropServices.WindowsRuntime; | |
using Windows.ApplicationModel; | |
using Windows.ApplicationModel.Activation; | |
using Windows.ApplicationModel.AppService; | |
using Windows.ApplicationModel.Background; | |
using Windows.Foundation; | |
using Windows.Foundation.Collections; | |
using Windows.UI.Xaml; | |
using Windows.UI.Xaml.Controls; | |
using Windows.UI.Xaml.Navigation; | |
namespace UWP | |
{ | |
/// <summary> | |
/// Provides application-specific behavior to supplement the default Application class. | |
/// </summary> | |
sealed partial class App : Application | |
{ | |
public static BackgroundTaskDeferral AppServiceDeferral = null; | |
public static AppServiceConnection Connection = null; | |
public static event EventHandler AppServiceDisconnected; | |
public static event EventHandler<AppServiceTriggerDetails> AppServiceConnected; | |
public static bool IsForeground = false; | |
/// <summary> | |
/// Initializes the singleton application object. This is the first line of authored code | |
/// executed, and as such is the logical equivalent of main() or WinMain(). | |
/// </summary> | |
public App() | |
{ | |
this.InitializeComponent(); | |
this.Suspending += OnSuspending; | |
this.EnteredBackground += App_EnteredBackground; | |
this.LeavingBackground += App_LeavingBackground; | |
} | |
private void App_LeavingBackground(object sender, LeavingBackgroundEventArgs e) | |
{ | |
IsForeground = true; | |
} | |
private void App_EnteredBackground(object sender, EnteredBackgroundEventArgs e) | |
{ | |
IsForeground = false; | |
} | |
/// <summary> | |
/// Handles connection requests to the app service | |
/// </summary> | |
protected override void OnBackgroundActivated(BackgroundActivatedEventArgs args) | |
{ | |
base.OnBackgroundActivated(args); | |
if (args.TaskInstance.TriggerDetails is AppServiceTriggerDetails details) | |
{ | |
// only accept connections from callers in the same package | |
if (details.CallerPackageFamilyName == Package.Current.Id.FamilyName) | |
{ | |
// connection established from the fulltrust process | |
AppServiceDeferral = args.TaskInstance.GetDeferral(); | |
args.TaskInstance.Canceled += OnTaskCanceled; | |
Connection = details.AppServiceConnection; | |
AppServiceConnected?.Invoke(this, args.TaskInstance.TriggerDetails as AppServiceTriggerDetails); | |
} | |
} | |
} | |
/// <summary> | |
/// Task canceled here means the app service client is gone | |
/// </summary> | |
private void OnTaskCanceled(IBackgroundTaskInstance sender, BackgroundTaskCancellationReason reason) | |
{ | |
AppServiceDeferral?.Complete(); | |
AppServiceDeferral = null; | |
Connection = null; | |
AppServiceDisconnected?.Invoke(this, null); | |
} | |
/// <summary> | |
/// Invoked when the application is launched normally by the end user. Other entry points | |
/// will be used such as when the application is launched to open a specific file. | |
/// </summary> | |
/// <param name="e">Details about the launch request and process.</param> | |
protected override void OnLaunched(LaunchActivatedEventArgs e) | |
{ | |
Frame rootFrame = Window.Current.Content as Frame; | |
// Do not repeat app initialization when the Window already has content, | |
// just ensure that the window is active | |
if (rootFrame == null) | |
{ | |
// Create a Frame to act as the navigation context and navigate to the first page | |
rootFrame = new Frame(); | |
rootFrame.NavigationFailed += OnNavigationFailed; | |
// Place the frame in the current Window | |
Window.Current.Content = rootFrame; | |
} | |
if (e.PrelaunchActivated == false) | |
{ | |
if (rootFrame.Content == null) | |
{ | |
// When the navigation stack isn't restored navigate to the first page, | |
// configuring the new page by passing required information as a navigation | |
// parameter | |
rootFrame.Navigate(typeof(MainPage), e.Arguments); | |
} | |
// Ensure the current window is active | |
Window.Current.Activate(); | |
} | |
} | |
/// <summary> | |
/// Invoked when Navigation to a certain page fails | |
/// </summary> | |
/// <param name="sender">The Frame which failed navigation</param> | |
/// <param name="e">Details about the navigation failure</param> | |
void OnNavigationFailed(object sender, NavigationFailedEventArgs e) | |
{ | |
throw new Exception("Failed to load Page " + e.SourcePageType.FullName); | |
} | |
/// <summary> | |
/// Invoked when application execution is being suspended. Application state is saved | |
/// without knowing whether the application will be terminated or resumed with the contents | |
/// of memory still intact. | |
/// </summary> | |
/// <param name="sender">The source of the suspend request.</param> | |
/// <param name="e">Details about the suspend request.</param> | |
private void OnSuspending(object sender, SuspendingEventArgs e) | |
{ | |
var deferral = e.SuspendingOperation.GetDeferral(); | |
deferral.Complete(); | |
} | |
} | |
} |