diff --git a/phoneClients/windowsPhone/GPSTracker.sln b/phoneClients/windowsPhone/GPSTracker.sln new file mode 100644 index 0000000..8b3ac04 --- /dev/null +++ b/phoneClients/windowsPhone/GPSTracker.sln @@ -0,0 +1,38 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Express 2012 for Windows Phone +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "GPSTracker", "GPSTracker\GPSTracker.csproj", "{DA68943F-9ABF-407C-8692-E3475337BBA7}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Debug|ARM = Debug|ARM + Debug|x86 = Debug|x86 + Release|Any CPU = Release|Any CPU + Release|ARM = Release|ARM + Release|x86 = Release|x86 + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {DA68943F-9ABF-407C-8692-E3475337BBA7}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {DA68943F-9ABF-407C-8692-E3475337BBA7}.Debug|Any CPU.Build.0 = Debug|Any CPU + {DA68943F-9ABF-407C-8692-E3475337BBA7}.Debug|Any CPU.Deploy.0 = Debug|Any CPU + {DA68943F-9ABF-407C-8692-E3475337BBA7}.Debug|ARM.ActiveCfg = Debug|ARM + {DA68943F-9ABF-407C-8692-E3475337BBA7}.Debug|ARM.Build.0 = Debug|ARM + {DA68943F-9ABF-407C-8692-E3475337BBA7}.Debug|ARM.Deploy.0 = Debug|ARM + {DA68943F-9ABF-407C-8692-E3475337BBA7}.Debug|x86.ActiveCfg = Debug|x86 + {DA68943F-9ABF-407C-8692-E3475337BBA7}.Debug|x86.Build.0 = Debug|x86 + {DA68943F-9ABF-407C-8692-E3475337BBA7}.Debug|x86.Deploy.0 = Debug|x86 + {DA68943F-9ABF-407C-8692-E3475337BBA7}.Release|Any CPU.ActiveCfg = Release|Any CPU + {DA68943F-9ABF-407C-8692-E3475337BBA7}.Release|Any CPU.Build.0 = Release|Any CPU + {DA68943F-9ABF-407C-8692-E3475337BBA7}.Release|Any CPU.Deploy.0 = Release|Any CPU + {DA68943F-9ABF-407C-8692-E3475337BBA7}.Release|ARM.ActiveCfg = Release|ARM + {DA68943F-9ABF-407C-8692-E3475337BBA7}.Release|ARM.Build.0 = Release|ARM + {DA68943F-9ABF-407C-8692-E3475337BBA7}.Release|ARM.Deploy.0 = Release|ARM + {DA68943F-9ABF-407C-8692-E3475337BBA7}.Release|x86.ActiveCfg = Release|x86 + {DA68943F-9ABF-407C-8692-E3475337BBA7}.Release|x86.Build.0 = Release|x86 + {DA68943F-9ABF-407C-8692-E3475337BBA7}.Release|x86.Deploy.0 = Release|x86 + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection +EndGlobal diff --git a/phoneClients/windowsPhone/GPSTracker/App.xaml b/phoneClients/windowsPhone/GPSTracker/App.xaml new file mode 100644 index 0000000..06732c8 --- /dev/null +++ b/phoneClients/windowsPhone/GPSTracker/App.xaml @@ -0,0 +1,21 @@ + + + + + + + + + + + + + \ No newline at end of file diff --git a/phoneClients/windowsPhone/GPSTracker/App.xaml.cs b/phoneClients/windowsPhone/GPSTracker/App.xaml.cs new file mode 100644 index 0000000..956ad7a --- /dev/null +++ b/phoneClients/windowsPhone/GPSTracker/App.xaml.cs @@ -0,0 +1,240 @@ +using System; +using System.Diagnostics; +using System.Resources; +using System.Windows; +using System.Windows.Markup; +using System.Windows.Navigation; +using Microsoft.Phone.Controls; +using Microsoft.Phone.Shell; +using GPSTracker.Resources; +using Windows.Devices.Geolocation; + +namespace GPSTracker +{ + public partial class App : Application + { + /// + /// Provides easy access to the root frame of the Phone Application. + /// + /// The root frame of the Phone Application. + public static PhoneApplicationFrame RootFrame { get; private set; } + + // Global Geolocator so that it doesn't go out of scope + public static Geolocator Geolocator { get; set; } + + // boolean to track whether we are currently running in the background + public static bool RunningInBackground { get; set; } + + /// + /// Constructor for the Application object. + /// + public App() + { + // Global handler for uncaught exceptions. + UnhandledException += Application_UnhandledException; + + // Standard XAML initialization + InitializeComponent(); + + // Phone-specific initialization + InitializePhoneApplication(); + + // Language display initialization + InitializeLanguage(); + + // Show graphics profiling information while debugging. + if (Debugger.IsAttached) + { + // Display the current frame rate counters. + Application.Current.Host.Settings.EnableFrameRateCounter = true; + + // Show the areas of the app that are being redrawn in each frame. + //Application.Current.Host.Settings.EnableRedrawRegions = true; + + // Enable non-production analysis visualization mode, + // which shows areas of a page that are handed off to GPU with a colored overlay. + //Application.Current.Host.Settings.EnableCacheVisualization = true; + + // Prevent the screen from turning off while under the debugger by disabling + // the application's idle detection. + // Caution:- Use this under debug mode only. Application that disables user idle detection will continue to run + // and consume battery power when the user is not using the phone. + PhoneApplicationService.Current.UserIdleDetectionMode = IdleDetectionMode.Disabled; + } + + } + + // Code to execute when the application is launching (eg, from Start) + // This code will not execute when the application is reactivated + private void Application_Launching(object sender, LaunchingEventArgs e) + { + } + + // Code to execute when the application is activated (brought to foreground) + // This code will not execute when the application is first launched + private void Application_Activated(object sender, ActivatedEventArgs e) + { + RunningInBackground = false; + } + + // Code to execute when the application is deactivated (sent to background) + // This code will not execute when the application is closing + private void Application_Deactivated(object sender, DeactivatedEventArgs e) + { + Debug.WriteLine(String.Format("{0:d/M/yy h:mm:ss tt} ", DateTime.Now + " deactivated reason: " + e.Reason)); + } + + // Code to execute when the application is closing (eg, user hit Back) + // This code will not execute when the application is deactivated + private void Application_Closing(object sender, ClosingEventArgs e) + { + Debug.WriteLine(String.Format("{0:d/M/yy h:mm:ss tt} ", DateTime.Now + " closing: " + e.ToString())); + } + + private void Application_RunningInBackground(object sender, RunningInBackgroundEventArgs args) + { + // Pages can check this value and know to suspend all unnecessary processing such as UI updates + RunningInBackground = true; + + } + + // Code to execute if a navigation fails + private void RootFrame_NavigationFailed(object sender, NavigationFailedEventArgs e) + { + if (Debugger.IsAttached) + { + // A navigation has failed; break into the debugger + Debugger.Break(); + } + } + + // Code to execute on Unhandled Exceptions + private void Application_UnhandledException(object sender, ApplicationUnhandledExceptionEventArgs e) + { + if (Debugger.IsAttached) + { + // An unhandled exception has occurred; break into the debugger + Debugger.Break(); + } + } + + #region Phone application initialization + + // Avoid double-initialization + private bool phoneApplicationInitialized = false; + + // Do not add any additional code to this method + private void InitializePhoneApplication() + { + if (phoneApplicationInitialized) + return; + + // Create the frame but don't set it as RootVisual yet; this allows the splash + // screen to remain active until the application is ready to render. + RootFrame = new PhoneApplicationFrame(); + RootFrame.Navigated += CompleteInitializePhoneApplication; + + // Handle navigation failures + RootFrame.NavigationFailed += RootFrame_NavigationFailed; + + // Handle reset requests for clearing the backstack + RootFrame.Navigated += CheckForResetNavigation; + + // Ensure we don't initialize again + phoneApplicationInitialized = true; + } + + // Do not add any additional code to this method + private void CompleteInitializePhoneApplication(object sender, NavigationEventArgs e) + { + // Set the root visual to allow the application to render + if (RootVisual != RootFrame) + RootVisual = RootFrame; + + // Remove this handler since it is no longer needed + RootFrame.Navigated -= CompleteInitializePhoneApplication; + } + + private void CheckForResetNavigation(object sender, NavigationEventArgs e) + { + // If the app has received a 'reset' navigation, then we need to check + // on the next navigation to see if the page stack should be reset + if (e.NavigationMode == NavigationMode.Reset) + RootFrame.Navigated += ClearBackStackAfterReset; + } + + private void ClearBackStackAfterReset(object sender, NavigationEventArgs e) + { + // Unregister the event so it doesn't get called again + RootFrame.Navigated -= ClearBackStackAfterReset; + + // Only clear the stack for 'new' (forward) and 'refresh' navigations + if (e.NavigationMode != NavigationMode.New && e.NavigationMode != NavigationMode.Refresh) + return; + + // For UI consistency, clear the entire page stack + while (RootFrame.RemoveBackEntry() != null) + { + ; // do nothing + } + } + + #endregion + + // Initialize the app's font and flow direction as defined in its localized resource strings. + // + // To ensure that the font of your application is aligned with its supported languages and that the + // FlowDirection for each of those languages follows its traditional direction, ResourceLanguage + // and ResourceFlowDirection should be initialized in each resx file to match these values with that + // file's culture. For example: + // + // AppResources.es-ES.resx + // ResourceLanguage's value should be "es-ES" + // ResourceFlowDirection's value should be "LeftToRight" + // + // AppResources.ar-SA.resx + // ResourceLanguage's value should be "ar-SA" + // ResourceFlowDirection's value should be "RightToLeft" + // + // For more info on localizing Windows Phone apps see http://go.microsoft.com/fwlink/?LinkId=262072. + // + private void InitializeLanguage() + { + try + { + // Set the font to match the display language defined by the + // ResourceLanguage resource string for each supported language. + // + // Fall back to the font of the neutral language if the Display + // language of the phone is not supported. + // + // If a compiler error is hit then ResourceLanguage is missing from + // the resource file. + RootFrame.Language = XmlLanguage.GetLanguage(AppResources.ResourceLanguage); + + // Set the FlowDirection of all elements under the root frame based + // on the ResourceFlowDirection resource string for each + // supported language. + // + // If a compiler error is hit then ResourceFlowDirection is missing from + // the resource file. + FlowDirection flow = (FlowDirection)Enum.Parse(typeof(FlowDirection), AppResources.ResourceFlowDirection); + RootFrame.FlowDirection = flow; + } + catch + { + // If an exception is caught here it is most likely due to either + // ResourceLangauge not being correctly set to a supported language + // code or ResourceFlowDirection is set to a value other than LeftToRight + // or RightToLeft. + + if (Debugger.IsAttached) + { + Debugger.Break(); + } + + throw; + } + } + } +} \ No newline at end of file diff --git a/phoneClients/windowsPhone/GPSTracker/Assets/AlignmentGrid.png b/phoneClients/windowsPhone/GPSTracker/Assets/AlignmentGrid.png new file mode 100644 index 0000000..f7d2e97 --- /dev/null +++ b/phoneClients/windowsPhone/GPSTracker/Assets/AlignmentGrid.png Binary files differ diff --git a/phoneClients/windowsPhone/GPSTracker/Assets/ApplicationIcon.png b/phoneClients/windowsPhone/GPSTracker/Assets/ApplicationIcon.png new file mode 100644 index 0000000..7d95d4e --- /dev/null +++ b/phoneClients/windowsPhone/GPSTracker/Assets/ApplicationIcon.png Binary files differ diff --git a/phoneClients/windowsPhone/GPSTracker/Assets/Tiles/FlipCycleTileLarge.png b/phoneClients/windowsPhone/GPSTracker/Assets/Tiles/FlipCycleTileLarge.png new file mode 100644 index 0000000..e0c59ac --- /dev/null +++ b/phoneClients/windowsPhone/GPSTracker/Assets/Tiles/FlipCycleTileLarge.png Binary files differ diff --git a/phoneClients/windowsPhone/GPSTracker/Assets/Tiles/FlipCycleTileMedium.png b/phoneClients/windowsPhone/GPSTracker/Assets/Tiles/FlipCycleTileMedium.png new file mode 100644 index 0000000..e93b89d --- /dev/null +++ b/phoneClients/windowsPhone/GPSTracker/Assets/Tiles/FlipCycleTileMedium.png Binary files differ diff --git a/phoneClients/windowsPhone/GPSTracker/Assets/Tiles/FlipCycleTileSmall.png b/phoneClients/windowsPhone/GPSTracker/Assets/Tiles/FlipCycleTileSmall.png new file mode 100644 index 0000000..550b1b5 --- /dev/null +++ b/phoneClients/windowsPhone/GPSTracker/Assets/Tiles/FlipCycleTileSmall.png Binary files differ diff --git a/phoneClients/windowsPhone/GPSTracker/Assets/Tiles/IconicTileMediumLarge.png b/phoneClients/windowsPhone/GPSTracker/Assets/Tiles/IconicTileMediumLarge.png new file mode 100644 index 0000000..686e6b5 --- /dev/null +++ b/phoneClients/windowsPhone/GPSTracker/Assets/Tiles/IconicTileMediumLarge.png Binary files differ diff --git a/phoneClients/windowsPhone/GPSTracker/Assets/Tiles/IconicTileSmall.png b/phoneClients/windowsPhone/GPSTracker/Assets/Tiles/IconicTileSmall.png new file mode 100644 index 0000000..d4b5ede --- /dev/null +++ b/phoneClients/windowsPhone/GPSTracker/Assets/Tiles/IconicTileSmall.png Binary files differ diff --git a/phoneClients/windowsPhone/GPSTracker/GPSTracker.csproj b/phoneClients/windowsPhone/GPSTracker/GPSTracker.csproj new file mode 100644 index 0000000..4f62cc4 --- /dev/null +++ b/phoneClients/windowsPhone/GPSTracker/GPSTracker.csproj @@ -0,0 +1,177 @@ + + + + Debug + AnyCPU + 10.0.20506 + 2.0 + {DA68943F-9ABF-407C-8692-E3475337BBA7} + {C089C8C0-30E0-4E22-80C0-CE093F111A43};{fae04ec0-301f-11d3-bf4b-00c04f79efbc} + Library + Properties + GPSTracker + GPSTracker + WindowsPhone + v8.0 + $(TargetFrameworkVersion) + true + + + true + true + GPSTracker_$(Configuration)_$(Platform).xap + Properties\AppManifest.xml + GPSTracker.App + true + 11.0 + true + + + true + full + false + Bin\Debug + DEBUG;TRACE;SILVERLIGHT;WINDOWS_PHONE + true + true + prompt + 4 + + + pdbonly + true + Bin\Release + TRACE;SILVERLIGHT;WINDOWS_PHONE + true + true + prompt + 4 + + + true + full + false + Bin\x86\Debug + DEBUG;TRACE;SILVERLIGHT;WINDOWS_PHONE + true + true + prompt + 4 + + + pdbonly + true + Bin\x86\Release + TRACE;SILVERLIGHT;WINDOWS_PHONE + true + true + prompt + 4 + + + true + full + false + Bin\ARM\Debug + DEBUG;TRACE;SILVERLIGHT;WINDOWS_PHONE + true + true + prompt + 4 + + + pdbonly + true + Bin\ARM\Release + TRACE;SILVERLIGHT;WINDOWS_PHONE + true + true + prompt + 4 + + + + App.xaml + + + + MainPage.xaml + + + + True + True + AppResources.resx + + + + + Designer + MSBuild:Compile + + + Designer + MSBuild:Compile + + + + + + + Designer + + + + + + PreserveNewest + + + PreserveNewest + + + PreserveNewest + + + PreserveNewest + + + PreserveNewest + + + PreserveNewest + + + + + PublicResXFileCodeGenerator + AppResources.Designer.cs + + + + + ..\packages\Microsoft.Net.Http.2.2.18\lib\sl4-windowsphone71\System.Net.Http.dll + + + ..\packages\Microsoft.Net.Http.2.2.18\lib\sl4-windowsphone71\System.Net.Http.Extensions.dll + + + ..\packages\Microsoft.Net.Http.2.2.18\lib\sl4-windowsphone71\System.Net.Http.Primitives.dll + + + + + + + + + + + + \ No newline at end of file diff --git a/phoneClients/windowsPhone/GPSTracker/LocalizedStrings.cs b/phoneClients/windowsPhone/GPSTracker/LocalizedStrings.cs new file mode 100644 index 0000000..ce17d86 --- /dev/null +++ b/phoneClients/windowsPhone/GPSTracker/LocalizedStrings.cs @@ -0,0 +1,14 @@ +using GPSTracker.Resources; + +namespace GPSTracker +{ + /// + /// Provides access to string resources. + /// + public class LocalizedStrings + { + private static AppResources _localizedResources = new AppResources(); + + public AppResources LocalizedResources { get { return _localizedResources; } } + } +} \ No newline at end of file diff --git a/phoneClients/windowsPhone/GPSTracker/MainPage.xaml b/phoneClients/windowsPhone/GPSTracker/MainPage.xaml new file mode 100644 index 0000000..fdcf82a --- /dev/null +++ b/phoneClients/windowsPhone/GPSTracker/MainPage.xaml @@ -0,0 +1,89 @@ + + + + + + + + + + + + + + + + + + + + + + + + +