Permalink
Browse files

Created WP8 Sample and Client

- Created pure awesomeness at a WP8 level.
  • Loading branch information...
1 parent 11da5b7 commit f4077d1f453c8b7800e00463697ee35fcced4d9a @NTaylorMullen NTaylorMullen committed Nov 20, 2012
Showing with 1,173 additions and 0 deletions.
  1. +50 −0 Microsoft.AspNet.SignalR.WindowsPhone.sln
  2. BIN lib/Newtonsoft.Json.dll
  3. +19 −0 samples/Microsoft.AspNet.SignalR.Client.WP8.Sample/App.xaml
  4. +187 −0 samples/Microsoft.AspNet.SignalR.Client.WP8.Sample/App.xaml.cs
  5. BIN samples/Microsoft.AspNet.SignalR.Client.WP8.Sample/ApplicationIcon.png
  6. BIN samples/Microsoft.AspNet.SignalR.Client.WP8.Sample/Assets/AlignmentGrid.png
  7. BIN samples/Microsoft.AspNet.SignalR.Client.WP8.Sample/Assets/ApplicationIcon.png
  8. BIN samples/Microsoft.AspNet.SignalR.Client.WP8.Sample/Assets/Tiles/FlipCycleTileLarge.png
  9. BIN samples/Microsoft.AspNet.SignalR.Client.WP8.Sample/Assets/Tiles/FlipCycleTileMedium.png
  10. BIN samples/Microsoft.AspNet.SignalR.Client.WP8.Sample/Assets/Tiles/FlipCycleTileSmall.png
  11. BIN samples/Microsoft.AspNet.SignalR.Client.WP8.Sample/Assets/Tiles/IconicTileMediumLarge.png
  12. BIN samples/Microsoft.AspNet.SignalR.Client.WP8.Sample/Assets/Tiles/IconicTileSmall.png
  13. BIN samples/Microsoft.AspNet.SignalR.Client.WP8.Sample/Background.png
  14. +44 −0 samples/Microsoft.AspNet.SignalR.Client.WP8.Sample/DetailsPage.xaml
  15. +54 −0 samples/Microsoft.AspNet.SignalR.Client.WP8.Sample/DetailsPage.xaml.cs
  16. +45 −0 samples/Microsoft.AspNet.SignalR.Client.WP8.Sample/MainPage.xaml
  17. +84 −0 samples/Microsoft.AspNet.SignalR.Client.WP8.Sample/MainPage.xaml.cs
  18. +162 −0 samples/Microsoft.AspNet.SignalR.Client.WP8.Sample/Microsoft.AspNet.SignalR.Client.WP8.Sample.csproj
  19. +6 −0 samples/Microsoft.AspNet.SignalR.Client.WP8.Sample/Properties/AppManifest.xml
  20. +37 −0 samples/Microsoft.AspNet.SignalR.Client.WP8.Sample/Properties/AssemblyInfo.cs
  21. +38 −0 samples/Microsoft.AspNet.SignalR.Client.WP8.Sample/Properties/WMAppManifest.xml
  22. +16 −0 samples/Microsoft.AspNet.SignalR.Client.WP8.Sample/SampleData/MainViewModelSampleData.xaml
  23. BIN samples/Microsoft.AspNet.SignalR.Client.WP8.Sample/SplashScreenImage.jpg
  24. +109 −0 samples/Microsoft.AspNet.SignalR.Client.WP8.Sample/ViewModels/ItemViewModel.cs
  25. +56 −0 samples/Microsoft.AspNet.SignalR.Client.WP8.Sample/ViewModels/MainViewModel.cs
  26. +229 −0 src/Microsoft.AspNet.SignalR.Client.WP8/Microsoft.AspNet.SignalR.Client.WP8.csproj
  27. +37 −0 src/Microsoft.AspNet.SignalR.Client.WP8/Properties/AssemblyInfo.cs
@@ -11,40 +11,90 @@ Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Microsoft.AspNet.SignalR.Cl
EndProject
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Microsoft.AspNet.SignalR.Client.WP7.Sample", "samples\Microsoft.AspNet.SignalR.Client.WP7.Sample\Microsoft.AspNet.SignalR.Client.WP7.Sample.csproj", "{E059F6F3-E9D5-4113-AF2B-C2D19CE7FAFF}"
EndProject
+Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Microsoft.AspNet.SignalR.Client.WP8", "src\Microsoft.AspNet.SignalR.Client.WP8\Microsoft.AspNet.SignalR.Client.WP8.csproj", "{12D04172-2A5A-420D-A29B-026DB62C3B72}"
+EndProject
+Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Microsoft.AspNet.SignalR.Client.WP8.Sample", "samples\Microsoft.AspNet.SignalR.Client.WP8.Sample\Microsoft.AspNet.SignalR.Client.WP8.Sample.csproj", "{2117F295-6451-4447-A646-614B2D8352EF}"
+EndProject
Global
GlobalSection(SolutionConfigurationPlatforms) = preSolution
Debug|Any CPU = Debug|Any CPU
+ Debug|ARM = Debug|ARM
Debug|Mixed Platforms = Debug|Mixed Platforms
Debug|x86 = Debug|x86
Release|Any CPU = Release|Any CPU
+ Release|ARM = Release|ARM
Release|Mixed Platforms = Release|Mixed Platforms
Release|x86 = Release|x86
EndGlobalSection
GlobalSection(ProjectConfigurationPlatforms) = postSolution
{1B2BD09D-ECFF-427F-BA58-C59A01EE6A2C}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
{1B2BD09D-ECFF-427F-BA58-C59A01EE6A2C}.Debug|Any CPU.Build.0 = Debug|Any CPU
+ {1B2BD09D-ECFF-427F-BA58-C59A01EE6A2C}.Debug|ARM.ActiveCfg = Debug|Any CPU
{1B2BD09D-ECFF-427F-BA58-C59A01EE6A2C}.Debug|Mixed Platforms.ActiveCfg = Debug|Any CPU
{1B2BD09D-ECFF-427F-BA58-C59A01EE6A2C}.Debug|Mixed Platforms.Build.0 = Debug|Any CPU
{1B2BD09D-ECFF-427F-BA58-C59A01EE6A2C}.Debug|x86.ActiveCfg = Debug|Any CPU
{1B2BD09D-ECFF-427F-BA58-C59A01EE6A2C}.Release|Any CPU.ActiveCfg = Release|Any CPU
{1B2BD09D-ECFF-427F-BA58-C59A01EE6A2C}.Release|Any CPU.Build.0 = Release|Any CPU
+ {1B2BD09D-ECFF-427F-BA58-C59A01EE6A2C}.Release|ARM.ActiveCfg = Release|Any CPU
{1B2BD09D-ECFF-427F-BA58-C59A01EE6A2C}.Release|Mixed Platforms.ActiveCfg = Release|Any CPU
{1B2BD09D-ECFF-427F-BA58-C59A01EE6A2C}.Release|Mixed Platforms.Build.0 = Release|Any CPU
{1B2BD09D-ECFF-427F-BA58-C59A01EE6A2C}.Release|x86.ActiveCfg = Release|Any CPU
{E059F6F3-E9D5-4113-AF2B-C2D19CE7FAFF}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
{E059F6F3-E9D5-4113-AF2B-C2D19CE7FAFF}.Debug|Any CPU.Build.0 = Debug|Any CPU
{E059F6F3-E9D5-4113-AF2B-C2D19CE7FAFF}.Debug|Any CPU.Deploy.0 = Debug|Any CPU
+ {E059F6F3-E9D5-4113-AF2B-C2D19CE7FAFF}.Debug|ARM.ActiveCfg = Debug|Any CPU
{E059F6F3-E9D5-4113-AF2B-C2D19CE7FAFF}.Debug|Mixed Platforms.ActiveCfg = Debug|Any CPU
{E059F6F3-E9D5-4113-AF2B-C2D19CE7FAFF}.Debug|Mixed Platforms.Build.0 = Debug|Any CPU
{E059F6F3-E9D5-4113-AF2B-C2D19CE7FAFF}.Debug|Mixed Platforms.Deploy.0 = Debug|Any CPU
{E059F6F3-E9D5-4113-AF2B-C2D19CE7FAFF}.Debug|x86.ActiveCfg = Debug|Any CPU
{E059F6F3-E9D5-4113-AF2B-C2D19CE7FAFF}.Release|Any CPU.ActiveCfg = Release|Any CPU
{E059F6F3-E9D5-4113-AF2B-C2D19CE7FAFF}.Release|Any CPU.Build.0 = Release|Any CPU
{E059F6F3-E9D5-4113-AF2B-C2D19CE7FAFF}.Release|Any CPU.Deploy.0 = Release|Any CPU
+ {E059F6F3-E9D5-4113-AF2B-C2D19CE7FAFF}.Release|ARM.ActiveCfg = Release|Any CPU
{E059F6F3-E9D5-4113-AF2B-C2D19CE7FAFF}.Release|Mixed Platforms.ActiveCfg = Release|Any CPU
{E059F6F3-E9D5-4113-AF2B-C2D19CE7FAFF}.Release|Mixed Platforms.Build.0 = Release|Any CPU
{E059F6F3-E9D5-4113-AF2B-C2D19CE7FAFF}.Release|Mixed Platforms.Deploy.0 = Release|Any CPU
{E059F6F3-E9D5-4113-AF2B-C2D19CE7FAFF}.Release|x86.ActiveCfg = Release|Any CPU
+ {12D04172-2A5A-420D-A29B-026DB62C3B72}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
+ {12D04172-2A5A-420D-A29B-026DB62C3B72}.Debug|Any CPU.Build.0 = Debug|Any CPU
+ {12D04172-2A5A-420D-A29B-026DB62C3B72}.Debug|ARM.ActiveCfg = Debug|ARM
+ {12D04172-2A5A-420D-A29B-026DB62C3B72}.Debug|ARM.Build.0 = Debug|ARM
+ {12D04172-2A5A-420D-A29B-026DB62C3B72}.Debug|Mixed Platforms.ActiveCfg = Debug|x86
+ {12D04172-2A5A-420D-A29B-026DB62C3B72}.Debug|Mixed Platforms.Build.0 = Debug|x86
+ {12D04172-2A5A-420D-A29B-026DB62C3B72}.Debug|x86.ActiveCfg = Debug|x86
+ {12D04172-2A5A-420D-A29B-026DB62C3B72}.Debug|x86.Build.0 = Debug|x86
+ {12D04172-2A5A-420D-A29B-026DB62C3B72}.Release|Any CPU.ActiveCfg = Release|Any CPU
+ {12D04172-2A5A-420D-A29B-026DB62C3B72}.Release|Any CPU.Build.0 = Release|Any CPU
+ {12D04172-2A5A-420D-A29B-026DB62C3B72}.Release|ARM.ActiveCfg = Release|ARM
+ {12D04172-2A5A-420D-A29B-026DB62C3B72}.Release|ARM.Build.0 = Release|ARM
+ {12D04172-2A5A-420D-A29B-026DB62C3B72}.Release|Mixed Platforms.ActiveCfg = Release|x86
+ {12D04172-2A5A-420D-A29B-026DB62C3B72}.Release|Mixed Platforms.Build.0 = Release|x86
+ {12D04172-2A5A-420D-A29B-026DB62C3B72}.Release|x86.ActiveCfg = Release|x86
+ {12D04172-2A5A-420D-A29B-026DB62C3B72}.Release|x86.Build.0 = Release|x86
+ {2117F295-6451-4447-A646-614B2D8352EF}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
+ {2117F295-6451-4447-A646-614B2D8352EF}.Debug|Any CPU.Build.0 = Debug|Any CPU
+ {2117F295-6451-4447-A646-614B2D8352EF}.Debug|Any CPU.Deploy.0 = Debug|Any CPU
+ {2117F295-6451-4447-A646-614B2D8352EF}.Debug|ARM.ActiveCfg = Debug|ARM
+ {2117F295-6451-4447-A646-614B2D8352EF}.Debug|ARM.Build.0 = Debug|ARM
+ {2117F295-6451-4447-A646-614B2D8352EF}.Debug|ARM.Deploy.0 = Debug|ARM
+ {2117F295-6451-4447-A646-614B2D8352EF}.Debug|Mixed Platforms.ActiveCfg = Debug|x86
+ {2117F295-6451-4447-A646-614B2D8352EF}.Debug|Mixed Platforms.Build.0 = Debug|x86
+ {2117F295-6451-4447-A646-614B2D8352EF}.Debug|Mixed Platforms.Deploy.0 = Debug|x86
+ {2117F295-6451-4447-A646-614B2D8352EF}.Debug|x86.ActiveCfg = Debug|x86
+ {2117F295-6451-4447-A646-614B2D8352EF}.Debug|x86.Build.0 = Debug|x86
+ {2117F295-6451-4447-A646-614B2D8352EF}.Debug|x86.Deploy.0 = Debug|x86
+ {2117F295-6451-4447-A646-614B2D8352EF}.Release|Any CPU.ActiveCfg = Release|Any CPU
+ {2117F295-6451-4447-A646-614B2D8352EF}.Release|Any CPU.Build.0 = Release|Any CPU
+ {2117F295-6451-4447-A646-614B2D8352EF}.Release|Any CPU.Deploy.0 = Release|Any CPU
+ {2117F295-6451-4447-A646-614B2D8352EF}.Release|ARM.ActiveCfg = Release|ARM
+ {2117F295-6451-4447-A646-614B2D8352EF}.Release|ARM.Build.0 = Release|ARM
+ {2117F295-6451-4447-A646-614B2D8352EF}.Release|ARM.Deploy.0 = Release|ARM
+ {2117F295-6451-4447-A646-614B2D8352EF}.Release|Mixed Platforms.ActiveCfg = Release|x86
+ {2117F295-6451-4447-A646-614B2D8352EF}.Release|Mixed Platforms.Build.0 = Release|x86
+ {2117F295-6451-4447-A646-614B2D8352EF}.Release|Mixed Platforms.Deploy.0 = Release|x86
+ {2117F295-6451-4447-A646-614B2D8352EF}.Release|x86.ActiveCfg = Release|x86
+ {2117F295-6451-4447-A646-614B2D8352EF}.Release|x86.Build.0 = Release|x86
+ {2117F295-6451-4447-A646-614B2D8352EF}.Release|x86.Deploy.0 = Release|x86
EndGlobalSection
GlobalSection(SolutionProperties) = preSolution
HideSolutionNode = FALSE
Binary file not shown.
@@ -0,0 +1,19 @@
+<Application
+ x:Class="Microsoft.AspNet.SignalR.Client.WP8.Sample.App"
+ xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
+ xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
+ xmlns:phone="clr-namespace:Microsoft.Phone.Controls;assembly=Microsoft.Phone"
+ xmlns:shell="clr-namespace:Microsoft.Phone.Shell;assembly=Microsoft.Phone">
+
+ <!--Application Resources-->
+ <Application.Resources>
+ </Application.Resources>
+
+ <Application.ApplicationLifetimeObjects>
+ <!--Required object that handles lifetime events for the application-->
+ <shell:PhoneApplicationService
+ Launching="Application_Launching" Closing="Application_Closing"
+ Activated="Application_Activated" Deactivated="Application_Deactivated"/>
+ </Application.ApplicationLifetimeObjects>
+
+</Application>
@@ -0,0 +1,187 @@
+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 Microsoft.AspNet.SignalR.Client.WP8.Sample.ViewModels;
+
+namespace Microsoft.AspNet.SignalR.Client.WP8.Sample
+{
+ public partial class App : Application
+ {
+ private static MainViewModel viewModel = null;
+
+ /// <summary>
+ /// A static ViewModel used by the views to bind against.
+ /// </summary>
+ /// <returns>The MainViewModel object.</returns>
+ public static MainViewModel ViewModel
+ {
+ get
+ {
+ // Delay creation of the view model until necessary
+ if (viewModel == null)
+ viewModel = new MainViewModel();
+
+ return viewModel;
+ }
+ }
+
+ /// <summary>
+ /// Provides easy access to the root frame of the Phone Application.
+ /// </summary>
+ /// <returns>The root frame of the Phone Application.</returns>
+ public static PhoneApplicationFrame RootFrame { get; private set; }
+
+ /// <summary>
+ /// Constructor for the Application object.
+ /// </summary>
+ public App()
+ {
+ // Global handler for uncaught exceptions.
+ UnhandledException += Application_UnhandledException;
+
+ // Standard XAML initialization
+ InitializeComponent();
+
+ // Phone-specific initialization
+ InitializePhoneApplication();
+
+ // 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 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)
+ {
+ // Ensure that application state is restored appropriately
+ //if (!App.ViewModel.IsDataLoaded)
+ //{
+ // App.ViewModel.LoadData();
+ //}
+ }
+
+ // 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)
+ {
+ // Ensure that required application state is persisted here.
+ }
+
+ // 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)
+ {
+ }
+
+ // 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
+ }
+}
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
@@ -0,0 +1,44 @@
+<phone:PhoneApplicationPage
+ x:Class="Microsoft.AspNet.SignalR.Client.WP8.Sample.DetailsPage"
+ xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
+ xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
+ xmlns:phone="clr-namespace:Microsoft.Phone.Controls;assembly=Microsoft.Phone"
+ xmlns:shell="clr-namespace:Microsoft.Phone.Shell;assembly=Microsoft.Phone"
+ xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
+ xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
+ d:DataContext="{d:DesignData SampleData/MainViewModelSampleData.xaml}"
+ mc:Ignorable="d"
+ FontFamily="{StaticResource PhoneFontFamilyNormal}"
+ FontSize="{StaticResource PhoneFontSizeNormal}"
+ Foreground="{StaticResource PhoneForegroundBrush}"
+ SupportedOrientations="Portrait" Orientation="Portrait"
+ shell:SystemTray.IsVisible="True">
+
+ <!--Data context is set to sample data above and first item in sample data collection below and LayoutRoot contains the root grid where all other page content is placed-->
+ <Grid x:Name="LayoutRoot" Background="Transparent" d:DataContext="{Binding Items[0]}">
+ <Grid.RowDefinitions>
+ <RowDefinition Height="Auto"/>
+ <RowDefinition Height="*"/>
+ </Grid.RowDefinitions>
+
+ <!--TitlePanel contains the name of the application and page title-->
+ <StackPanel x:Name="TitlePanel" Grid.Row="0" Margin="12,17,0,28">
+ <TextBlock Text="MY APPLICATION" Style="{StaticResource PhoneTextNormalStyle}"/>
+ <TextBlock Text="{Binding LineOne}" Margin="9,-7,0,0" Style="{StaticResource PhoneTextTitle1Style}"/>
+ </StackPanel>
+
+ <!--ContentPanel contains details text. Place additional content here-->
+ <Grid x:Name="ContentPanel" Grid.Row="1" Margin="12,0,12,0">
+ <TextBlock Text="{Binding LineThree}" TextWrapping="Wrap" Style="{StaticResource PhoneTextNormalStyle}"/>
+ </Grid>
+
+ <!--Uncomment to see an alignment grid to help ensure your controls are
+ aligned on common boundaries. The image has a top margin of -32px to
+ account for the System Tray. Set this to 0 (or remove the margin altogether)
+ if the System Tray is hidden.
+
+ Before shipping remove this XAML and the image itself.-->
+ <!--<Image Source="/Assets/AlignmentGrid.png" VerticalAlignment="Top" Height="800" Width="480" Margin="0,-32,0,0" Grid.Row="0" Grid.RowSpan="2" IsHitTestVisible="False" />-->
+ </Grid>
+
+</phone:PhoneApplicationPage>
Oops, something went wrong.

0 comments on commit f4077d1

Please sign in to comment.