diff --git a/Tasks/Lab6/UWPClient/App.xaml b/Tasks/Lab6/UWPClient/App.xaml new file mode 100644 index 0000000..2e835a2 --- /dev/null +++ b/Tasks/Lab6/UWPClient/App.xaml @@ -0,0 +1,7 @@ + + + diff --git a/Tasks/Lab6/UWPClient/App.xaml.cs b/Tasks/Lab6/UWPClient/App.xaml.cs new file mode 100644 index 0000000..9c1d7e9 --- /dev/null +++ b/Tasks/Lab6/UWPClient/App.xaml.cs @@ -0,0 +1,100 @@ +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.Foundation; +using Windows.Foundation.Collections; +using Windows.UI.Xaml; +using Windows.UI.Xaml.Controls; +using Windows.UI.Xaml.Controls.Primitives; +using Windows.UI.Xaml.Data; +using Windows.UI.Xaml.Input; +using Windows.UI.Xaml.Media; +using Windows.UI.Xaml.Navigation; + +namespace UWPClient +{ + /// + /// Provides application-specific behavior to supplement the default Application class. + /// + sealed partial class App : Application + { + /// + /// 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(). + /// + public App() + { + this.InitializeComponent(); + this.Suspending += OnSuspending; + } + + /// + /// 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. + /// + /// Details about the launch request and process. + 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; + + if (e.PreviousExecutionState == ApplicationExecutionState.Terminated) + { + //TODO: Load state from previously suspended application + } + + // 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(); + } + } + + /// + /// Invoked when Navigation to a certain page fails + /// + /// The Frame which failed navigation + /// Details about the navigation failure + void OnNavigationFailed(object sender, NavigationFailedEventArgs e) + { + throw new Exception("Failed to load Page " + e.SourcePageType.FullName); + } + + /// + /// 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. + /// + /// The source of the suspend request. + /// Details about the suspend request. + private void OnSuspending(object sender, SuspendingEventArgs e) + { + var deferral = e.SuspendingOperation.GetDeferral(); + //TODO: Save application state and stop any background activity + deferral.Complete(); + } + } +} diff --git a/Tasks/Lab6/UWPClient/Assets/LockScreenLogo.scale-200.png b/Tasks/Lab6/UWPClient/Assets/LockScreenLogo.scale-200.png new file mode 100644 index 0000000..735f57a Binary files /dev/null and b/Tasks/Lab6/UWPClient/Assets/LockScreenLogo.scale-200.png differ diff --git a/Tasks/Lab6/UWPClient/Assets/SplashScreen.scale-200.png b/Tasks/Lab6/UWPClient/Assets/SplashScreen.scale-200.png new file mode 100644 index 0000000..023e7f1 Binary files /dev/null and b/Tasks/Lab6/UWPClient/Assets/SplashScreen.scale-200.png differ diff --git a/Tasks/Lab6/UWPClient/Assets/Square150x150Logo.scale-200.png b/Tasks/Lab6/UWPClient/Assets/Square150x150Logo.scale-200.png new file mode 100644 index 0000000..af49fec Binary files /dev/null and b/Tasks/Lab6/UWPClient/Assets/Square150x150Logo.scale-200.png differ diff --git a/Tasks/Lab6/UWPClient/Assets/Square44x44Logo.scale-200.png b/Tasks/Lab6/UWPClient/Assets/Square44x44Logo.scale-200.png new file mode 100644 index 0000000..ce342a2 Binary files /dev/null and b/Tasks/Lab6/UWPClient/Assets/Square44x44Logo.scale-200.png differ diff --git a/Tasks/Lab6/UWPClient/Assets/Square44x44Logo.targetsize-24_altform-unplated.png b/Tasks/Lab6/UWPClient/Assets/Square44x44Logo.targetsize-24_altform-unplated.png new file mode 100644 index 0000000..f6c02ce Binary files /dev/null and b/Tasks/Lab6/UWPClient/Assets/Square44x44Logo.targetsize-24_altform-unplated.png differ diff --git a/Tasks/Lab6/UWPClient/Assets/StoreLogo.png b/Tasks/Lab6/UWPClient/Assets/StoreLogo.png new file mode 100644 index 0000000..7385b56 Binary files /dev/null and b/Tasks/Lab6/UWPClient/Assets/StoreLogo.png differ diff --git a/Tasks/Lab6/UWPClient/Assets/Wide310x150Logo.scale-200.png b/Tasks/Lab6/UWPClient/Assets/Wide310x150Logo.scale-200.png new file mode 100644 index 0000000..288995b Binary files /dev/null and b/Tasks/Lab6/UWPClient/Assets/Wide310x150Logo.scale-200.png differ diff --git a/Tasks/Lab6/UWPClient/MainPage.xaml b/Tasks/Lab6/UWPClient/MainPage.xaml new file mode 100644 index 0000000..078c9af --- /dev/null +++ b/Tasks/Lab6/UWPClient/MainPage.xaml @@ -0,0 +1,27 @@ + + + + + + + +