diff --git a/Apps/Pointing_Task/App2/App.xaml b/Apps/Pointing_Task/App2/App.xaml
new file mode 100644
index 0000000..9d7d0be
--- /dev/null
+++ b/Apps/Pointing_Task/App2/App.xaml
@@ -0,0 +1,8 @@
+
+
+
diff --git a/Apps/Pointing_Task/App2/App.xaml.cs b/Apps/Pointing_Task/App2/App.xaml.cs
new file mode 100644
index 0000000..0548b8a
--- /dev/null
+++ b/Apps/Pointing_Task/App2/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 Pointing_Task
+{
+ ///
+ /// 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/Apps/Pointing_Task/App2/Assets/LockScreenLogo.scale-200.png b/Apps/Pointing_Task/App2/Assets/LockScreenLogo.scale-200.png
new file mode 100644
index 0000000..735f57a
Binary files /dev/null and b/Apps/Pointing_Task/App2/Assets/LockScreenLogo.scale-200.png differ
diff --git a/Apps/Pointing_Task/App2/Assets/SplashScreen.scale-200.png b/Apps/Pointing_Task/App2/Assets/SplashScreen.scale-200.png
new file mode 100644
index 0000000..023e7f1
Binary files /dev/null and b/Apps/Pointing_Task/App2/Assets/SplashScreen.scale-200.png differ
diff --git a/Apps/Pointing_Task/App2/Assets/Square150x150Logo.scale-200.png b/Apps/Pointing_Task/App2/Assets/Square150x150Logo.scale-200.png
new file mode 100644
index 0000000..af49fec
Binary files /dev/null and b/Apps/Pointing_Task/App2/Assets/Square150x150Logo.scale-200.png differ
diff --git a/Apps/Pointing_Task/App2/Assets/Square44x44Logo.scale-200.png b/Apps/Pointing_Task/App2/Assets/Square44x44Logo.scale-200.png
new file mode 100644
index 0000000..ce342a2
Binary files /dev/null and b/Apps/Pointing_Task/App2/Assets/Square44x44Logo.scale-200.png differ
diff --git a/Apps/Pointing_Task/App2/Assets/Square44x44Logo.targetsize-24_altform-unplated.png b/Apps/Pointing_Task/App2/Assets/Square44x44Logo.targetsize-24_altform-unplated.png
new file mode 100644
index 0000000..f6c02ce
Binary files /dev/null and b/Apps/Pointing_Task/App2/Assets/Square44x44Logo.targetsize-24_altform-unplated.png differ
diff --git a/Apps/Pointing_Task/App2/Assets/StoreLogo.png b/Apps/Pointing_Task/App2/Assets/StoreLogo.png
new file mode 100644
index 0000000..7385b56
Binary files /dev/null and b/Apps/Pointing_Task/App2/Assets/StoreLogo.png differ
diff --git a/Apps/Pointing_Task/App2/Assets/Wide310x150Logo.scale-200.png b/Apps/Pointing_Task/App2/Assets/Wide310x150Logo.scale-200.png
new file mode 100644
index 0000000..288995b
Binary files /dev/null and b/Apps/Pointing_Task/App2/Assets/Wide310x150Logo.scale-200.png differ
diff --git a/Apps/Pointing_Task/App2/MainPage.xaml b/Apps/Pointing_Task/App2/MainPage.xaml
new file mode 100644
index 0000000..b385651
--- /dev/null
+++ b/Apps/Pointing_Task/App2/MainPage.xaml
@@ -0,0 +1,33 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/Apps/Pointing_Task/App2/MainPage.xaml.cs b/Apps/Pointing_Task/App2/MainPage.xaml.cs
new file mode 100644
index 0000000..8599230
--- /dev/null
+++ b/Apps/Pointing_Task/App2/MainPage.xaml.cs
@@ -0,0 +1,261 @@
+using System;
+using System.Collections.Generic;
+using System.IO;
+using System.Linq;
+using System.Runtime.InteropServices.WindowsRuntime;
+using Windows.Foundation;
+using Windows.Foundation.Collections;
+using Windows.Storage.Streams;
+using Windows.UI.Popups;
+using Windows.UI.ViewManagement;
+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;
+using Windows.Devices.Input.Preview;
+
+
+namespace Pointing_Task
+{
+ ///
+ /// An empty page that can be used on its own or navigated to within a Frame.
+ ///
+ public sealed partial class MainPage : Page
+ {
+ List buttons = new List();
+ Random rand = new Random();
+ SolidColorBrush black = new SolidColorBrush(Windows.UI.Colors.Black);
+ SolidColorBrush white = new SolidColorBrush(Windows.UI.Colors.White);
+ SolidColorBrush blue = new SolidColorBrush(Windows.UI.Colors.Blue);
+ Button currentButton = null;
+ TranslateTransform translateTransform = new TranslateTransform();
+
+ int counter = 0;
+ int trials = 0;
+
+
+
+
+ TransformGroup transformGroup = new TransformGroup();
+ Rect bounds = ApplicationView.GetForCurrentView().VisibleBounds;
+ private IRandomAccessStream stream;
+ private IOutputStream outputStream;
+ private DataWriter dataWriter;
+
+
+ public MainPage()
+ {
+
+ createLogFileAsync();//creating logFile in the app's localstate folder
+ this.InitializeComponent();
+ Window.Current.Activate();
+ var appView = Windows.UI.ViewManagement.ApplicationView.GetForCurrentView();
+ appView.Title = "Pointing Task";
+ buttons.Add(button1);
+ buttons.Add(button2);
+ buttons.Add(button3);
+ buttons.Add(button4);
+ buttons.Add(button5);
+ buttons.Add(button6);
+ buttons.Add(button7);
+ buttons.Add(button8);
+ //initialising all button positions to 0,0
+ foreach (Button b in buttons)
+ {
+ b.Visibility = Visibility.Collapsed;
+ b.Margin = new Thickness(0, 0, 0, 0);
+ }
+ resetButtons();
+ currentButton = button1;
+ currentButton.Background = black;
+ currentButton.Foreground = white;
+ currentButton.Content = "X";
+
+
+
+ centerButton.Margin = new Thickness(0, 0, 0, 0);
+ translateTransform = new TranslateTransform();
+ transformGroup = new TransformGroup();
+ translateTransform.X = bounds.Width / 2 - centerButton.Width / 2;
+ translateTransform.Y = bounds.Height / 2 - centerButton.Height / 2;
+ transformGroup.Children.Add(translateTransform);
+ centerButton.RenderTransform = transformGroup;
+ centerButton.Visibility = Visibility.Collapsed;
+
+ StartButton.Margin = new Thickness(0, 0, 0, 0);
+ translateTransform = new TranslateTransform();
+ transformGroup = new TransformGroup();
+ translateTransform.X = bounds.Width / 2 - centerButton.Width / 2;
+ translateTransform.Y = bounds.Height / 2 - centerButton.Height / 2;
+ transformGroup.Children.Add(translateTransform);
+ StartButton.RenderTransform = transformGroup;
+
+
+ }
+ private async void createLogFileAsync()
+ {
+ Windows.Storage.StorageFolder storageFolder =
+ Windows.Storage.ApplicationData.Current.LocalFolder;
+ var messageDialog = new MessageDialog(storageFolder.ToString());
+
+
+ Windows.Storage.StorageFile sampleFile =
+ await storageFolder.CreateFileAsync("log.txt",
+ Windows.Storage.CreationCollisionOption.GenerateUniqueName);
+ stream = await sampleFile.OpenAsync(Windows.Storage.FileAccessMode.ReadWrite);
+ outputStream = stream.GetOutputStreamAt(0);
+ dataWriter = new Windows.Storage.Streams.DataWriter(outputStream);
+
+
+
+
+ }
+
+
+ struct cStruct //structure for storing combination
+ {
+ public int radius;
+ public int edge;
+ public cStruct(int radius, int edge)
+ {
+ this.radius = radius;
+ this.edge = edge;
+ }
+ };
+ List combinationList = new List();
+
+ private void resetList() //generating list for all combinations
+ {
+
+ int radius = 200;
+ int edge = 135;
+ int radius1 = 260;
+ int edge1 = 100;
+
+ combinationList = new List();
+ combinationList.Add(new cStruct(radius, edge)); //200,135
+ combinationList.Add(new cStruct(radius1, edge1)); //260,100
+ combinationList.Add(new cStruct(radius1, edge)); //260,135
+ combinationList.Add(new cStruct(radius, edge1)); //200,100
+ }
+
+ private void positionTargets() //positioning targets in a circle
+ {
+
+ TranslateTransform translateTransform = new TranslateTransform();
+
+ TransformGroup transformGroup = new TransformGroup();
+ if (counter % 4 == 0) resetList();
+
+ int steps = buttons.Count;
+
+
+ double left;
+ double top;
+
+ Random random = new Random();
+ int a = random.Next(0, combinationList.Count - 1);
+ if (counter == 3)
+ {
+ a = 0;
+ }
+ var cStruct = combinationList[a];
+
+ for (var i = 1; i <= buttons.Count; i++)
+ {
+ buttons[i - 1].Visibility = Visibility.Visible;
+ buttons[i - 1].Width = cStruct.edge;
+ buttons[i - 1].Height = cStruct.edge;
+ left = (bounds.Width / 2 + cStruct.radius * Math.Cos(2 * Math.PI * i / steps));
+ top = (bounds.Height / 2 + cStruct.radius * Math.Sin(2 * Math.PI * i / steps));
+ translateTransform = new TranslateTransform();
+ transformGroup = new TransformGroup();
+ translateTransform.X = left;
+ translateTransform.Y = top;
+ transformGroup.Children.Add(translateTransform);
+
+ buttons[i - 1].RenderTransform = transformGroup;
+
+ }
+
+
+ counter++;
+ combinationList.Remove(cStruct);
+ trials++;
+ if (trials == 20) Application.Current.Exit();
+
+ }
+
+
+ private void StartButton_Click(object sender, RoutedEventArgs e)
+ {
+ centerButton.Visibility = Visibility.Visible;
+ Button b = sender as Button;
+ b.Visibility = Visibility.Collapsed;
+ var ttv = b.TransformToVisual(Window.Current.Content);
+ Point screenCoords = ttv.TransformPoint(new Point(0, 0));
+ writeDataAsync("StartButton," + screenCoords.X + "," + screenCoords.Y + "," + b.Width + "," + b.Height);
+
+ }
+
+ private void Button5_Click(object sender, RoutedEventArgs e)
+ {
+
+ Button b = sender as Button;
+
+ if (b == centerButton)
+ {
+ positionTargets();
+ centerButton.Visibility = Visibility.Collapsed;
+ var ttv = b.TransformToVisual(Window.Current.Content);
+ Point screenCoords = ttv.TransformPoint(new Point(0, 0));
+ writeDataAsync("CenterButton," + bounds.Width / 2 + "," + bounds.Height / 2 + "," + b.Width + "," + b.Height);
+ }
+ else
+ if (b.Name.Equals(((Button)currentButton).Name))
+ {
+ resetButtons();
+ var r = rand.Next(1, 8);
+ Button s = buttons[r] as Button;
+ s.Background = black;
+ s.Foreground = white;
+ s.Content = "X";
+ s.FontSize = 50;
+ currentButton = s;
+ centerButton.Visibility = Visibility.Visible;
+ var ttv = b.TransformToVisual(Window.Current.Content);
+ Point screenCoords = ttv.TransformPoint(new Point(0, 0));
+ writeDataAsync("CurrentButton," + screenCoords.X + "," + screenCoords.Y + "," + b.Width + "," + b.Height);
+
+ }
+ else
+ {
+ var ttv = b.TransformToVisual(Window.Current.Content);
+ Point screenCoords = ttv.TransformPoint(new Point(0, 0));
+ writeDataAsync("Missed" + b.Name + "," + screenCoords.X + "," + screenCoords.Y + "," + b.Width + "," + b.Height);
+ }
+
+ }
+ private void resetButtons()
+ {
+ foreach (Button b in buttons)
+ {
+
+ b.Background = blue;
+ b.Content = "";
+ b.Visibility = Visibility.Collapsed;
+ }
+
+ }
+ private async void writeDataAsync(String data)
+ {
+ dataWriter.WriteString(data + "," + DateTime.UtcNow.Ticks + Environment.NewLine);
+ await dataWriter.StoreAsync();
+ await dataWriter.FlushAsync();
+ }
+
+ }
+}
\ No newline at end of file
diff --git a/Apps/Pointing_Task/App2/Package.appxmanifest b/Apps/Pointing_Task/App2/Package.appxmanifest
new file mode 100644
index 0000000..437a70c
--- /dev/null
+++ b/Apps/Pointing_Task/App2/Package.appxmanifest
@@ -0,0 +1,29 @@
+
+
+
+
+
+ Pointing_Task
+ Sin-PC
+ Assets\StoreLogo.png
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/Apps/Pointing_Task/App2/Pointing_Task.csproj b/Apps/Pointing_Task/App2/Pointing_Task.csproj
new file mode 100644
index 0000000..1e092fc
--- /dev/null
+++ b/Apps/Pointing_Task/App2/Pointing_Task.csproj
@@ -0,0 +1,151 @@
+
+
+
+
+ Debug
+ x86
+ {EAA3DD1D-5417-4E3F-B239-0644A4446379}
+ AppContainerExe
+ Properties
+ Pointing_Task
+ Pointing_Task
+ en-US
+ UAP
+ 10.0.17763.0
+ 10.0.17134.0
+ 14
+ 512
+ {A5A43C5B-DE2A-4C0C-9213-0A381AF9435A};{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}
+ true
+ App2_TemporaryKey.pfx
+ True
+ Always
+ x86|x64
+
+
+ true
+ bin\x86\Debug\
+ DEBUG;TRACE;NETFX_CORE;WINDOWS_UWP
+ ;2008
+ full
+ x86
+ false
+ prompt
+ true
+
+
+ bin\x86\Release\
+ TRACE;NETFX_CORE;WINDOWS_UWP
+ true
+ ;2008
+ pdbonly
+ x86
+ false
+ prompt
+ true
+ true
+
+
+ true
+ bin\ARM\Debug\
+ DEBUG;TRACE;NETFX_CORE;WINDOWS_UWP
+ ;2008
+ full
+ ARM
+ false
+ prompt
+ true
+
+
+ bin\ARM\Release\
+ TRACE;NETFX_CORE;WINDOWS_UWP
+ true
+ ;2008
+ pdbonly
+ ARM
+ false
+ prompt
+ true
+ true
+
+
+ true
+ bin\x64\Debug\
+ DEBUG;TRACE;NETFX_CORE;WINDOWS_UWP
+ ;2008
+ full
+ x64
+ false
+ prompt
+ true
+
+
+ bin\x64\Release\
+ TRACE;NETFX_CORE;WINDOWS_UWP
+ true
+ ;2008
+ pdbonly
+ x64
+ false
+ prompt
+ true
+ true
+
+
+ PackageReference
+
+
+
+ App.xaml
+
+
+ MainPage.xaml
+
+
+
+
+
+ Designer
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ MSBuild:Compile
+ Designer
+
+
+ MSBuild:Compile
+ Designer
+
+
+
+
+ 5.4.0
+
+
+ 5.0.0
+
+
+
+ 14.0
+
+
+
+
\ No newline at end of file
diff --git a/Apps/Pointing_Task/App2/Properties/AssemblyInfo.cs b/Apps/Pointing_Task/App2/Properties/AssemblyInfo.cs
new file mode 100644
index 0000000..6fda23c
--- /dev/null
+++ b/Apps/Pointing_Task/App2/Properties/AssemblyInfo.cs
@@ -0,0 +1,29 @@
+using System.Reflection;
+using System.Runtime.CompilerServices;
+using System.Runtime.InteropServices;
+
+// General Information about an assembly is controlled through the following
+// set of attributes. Change these attribute values to modify the information
+// associated with an assembly.
+[assembly: AssemblyTitle("Pointing_Task")]
+[assembly: AssemblyDescription("")]
+[assembly: AssemblyConfiguration("")]
+[assembly: AssemblyCompany("")]
+[assembly: AssemblyProduct("Pointing_Task")]
+[assembly: AssemblyCopyright("Copyright I3D,IISC© 2019")]
+[assembly: AssemblyTrademark("")]
+[assembly: AssemblyCulture("")]
+
+// Version information for an assembly consists of the following four values:
+//
+// Major Version
+// Minor Version
+// Build Number
+// Revision
+//
+// You can specify all the values or you can default the Build and Revision Numbers
+// by using the '*' as shown below:
+// [assembly: AssemblyVersion("1.0.*")]
+[assembly: AssemblyVersion("1.0.0.0")]
+[assembly: AssemblyFileVersion("1.0.0.0")]
+[assembly: ComVisible(false)]
\ No newline at end of file
diff --git a/Apps/Pointing_Task/App2/Properties/Default.rd.xml b/Apps/Pointing_Task/App2/Properties/Default.rd.xml
new file mode 100644
index 0000000..af00722
--- /dev/null
+++ b/Apps/Pointing_Task/App2/Properties/Default.rd.xml
@@ -0,0 +1,31 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/Apps/Pointing_Task/Pointing_Task.sln b/Apps/Pointing_Task/Pointing_Task.sln
new file mode 100644
index 0000000..71d90b1
--- /dev/null
+++ b/Apps/Pointing_Task/Pointing_Task.sln
@@ -0,0 +1,43 @@
+
+Microsoft Visual Studio Solution File, Format Version 12.00
+# Visual Studio 15
+VisualStudioVersion = 15.0.26730.8
+MinimumVisualStudioVersion = 10.0.40219.1
+Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Pointing_Task", "App2\Pointing_Task.csproj", "{EAA3DD1D-5417-4E3F-B239-0644A4446379}"
+EndProject
+Global
+ GlobalSection(SolutionConfigurationPlatforms) = preSolution
+ Debug|ARM = Debug|ARM
+ Debug|x64 = Debug|x64
+ Debug|x86 = Debug|x86
+ Release|ARM = Release|ARM
+ Release|x64 = Release|x64
+ Release|x86 = Release|x86
+ EndGlobalSection
+ GlobalSection(ProjectConfigurationPlatforms) = postSolution
+ {EAA3DD1D-5417-4E3F-B239-0644A4446379}.Debug|ARM.ActiveCfg = Debug|ARM
+ {EAA3DD1D-5417-4E3F-B239-0644A4446379}.Debug|ARM.Build.0 = Debug|ARM
+ {EAA3DD1D-5417-4E3F-B239-0644A4446379}.Debug|ARM.Deploy.0 = Debug|ARM
+ {EAA3DD1D-5417-4E3F-B239-0644A4446379}.Debug|x64.ActiveCfg = Debug|x64
+ {EAA3DD1D-5417-4E3F-B239-0644A4446379}.Debug|x64.Build.0 = Debug|x64
+ {EAA3DD1D-5417-4E3F-B239-0644A4446379}.Debug|x64.Deploy.0 = Debug|x64
+ {EAA3DD1D-5417-4E3F-B239-0644A4446379}.Debug|x86.ActiveCfg = Debug|x86
+ {EAA3DD1D-5417-4E3F-B239-0644A4446379}.Debug|x86.Build.0 = Debug|x86
+ {EAA3DD1D-5417-4E3F-B239-0644A4446379}.Debug|x86.Deploy.0 = Debug|x86
+ {EAA3DD1D-5417-4E3F-B239-0644A4446379}.Release|ARM.ActiveCfg = Release|ARM
+ {EAA3DD1D-5417-4E3F-B239-0644A4446379}.Release|ARM.Build.0 = Release|ARM
+ {EAA3DD1D-5417-4E3F-B239-0644A4446379}.Release|ARM.Deploy.0 = Release|ARM
+ {EAA3DD1D-5417-4E3F-B239-0644A4446379}.Release|x64.ActiveCfg = Release|x64
+ {EAA3DD1D-5417-4E3F-B239-0644A4446379}.Release|x64.Build.0 = Release|x64
+ {EAA3DD1D-5417-4E3F-B239-0644A4446379}.Release|x64.Deploy.0 = Release|x64
+ {EAA3DD1D-5417-4E3F-B239-0644A4446379}.Release|x86.ActiveCfg = Release|x86
+ {EAA3DD1D-5417-4E3F-B239-0644A4446379}.Release|x86.Build.0 = Release|x86
+ {EAA3DD1D-5417-4E3F-B239-0644A4446379}.Release|x86.Deploy.0 = Release|x86
+ EndGlobalSection
+ GlobalSection(SolutionProperties) = preSolution
+ HideSolutionNode = FALSE
+ EndGlobalSection
+ GlobalSection(ExtensibilityGlobals) = postSolution
+ SolutionGuid = {94D168FE-4978-4D4B-B6F7-7C6D9378AE48}
+ EndGlobalSection
+EndGlobal
diff --git a/GazeInteractionApps.sln b/GazeInteractionApps.sln
index 56f1e18..e129817 100644
--- a/GazeInteractionApps.sln
+++ b/GazeInteractionApps.sln
@@ -35,88 +35,300 @@ Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Maze", "Games\Maze\Maze.csp
EndProject
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "EyeVolume", "Apps\EyeVolume\EyeVolume.csproj", "{05D9AB57-A57F-4488-A603-C9B76F6932C5}"
EndProject
+Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "ISO_9241_PT", "Tools\ISO_9241_PT\ISO_9241_PT.csproj", "{1CC1DD79-F392-47EC-94E6-26F32B28B65B}"
+EndProject
Global
GlobalSection(SolutionConfigurationPlatforms) = preSolution
+ Debug|ARM = Debug|ARM
+ Debug|ARM64 = Debug|ARM64
Debug|x64 = Debug|x64
+ Debug|x86 = Debug|x86
+ Release|ARM = Release|ARM
+ Release|ARM64 = Release|ARM64
Release|x64 = Release|x64
+ Release|x86 = Release|x86
EndGlobalSection
GlobalSection(ProjectConfigurationPlatforms) = postSolution
+ {E517B2E1-D6D9-49BD-8CAF-5371143CF6C2}.Debug|ARM.ActiveCfg = Debug|ARM
+ {E517B2E1-D6D9-49BD-8CAF-5371143CF6C2}.Debug|ARM.Build.0 = Debug|ARM
+ {E517B2E1-D6D9-49BD-8CAF-5371143CF6C2}.Debug|ARM.Deploy.0 = Debug|ARM
+ {E517B2E1-D6D9-49BD-8CAF-5371143CF6C2}.Debug|ARM64.ActiveCfg = Debug|x86
{E517B2E1-D6D9-49BD-8CAF-5371143CF6C2}.Debug|x64.ActiveCfg = Debug|x64
{E517B2E1-D6D9-49BD-8CAF-5371143CF6C2}.Debug|x64.Build.0 = Debug|x64
{E517B2E1-D6D9-49BD-8CAF-5371143CF6C2}.Debug|x64.Deploy.0 = Debug|x64
+ {E517B2E1-D6D9-49BD-8CAF-5371143CF6C2}.Debug|x86.ActiveCfg = Debug|x86
+ {E517B2E1-D6D9-49BD-8CAF-5371143CF6C2}.Debug|x86.Build.0 = Debug|x86
+ {E517B2E1-D6D9-49BD-8CAF-5371143CF6C2}.Debug|x86.Deploy.0 = Debug|x86
+ {E517B2E1-D6D9-49BD-8CAF-5371143CF6C2}.Release|ARM.ActiveCfg = Release|ARM
+ {E517B2E1-D6D9-49BD-8CAF-5371143CF6C2}.Release|ARM.Build.0 = Release|ARM
+ {E517B2E1-D6D9-49BD-8CAF-5371143CF6C2}.Release|ARM.Deploy.0 = Release|ARM
+ {E517B2E1-D6D9-49BD-8CAF-5371143CF6C2}.Release|ARM64.ActiveCfg = Release|x86
{E517B2E1-D6D9-49BD-8CAF-5371143CF6C2}.Release|x64.ActiveCfg = Release|x64
{E517B2E1-D6D9-49BD-8CAF-5371143CF6C2}.Release|x64.Build.0 = Release|x64
{E517B2E1-D6D9-49BD-8CAF-5371143CF6C2}.Release|x64.Deploy.0 = Release|x64
+ {E517B2E1-D6D9-49BD-8CAF-5371143CF6C2}.Release|x86.ActiveCfg = Release|x86
+ {E517B2E1-D6D9-49BD-8CAF-5371143CF6C2}.Release|x86.Build.0 = Release|x86
+ {E517B2E1-D6D9-49BD-8CAF-5371143CF6C2}.Release|x86.Deploy.0 = Release|x86
+ {9107A7FF-42DD-4128-9AE0-6EEBFF1EA4E2}.Debug|ARM.ActiveCfg = Debug|ARM
+ {9107A7FF-42DD-4128-9AE0-6EEBFF1EA4E2}.Debug|ARM.Build.0 = Debug|ARM
+ {9107A7FF-42DD-4128-9AE0-6EEBFF1EA4E2}.Debug|ARM.Deploy.0 = Debug|ARM
+ {9107A7FF-42DD-4128-9AE0-6EEBFF1EA4E2}.Debug|ARM64.ActiveCfg = Debug|x86
{9107A7FF-42DD-4128-9AE0-6EEBFF1EA4E2}.Debug|x64.ActiveCfg = Debug|x64
{9107A7FF-42DD-4128-9AE0-6EEBFF1EA4E2}.Debug|x64.Build.0 = Debug|x64
{9107A7FF-42DD-4128-9AE0-6EEBFF1EA4E2}.Debug|x64.Deploy.0 = Debug|x64
+ {9107A7FF-42DD-4128-9AE0-6EEBFF1EA4E2}.Debug|x86.ActiveCfg = Debug|x86
+ {9107A7FF-42DD-4128-9AE0-6EEBFF1EA4E2}.Debug|x86.Build.0 = Debug|x86
+ {9107A7FF-42DD-4128-9AE0-6EEBFF1EA4E2}.Debug|x86.Deploy.0 = Debug|x86
+ {9107A7FF-42DD-4128-9AE0-6EEBFF1EA4E2}.Release|ARM.ActiveCfg = Release|ARM
+ {9107A7FF-42DD-4128-9AE0-6EEBFF1EA4E2}.Release|ARM.Build.0 = Release|ARM
+ {9107A7FF-42DD-4128-9AE0-6EEBFF1EA4E2}.Release|ARM.Deploy.0 = Release|ARM
+ {9107A7FF-42DD-4128-9AE0-6EEBFF1EA4E2}.Release|ARM64.ActiveCfg = Release|x86
{9107A7FF-42DD-4128-9AE0-6EEBFF1EA4E2}.Release|x64.ActiveCfg = Release|x64
{9107A7FF-42DD-4128-9AE0-6EEBFF1EA4E2}.Release|x64.Build.0 = Release|x64
{9107A7FF-42DD-4128-9AE0-6EEBFF1EA4E2}.Release|x64.Deploy.0 = Release|x64
+ {9107A7FF-42DD-4128-9AE0-6EEBFF1EA4E2}.Release|x86.ActiveCfg = Release|x86
+ {9107A7FF-42DD-4128-9AE0-6EEBFF1EA4E2}.Release|x86.Build.0 = Release|x86
+ {9107A7FF-42DD-4128-9AE0-6EEBFF1EA4E2}.Release|x86.Deploy.0 = Release|x86
+ {71D93D66-8048-4190-8B94-404B80CE542C}.Debug|ARM.ActiveCfg = Debug|ARM
+ {71D93D66-8048-4190-8B94-404B80CE542C}.Debug|ARM.Build.0 = Debug|ARM
+ {71D93D66-8048-4190-8B94-404B80CE542C}.Debug|ARM.Deploy.0 = Debug|ARM
+ {71D93D66-8048-4190-8B94-404B80CE542C}.Debug|ARM64.ActiveCfg = Debug|x86
{71D93D66-8048-4190-8B94-404B80CE542C}.Debug|x64.ActiveCfg = Debug|x64
{71D93D66-8048-4190-8B94-404B80CE542C}.Debug|x64.Build.0 = Debug|x64
{71D93D66-8048-4190-8B94-404B80CE542C}.Debug|x64.Deploy.0 = Debug|x64
+ {71D93D66-8048-4190-8B94-404B80CE542C}.Debug|x86.ActiveCfg = Debug|x86
+ {71D93D66-8048-4190-8B94-404B80CE542C}.Debug|x86.Build.0 = Debug|x86
+ {71D93D66-8048-4190-8B94-404B80CE542C}.Debug|x86.Deploy.0 = Debug|x86
+ {71D93D66-8048-4190-8B94-404B80CE542C}.Release|ARM.ActiveCfg = Release|ARM
+ {71D93D66-8048-4190-8B94-404B80CE542C}.Release|ARM.Build.0 = Release|ARM
+ {71D93D66-8048-4190-8B94-404B80CE542C}.Release|ARM.Deploy.0 = Release|ARM
+ {71D93D66-8048-4190-8B94-404B80CE542C}.Release|ARM64.ActiveCfg = Release|x86
{71D93D66-8048-4190-8B94-404B80CE542C}.Release|x64.ActiveCfg = Release|x64
{71D93D66-8048-4190-8B94-404B80CE542C}.Release|x64.Build.0 = Release|x64
{71D93D66-8048-4190-8B94-404B80CE542C}.Release|x64.Deploy.0 = Release|x64
+ {71D93D66-8048-4190-8B94-404B80CE542C}.Release|x86.ActiveCfg = Release|x86
+ {71D93D66-8048-4190-8B94-404B80CE542C}.Release|x86.Build.0 = Release|x86
+ {71D93D66-8048-4190-8B94-404B80CE542C}.Release|x86.Deploy.0 = Release|x86
+ {8D06B06E-A7AF-46D4-9E03-37661920F89A}.Debug|ARM.ActiveCfg = Debug|ARM
+ {8D06B06E-A7AF-46D4-9E03-37661920F89A}.Debug|ARM.Build.0 = Debug|ARM
+ {8D06B06E-A7AF-46D4-9E03-37661920F89A}.Debug|ARM.Deploy.0 = Debug|ARM
+ {8D06B06E-A7AF-46D4-9E03-37661920F89A}.Debug|ARM64.ActiveCfg = Debug|x86
{8D06B06E-A7AF-46D4-9E03-37661920F89A}.Debug|x64.ActiveCfg = Debug|x64
{8D06B06E-A7AF-46D4-9E03-37661920F89A}.Debug|x64.Build.0 = Debug|x64
{8D06B06E-A7AF-46D4-9E03-37661920F89A}.Debug|x64.Deploy.0 = Debug|x64
+ {8D06B06E-A7AF-46D4-9E03-37661920F89A}.Debug|x86.ActiveCfg = Debug|x86
+ {8D06B06E-A7AF-46D4-9E03-37661920F89A}.Debug|x86.Build.0 = Debug|x86
+ {8D06B06E-A7AF-46D4-9E03-37661920F89A}.Debug|x86.Deploy.0 = Debug|x86
+ {8D06B06E-A7AF-46D4-9E03-37661920F89A}.Release|ARM.ActiveCfg = Release|ARM
+ {8D06B06E-A7AF-46D4-9E03-37661920F89A}.Release|ARM.Build.0 = Release|ARM
+ {8D06B06E-A7AF-46D4-9E03-37661920F89A}.Release|ARM.Deploy.0 = Release|ARM
+ {8D06B06E-A7AF-46D4-9E03-37661920F89A}.Release|ARM64.ActiveCfg = Release|x86
{8D06B06E-A7AF-46D4-9E03-37661920F89A}.Release|x64.ActiveCfg = Release|x64
{8D06B06E-A7AF-46D4-9E03-37661920F89A}.Release|x64.Build.0 = Release|x64
{8D06B06E-A7AF-46D4-9E03-37661920F89A}.Release|x64.Deploy.0 = Release|x64
+ {8D06B06E-A7AF-46D4-9E03-37661920F89A}.Release|x86.ActiveCfg = Release|x86
+ {8D06B06E-A7AF-46D4-9E03-37661920F89A}.Release|x86.Build.0 = Release|x86
+ {8D06B06E-A7AF-46D4-9E03-37661920F89A}.Release|x86.Deploy.0 = Release|x86
+ {815DC811-1B36-4B60-AE29-1F5F25FB41DC}.Debug|ARM.ActiveCfg = Debug|ARM
+ {815DC811-1B36-4B60-AE29-1F5F25FB41DC}.Debug|ARM.Build.0 = Debug|ARM
+ {815DC811-1B36-4B60-AE29-1F5F25FB41DC}.Debug|ARM.Deploy.0 = Debug|ARM
+ {815DC811-1B36-4B60-AE29-1F5F25FB41DC}.Debug|ARM64.ActiveCfg = Debug|x86
{815DC811-1B36-4B60-AE29-1F5F25FB41DC}.Debug|x64.ActiveCfg = Debug|x64
{815DC811-1B36-4B60-AE29-1F5F25FB41DC}.Debug|x64.Build.0 = Debug|x64
{815DC811-1B36-4B60-AE29-1F5F25FB41DC}.Debug|x64.Deploy.0 = Debug|x64
+ {815DC811-1B36-4B60-AE29-1F5F25FB41DC}.Debug|x86.ActiveCfg = Debug|x86
+ {815DC811-1B36-4B60-AE29-1F5F25FB41DC}.Debug|x86.Build.0 = Debug|x86
+ {815DC811-1B36-4B60-AE29-1F5F25FB41DC}.Debug|x86.Deploy.0 = Debug|x86
+ {815DC811-1B36-4B60-AE29-1F5F25FB41DC}.Release|ARM.ActiveCfg = Release|ARM
+ {815DC811-1B36-4B60-AE29-1F5F25FB41DC}.Release|ARM.Build.0 = Release|ARM
+ {815DC811-1B36-4B60-AE29-1F5F25FB41DC}.Release|ARM.Deploy.0 = Release|ARM
+ {815DC811-1B36-4B60-AE29-1F5F25FB41DC}.Release|ARM64.ActiveCfg = Release|x86
{815DC811-1B36-4B60-AE29-1F5F25FB41DC}.Release|x64.ActiveCfg = Release|x64
{815DC811-1B36-4B60-AE29-1F5F25FB41DC}.Release|x64.Build.0 = Release|x64
{815DC811-1B36-4B60-AE29-1F5F25FB41DC}.Release|x64.Deploy.0 = Release|x64
+ {815DC811-1B36-4B60-AE29-1F5F25FB41DC}.Release|x86.ActiveCfg = Release|x86
+ {815DC811-1B36-4B60-AE29-1F5F25FB41DC}.Release|x86.Build.0 = Release|x86
+ {815DC811-1B36-4B60-AE29-1F5F25FB41DC}.Release|x86.Deploy.0 = Release|x86
+ {5234ACC2-814B-4232-8647-7142E74B9295}.Debug|ARM.ActiveCfg = Debug|ARM
+ {5234ACC2-814B-4232-8647-7142E74B9295}.Debug|ARM.Build.0 = Debug|ARM
+ {5234ACC2-814B-4232-8647-7142E74B9295}.Debug|ARM64.ActiveCfg = Debug|Any CPU
+ {5234ACC2-814B-4232-8647-7142E74B9295}.Debug|ARM64.Build.0 = Debug|Any CPU
{5234ACC2-814B-4232-8647-7142E74B9295}.Debug|x64.ActiveCfg = Debug|x64
{5234ACC2-814B-4232-8647-7142E74B9295}.Debug|x64.Build.0 = Debug|x64
+ {5234ACC2-814B-4232-8647-7142E74B9295}.Debug|x86.ActiveCfg = Debug|x86
+ {5234ACC2-814B-4232-8647-7142E74B9295}.Debug|x86.Build.0 = Debug|x86
+ {5234ACC2-814B-4232-8647-7142E74B9295}.Release|ARM.ActiveCfg = Release|ARM
+ {5234ACC2-814B-4232-8647-7142E74B9295}.Release|ARM.Build.0 = Release|ARM
+ {5234ACC2-814B-4232-8647-7142E74B9295}.Release|ARM64.ActiveCfg = Release|Any CPU
+ {5234ACC2-814B-4232-8647-7142E74B9295}.Release|ARM64.Build.0 = Release|Any CPU
{5234ACC2-814B-4232-8647-7142E74B9295}.Release|x64.ActiveCfg = Release|x64
{5234ACC2-814B-4232-8647-7142E74B9295}.Release|x64.Build.0 = Release|x64
+ {5234ACC2-814B-4232-8647-7142E74B9295}.Release|x86.ActiveCfg = Release|x86
+ {5234ACC2-814B-4232-8647-7142E74B9295}.Release|x86.Build.0 = Release|x86
+ {AA96C0A0-0202-43C1-BD35-4F70D23BE8ED}.Debug|ARM.ActiveCfg = Debug|ARM
+ {AA96C0A0-0202-43C1-BD35-4F70D23BE8ED}.Debug|ARM.Build.0 = Debug|ARM
+ {AA96C0A0-0202-43C1-BD35-4F70D23BE8ED}.Debug|ARM.Deploy.0 = Debug|ARM
+ {AA96C0A0-0202-43C1-BD35-4F70D23BE8ED}.Debug|ARM64.ActiveCfg = Debug|x86
{AA96C0A0-0202-43C1-BD35-4F70D23BE8ED}.Debug|x64.ActiveCfg = Debug|x64
{AA96C0A0-0202-43C1-BD35-4F70D23BE8ED}.Debug|x64.Build.0 = Debug|x64
{AA96C0A0-0202-43C1-BD35-4F70D23BE8ED}.Debug|x64.Deploy.0 = Debug|x64
+ {AA96C0A0-0202-43C1-BD35-4F70D23BE8ED}.Debug|x86.ActiveCfg = Debug|x86
+ {AA96C0A0-0202-43C1-BD35-4F70D23BE8ED}.Debug|x86.Build.0 = Debug|x86
+ {AA96C0A0-0202-43C1-BD35-4F70D23BE8ED}.Debug|x86.Deploy.0 = Debug|x86
+ {AA96C0A0-0202-43C1-BD35-4F70D23BE8ED}.Release|ARM.ActiveCfg = Release|ARM
+ {AA96C0A0-0202-43C1-BD35-4F70D23BE8ED}.Release|ARM.Build.0 = Release|ARM
+ {AA96C0A0-0202-43C1-BD35-4F70D23BE8ED}.Release|ARM.Deploy.0 = Release|ARM
+ {AA96C0A0-0202-43C1-BD35-4F70D23BE8ED}.Release|ARM64.ActiveCfg = Release|x86
{AA96C0A0-0202-43C1-BD35-4F70D23BE8ED}.Release|x64.ActiveCfg = Release|x64
{AA96C0A0-0202-43C1-BD35-4F70D23BE8ED}.Release|x64.Build.0 = Release|x64
{AA96C0A0-0202-43C1-BD35-4F70D23BE8ED}.Release|x64.Deploy.0 = Release|x64
+ {AA96C0A0-0202-43C1-BD35-4F70D23BE8ED}.Release|x86.ActiveCfg = Release|x86
+ {AA96C0A0-0202-43C1-BD35-4F70D23BE8ED}.Release|x86.Build.0 = Release|x86
+ {AA96C0A0-0202-43C1-BD35-4F70D23BE8ED}.Release|x86.Deploy.0 = Release|x86
+ {7C684468-F4C8-453E-8A8D-E107B2088908}.Debug|ARM.ActiveCfg = Debug|ARM
+ {7C684468-F4C8-453E-8A8D-E107B2088908}.Debug|ARM.Build.0 = Debug|ARM
+ {7C684468-F4C8-453E-8A8D-E107B2088908}.Debug|ARM.Deploy.0 = Debug|ARM
+ {7C684468-F4C8-453E-8A8D-E107B2088908}.Debug|ARM64.ActiveCfg = Debug|x86
{7C684468-F4C8-453E-8A8D-E107B2088908}.Debug|x64.ActiveCfg = Debug|x64
{7C684468-F4C8-453E-8A8D-E107B2088908}.Debug|x64.Build.0 = Debug|x64
{7C684468-F4C8-453E-8A8D-E107B2088908}.Debug|x64.Deploy.0 = Debug|x64
+ {7C684468-F4C8-453E-8A8D-E107B2088908}.Debug|x86.ActiveCfg = Debug|x86
+ {7C684468-F4C8-453E-8A8D-E107B2088908}.Debug|x86.Build.0 = Debug|x86
+ {7C684468-F4C8-453E-8A8D-E107B2088908}.Debug|x86.Deploy.0 = Debug|x86
+ {7C684468-F4C8-453E-8A8D-E107B2088908}.Release|ARM.ActiveCfg = Release|ARM
+ {7C684468-F4C8-453E-8A8D-E107B2088908}.Release|ARM.Build.0 = Release|ARM
+ {7C684468-F4C8-453E-8A8D-E107B2088908}.Release|ARM.Deploy.0 = Release|ARM
+ {7C684468-F4C8-453E-8A8D-E107B2088908}.Release|ARM64.ActiveCfg = Release|x86
{7C684468-F4C8-453E-8A8D-E107B2088908}.Release|x64.ActiveCfg = Release|x64
{7C684468-F4C8-453E-8A8D-E107B2088908}.Release|x64.Build.0 = Release|x64
{7C684468-F4C8-453E-8A8D-E107B2088908}.Release|x64.Deploy.0 = Release|x64
+ {7C684468-F4C8-453E-8A8D-E107B2088908}.Release|x86.ActiveCfg = Release|x86
+ {7C684468-F4C8-453E-8A8D-E107B2088908}.Release|x86.Build.0 = Release|x86
+ {7C684468-F4C8-453E-8A8D-E107B2088908}.Release|x86.Deploy.0 = Release|x86
+ {D2E1C5D4-BD90-4652-84C7-4B43B5A8D945}.Debug|ARM.ActiveCfg = Debug|ARM
+ {D2E1C5D4-BD90-4652-84C7-4B43B5A8D945}.Debug|ARM.Build.0 = Debug|ARM
+ {D2E1C5D4-BD90-4652-84C7-4B43B5A8D945}.Debug|ARM.Deploy.0 = Debug|ARM
+ {D2E1C5D4-BD90-4652-84C7-4B43B5A8D945}.Debug|ARM64.ActiveCfg = Debug|x86
{D2E1C5D4-BD90-4652-84C7-4B43B5A8D945}.Debug|x64.ActiveCfg = Debug|x64
{D2E1C5D4-BD90-4652-84C7-4B43B5A8D945}.Debug|x64.Build.0 = Debug|x64
{D2E1C5D4-BD90-4652-84C7-4B43B5A8D945}.Debug|x64.Deploy.0 = Debug|x64
+ {D2E1C5D4-BD90-4652-84C7-4B43B5A8D945}.Debug|x86.ActiveCfg = Debug|x86
+ {D2E1C5D4-BD90-4652-84C7-4B43B5A8D945}.Debug|x86.Build.0 = Debug|x86
+ {D2E1C5D4-BD90-4652-84C7-4B43B5A8D945}.Debug|x86.Deploy.0 = Debug|x86
+ {D2E1C5D4-BD90-4652-84C7-4B43B5A8D945}.Release|ARM.ActiveCfg = Release|ARM
+ {D2E1C5D4-BD90-4652-84C7-4B43B5A8D945}.Release|ARM.Build.0 = Release|ARM
+ {D2E1C5D4-BD90-4652-84C7-4B43B5A8D945}.Release|ARM.Deploy.0 = Release|ARM
+ {D2E1C5D4-BD90-4652-84C7-4B43B5A8D945}.Release|ARM64.ActiveCfg = Release|x86
{D2E1C5D4-BD90-4652-84C7-4B43B5A8D945}.Release|x64.ActiveCfg = Release|x64
{D2E1C5D4-BD90-4652-84C7-4B43B5A8D945}.Release|x64.Build.0 = Release|x64
{D2E1C5D4-BD90-4652-84C7-4B43B5A8D945}.Release|x64.Deploy.0 = Release|x64
+ {D2E1C5D4-BD90-4652-84C7-4B43B5A8D945}.Release|x86.ActiveCfg = Release|x86
+ {D2E1C5D4-BD90-4652-84C7-4B43B5A8D945}.Release|x86.Build.0 = Release|x86
+ {D2E1C5D4-BD90-4652-84C7-4B43B5A8D945}.Release|x86.Deploy.0 = Release|x86
+ {33F8C226-B2F5-449B-8389-81BEA753ED0C}.Debug|ARM.ActiveCfg = Debug|ARM
+ {33F8C226-B2F5-449B-8389-81BEA753ED0C}.Debug|ARM.Build.0 = Debug|ARM
+ {33F8C226-B2F5-449B-8389-81BEA753ED0C}.Debug|ARM.Deploy.0 = Debug|ARM
+ {33F8C226-B2F5-449B-8389-81BEA753ED0C}.Debug|ARM64.ActiveCfg = Debug|x86
{33F8C226-B2F5-449B-8389-81BEA753ED0C}.Debug|x64.ActiveCfg = Debug|x64
{33F8C226-B2F5-449B-8389-81BEA753ED0C}.Debug|x64.Build.0 = Debug|x64
{33F8C226-B2F5-449B-8389-81BEA753ED0C}.Debug|x64.Deploy.0 = Debug|x64
+ {33F8C226-B2F5-449B-8389-81BEA753ED0C}.Debug|x86.ActiveCfg = Debug|x86
+ {33F8C226-B2F5-449B-8389-81BEA753ED0C}.Debug|x86.Build.0 = Debug|x86
+ {33F8C226-B2F5-449B-8389-81BEA753ED0C}.Debug|x86.Deploy.0 = Debug|x86
+ {33F8C226-B2F5-449B-8389-81BEA753ED0C}.Release|ARM.ActiveCfg = Release|ARM
+ {33F8C226-B2F5-449B-8389-81BEA753ED0C}.Release|ARM.Build.0 = Release|ARM
+ {33F8C226-B2F5-449B-8389-81BEA753ED0C}.Release|ARM.Deploy.0 = Release|ARM
+ {33F8C226-B2F5-449B-8389-81BEA753ED0C}.Release|ARM64.ActiveCfg = Release|x86
{33F8C226-B2F5-449B-8389-81BEA753ED0C}.Release|x64.ActiveCfg = Release|x64
{33F8C226-B2F5-449B-8389-81BEA753ED0C}.Release|x64.Build.0 = Release|x64
{33F8C226-B2F5-449B-8389-81BEA753ED0C}.Release|x64.Deploy.0 = Release|x64
+ {33F8C226-B2F5-449B-8389-81BEA753ED0C}.Release|x86.ActiveCfg = Release|x86
+ {33F8C226-B2F5-449B-8389-81BEA753ED0C}.Release|x86.Build.0 = Release|x86
+ {33F8C226-B2F5-449B-8389-81BEA753ED0C}.Release|x86.Deploy.0 = Release|x86
+ {0A83E4C8-2660-4004-BA8D-D4BB7C7EB290}.Debug|ARM.ActiveCfg = Debug|ARM
+ {0A83E4C8-2660-4004-BA8D-D4BB7C7EB290}.Debug|ARM.Build.0 = Debug|ARM
+ {0A83E4C8-2660-4004-BA8D-D4BB7C7EB290}.Debug|ARM.Deploy.0 = Debug|ARM
+ {0A83E4C8-2660-4004-BA8D-D4BB7C7EB290}.Debug|ARM64.ActiveCfg = Debug|x86
{0A83E4C8-2660-4004-BA8D-D4BB7C7EB290}.Debug|x64.ActiveCfg = Debug|x64
{0A83E4C8-2660-4004-BA8D-D4BB7C7EB290}.Debug|x64.Build.0 = Debug|x64
{0A83E4C8-2660-4004-BA8D-D4BB7C7EB290}.Debug|x64.Deploy.0 = Debug|x64
+ {0A83E4C8-2660-4004-BA8D-D4BB7C7EB290}.Debug|x86.ActiveCfg = Debug|x86
+ {0A83E4C8-2660-4004-BA8D-D4BB7C7EB290}.Debug|x86.Build.0 = Debug|x86
+ {0A83E4C8-2660-4004-BA8D-D4BB7C7EB290}.Debug|x86.Deploy.0 = Debug|x86
+ {0A83E4C8-2660-4004-BA8D-D4BB7C7EB290}.Release|ARM.ActiveCfg = Release|ARM
+ {0A83E4C8-2660-4004-BA8D-D4BB7C7EB290}.Release|ARM.Build.0 = Release|ARM
+ {0A83E4C8-2660-4004-BA8D-D4BB7C7EB290}.Release|ARM.Deploy.0 = Release|ARM
+ {0A83E4C8-2660-4004-BA8D-D4BB7C7EB290}.Release|ARM64.ActiveCfg = Release|x86
{0A83E4C8-2660-4004-BA8D-D4BB7C7EB290}.Release|x64.ActiveCfg = Release|x64
{0A83E4C8-2660-4004-BA8D-D4BB7C7EB290}.Release|x64.Build.0 = Release|x64
{0A83E4C8-2660-4004-BA8D-D4BB7C7EB290}.Release|x64.Deploy.0 = Release|x64
+ {0A83E4C8-2660-4004-BA8D-D4BB7C7EB290}.Release|x86.ActiveCfg = Release|x86
+ {0A83E4C8-2660-4004-BA8D-D4BB7C7EB290}.Release|x86.Build.0 = Release|x86
+ {0A83E4C8-2660-4004-BA8D-D4BB7C7EB290}.Release|x86.Deploy.0 = Release|x86
+ {D3B787FF-5522-447F-AC1E-0774DD264D04}.Debug|ARM.ActiveCfg = Debug|ARM
+ {D3B787FF-5522-447F-AC1E-0774DD264D04}.Debug|ARM.Build.0 = Debug|ARM
+ {D3B787FF-5522-447F-AC1E-0774DD264D04}.Debug|ARM.Deploy.0 = Debug|ARM
+ {D3B787FF-5522-447F-AC1E-0774DD264D04}.Debug|ARM64.ActiveCfg = Debug|x86
{D3B787FF-5522-447F-AC1E-0774DD264D04}.Debug|x64.ActiveCfg = Debug|x64
{D3B787FF-5522-447F-AC1E-0774DD264D04}.Debug|x64.Build.0 = Debug|x64
{D3B787FF-5522-447F-AC1E-0774DD264D04}.Debug|x64.Deploy.0 = Debug|x64
+ {D3B787FF-5522-447F-AC1E-0774DD264D04}.Debug|x86.ActiveCfg = Debug|x86
+ {D3B787FF-5522-447F-AC1E-0774DD264D04}.Debug|x86.Build.0 = Debug|x86
+ {D3B787FF-5522-447F-AC1E-0774DD264D04}.Debug|x86.Deploy.0 = Debug|x86
+ {D3B787FF-5522-447F-AC1E-0774DD264D04}.Release|ARM.ActiveCfg = Release|ARM
+ {D3B787FF-5522-447F-AC1E-0774DD264D04}.Release|ARM.Build.0 = Release|ARM
+ {D3B787FF-5522-447F-AC1E-0774DD264D04}.Release|ARM.Deploy.0 = Release|ARM
+ {D3B787FF-5522-447F-AC1E-0774DD264D04}.Release|ARM64.ActiveCfg = Release|x86
{D3B787FF-5522-447F-AC1E-0774DD264D04}.Release|x64.ActiveCfg = Release|x64
{D3B787FF-5522-447F-AC1E-0774DD264D04}.Release|x64.Build.0 = Release|x64
{D3B787FF-5522-447F-AC1E-0774DD264D04}.Release|x64.Deploy.0 = Release|x64
+ {D3B787FF-5522-447F-AC1E-0774DD264D04}.Release|x86.ActiveCfg = Release|x86
+ {D3B787FF-5522-447F-AC1E-0774DD264D04}.Release|x86.Build.0 = Release|x86
+ {D3B787FF-5522-447F-AC1E-0774DD264D04}.Release|x86.Deploy.0 = Release|x86
+ {05D9AB57-A57F-4488-A603-C9B76F6932C5}.Debug|ARM.ActiveCfg = Debug|ARM
+ {05D9AB57-A57F-4488-A603-C9B76F6932C5}.Debug|ARM.Build.0 = Debug|ARM
+ {05D9AB57-A57F-4488-A603-C9B76F6932C5}.Debug|ARM.Deploy.0 = Debug|ARM
+ {05D9AB57-A57F-4488-A603-C9B76F6932C5}.Debug|ARM64.ActiveCfg = Debug|x86
{05D9AB57-A57F-4488-A603-C9B76F6932C5}.Debug|x64.ActiveCfg = Debug|x64
{05D9AB57-A57F-4488-A603-C9B76F6932C5}.Debug|x64.Build.0 = Debug|x64
{05D9AB57-A57F-4488-A603-C9B76F6932C5}.Debug|x64.Deploy.0 = Debug|x64
+ {05D9AB57-A57F-4488-A603-C9B76F6932C5}.Debug|x86.ActiveCfg = Debug|x86
+ {05D9AB57-A57F-4488-A603-C9B76F6932C5}.Debug|x86.Build.0 = Debug|x86
+ {05D9AB57-A57F-4488-A603-C9B76F6932C5}.Debug|x86.Deploy.0 = Debug|x86
+ {05D9AB57-A57F-4488-A603-C9B76F6932C5}.Release|ARM.ActiveCfg = Release|ARM
+ {05D9AB57-A57F-4488-A603-C9B76F6932C5}.Release|ARM.Build.0 = Release|ARM
+ {05D9AB57-A57F-4488-A603-C9B76F6932C5}.Release|ARM.Deploy.0 = Release|ARM
+ {05D9AB57-A57F-4488-A603-C9B76F6932C5}.Release|ARM64.ActiveCfg = Release|x86
{05D9AB57-A57F-4488-A603-C9B76F6932C5}.Release|x64.ActiveCfg = Release|x64
{05D9AB57-A57F-4488-A603-C9B76F6932C5}.Release|x64.Build.0 = Release|x64
{05D9AB57-A57F-4488-A603-C9B76F6932C5}.Release|x64.Deploy.0 = Release|x64
+ {05D9AB57-A57F-4488-A603-C9B76F6932C5}.Release|x86.ActiveCfg = Release|x86
+ {05D9AB57-A57F-4488-A603-C9B76F6932C5}.Release|x86.Build.0 = Release|x86
+ {05D9AB57-A57F-4488-A603-C9B76F6932C5}.Release|x86.Deploy.0 = Release|x86
+ {1CC1DD79-F392-47EC-94E6-26F32B28B65B}.Debug|ARM.ActiveCfg = Debug|ARM
+ {1CC1DD79-F392-47EC-94E6-26F32B28B65B}.Debug|ARM.Build.0 = Debug|ARM
+ {1CC1DD79-F392-47EC-94E6-26F32B28B65B}.Debug|ARM.Deploy.0 = Debug|ARM
+ {1CC1DD79-F392-47EC-94E6-26F32B28B65B}.Debug|ARM64.ActiveCfg = Debug|ARM64
+ {1CC1DD79-F392-47EC-94E6-26F32B28B65B}.Debug|ARM64.Build.0 = Debug|ARM64
+ {1CC1DD79-F392-47EC-94E6-26F32B28B65B}.Debug|ARM64.Deploy.0 = Debug|ARM64
+ {1CC1DD79-F392-47EC-94E6-26F32B28B65B}.Debug|x64.ActiveCfg = Debug|x64
+ {1CC1DD79-F392-47EC-94E6-26F32B28B65B}.Debug|x64.Build.0 = Debug|x64
+ {1CC1DD79-F392-47EC-94E6-26F32B28B65B}.Debug|x64.Deploy.0 = Debug|x64
+ {1CC1DD79-F392-47EC-94E6-26F32B28B65B}.Debug|x86.ActiveCfg = Debug|x86
+ {1CC1DD79-F392-47EC-94E6-26F32B28B65B}.Debug|x86.Build.0 = Debug|x86
+ {1CC1DD79-F392-47EC-94E6-26F32B28B65B}.Debug|x86.Deploy.0 = Debug|x86
+ {1CC1DD79-F392-47EC-94E6-26F32B28B65B}.Release|ARM.ActiveCfg = Release|ARM
+ {1CC1DD79-F392-47EC-94E6-26F32B28B65B}.Release|ARM.Build.0 = Release|ARM
+ {1CC1DD79-F392-47EC-94E6-26F32B28B65B}.Release|ARM.Deploy.0 = Release|ARM
+ {1CC1DD79-F392-47EC-94E6-26F32B28B65B}.Release|ARM64.ActiveCfg = Release|ARM64
+ {1CC1DD79-F392-47EC-94E6-26F32B28B65B}.Release|ARM64.Build.0 = Release|ARM64
+ {1CC1DD79-F392-47EC-94E6-26F32B28B65B}.Release|ARM64.Deploy.0 = Release|ARM64
+ {1CC1DD79-F392-47EC-94E6-26F32B28B65B}.Release|x64.ActiveCfg = Release|x64
+ {1CC1DD79-F392-47EC-94E6-26F32B28B65B}.Release|x64.Build.0 = Release|x64
+ {1CC1DD79-F392-47EC-94E6-26F32B28B65B}.Release|x64.Deploy.0 = Release|x64
+ {1CC1DD79-F392-47EC-94E6-26F32B28B65B}.Release|x86.ActiveCfg = Release|x86
+ {1CC1DD79-F392-47EC-94E6-26F32B28B65B}.Release|x86.Build.0 = Release|x86
+ {1CC1DD79-F392-47EC-94E6-26F32B28B65B}.Release|x86.Deploy.0 = Release|x86
EndGlobalSection
GlobalSection(SolutionProperties) = preSolution
HideSolutionNode = FALSE
@@ -134,6 +346,7 @@ Global
{0A83E4C8-2660-4004-BA8D-D4BB7C7EB290} = {6111DFA8-1B3F-447F-BF12-50569369933F}
{D3B787FF-5522-447F-AC1E-0774DD264D04} = {63D34804-3752-4A32-B282-239553D08276}
{05D9AB57-A57F-4488-A603-C9B76F6932C5} = {6111DFA8-1B3F-447F-BF12-50569369933F}
+ {1CC1DD79-F392-47EC-94E6-26F32B28B65B} = {B15AA40C-BB1A-4718-9F6E-4E20008C1D9A}
EndGlobalSection
GlobalSection(ExtensibilityGlobals) = postSolution
SolutionGuid = {BFE963A0-B319-42F1-8A82-A2C425F87FE9}