From: Gustavo Martin Date: Sun, 23 Feb 2014 20:39:18 +0000 (+0100) Subject: RemoteAgens .NET Windows Phone implementation X-Git-Url: https://git.gumartinm.name/?a=commitdiff_plain;h=109a4db608ba732f041a19e0944ea70e03a77102;p=CSharpForFun%2F.git RemoteAgens .NET Windows Phone implementation --- diff --git a/WindowsPhone/RemoteAgents/RemoteAgents.sln b/WindowsPhone/RemoteAgents/RemoteAgents.sln new file mode 100644 index 0000000..1d0a861 --- /dev/null +++ b/WindowsPhone/RemoteAgents/RemoteAgents.sln @@ -0,0 +1,40 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio 2013 +VisualStudioVersion = 12.0.30110.0 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "RemoteAgents", "RemoteAgents\RemoteAgents.csproj", "{C11B661C-3470-4542-83A7-939674DB2BD2}" +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 + {C11B661C-3470-4542-83A7-939674DB2BD2}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {C11B661C-3470-4542-83A7-939674DB2BD2}.Debug|Any CPU.Build.0 = Debug|Any CPU + {C11B661C-3470-4542-83A7-939674DB2BD2}.Debug|Any CPU.Deploy.0 = Debug|Any CPU + {C11B661C-3470-4542-83A7-939674DB2BD2}.Debug|ARM.ActiveCfg = Debug|ARM + {C11B661C-3470-4542-83A7-939674DB2BD2}.Debug|ARM.Build.0 = Debug|ARM + {C11B661C-3470-4542-83A7-939674DB2BD2}.Debug|ARM.Deploy.0 = Debug|ARM + {C11B661C-3470-4542-83A7-939674DB2BD2}.Debug|x86.ActiveCfg = Debug|x86 + {C11B661C-3470-4542-83A7-939674DB2BD2}.Debug|x86.Build.0 = Debug|x86 + {C11B661C-3470-4542-83A7-939674DB2BD2}.Debug|x86.Deploy.0 = Debug|x86 + {C11B661C-3470-4542-83A7-939674DB2BD2}.Release|Any CPU.ActiveCfg = Release|Any CPU + {C11B661C-3470-4542-83A7-939674DB2BD2}.Release|Any CPU.Build.0 = Release|Any CPU + {C11B661C-3470-4542-83A7-939674DB2BD2}.Release|Any CPU.Deploy.0 = Release|Any CPU + {C11B661C-3470-4542-83A7-939674DB2BD2}.Release|ARM.ActiveCfg = Release|ARM + {C11B661C-3470-4542-83A7-939674DB2BD2}.Release|ARM.Build.0 = Release|ARM + {C11B661C-3470-4542-83A7-939674DB2BD2}.Release|ARM.Deploy.0 = Release|ARM + {C11B661C-3470-4542-83A7-939674DB2BD2}.Release|x86.ActiveCfg = Release|x86 + {C11B661C-3470-4542-83A7-939674DB2BD2}.Release|x86.Build.0 = Release|x86 + {C11B661C-3470-4542-83A7-939674DB2BD2}.Release|x86.Deploy.0 = Release|x86 + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection +EndGlobal diff --git a/WindowsPhone/RemoteAgents/RemoteAgents/App.xaml b/WindowsPhone/RemoteAgents/RemoteAgents/App.xaml new file mode 100644 index 0000000..f2681b6 --- /dev/null +++ b/WindowsPhone/RemoteAgents/RemoteAgents/App.xaml @@ -0,0 +1,20 @@ + + + + + + + + + + + + + \ No newline at end of file diff --git a/WindowsPhone/RemoteAgents/RemoteAgents/App.xaml.cs b/WindowsPhone/RemoteAgents/RemoteAgents/App.xaml.cs new file mode 100644 index 0000000..5453f1e --- /dev/null +++ b/WindowsPhone/RemoteAgents/RemoteAgents/App.xaml.cs @@ -0,0 +1,223 @@ +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 Example.RemoteAgents.WindowsPhone.Resources; + +namespace RemoteAgents +{ + public partial class App : Application + { + /// + /// Proporcionar acceso sencillo al marco raíz de la aplicación telefónica. + /// + /// Marco raíz de la aplicación telefónica. + public static PhoneApplicationFrame RootFrame { get; private set; } + + /// + /// Constructor para el objeto Application. + /// + public App() + { + // Controlador global para excepciones no detectadas. + UnhandledException += Application_UnhandledException; + + // Inicialización XAML estándar + InitializeComponent(); + + // Inicialización especifica del teléfono + InitializePhoneApplication(); + + // Inicialización del idioma + InitializeLanguage(); + + // Mostrar información de generación de perfiles gráfica durante la depuración. + if (Debugger.IsAttached) + { + // Mostrar los contadores de velocidad de marcos actual. + Application.Current.Host.Settings.EnableFrameRateCounter = true; + + // Mostrar las áreas de la aplicación que se están volviendo a dibujar en cada marco. + //Application.Current.Host.Settings.EnableRedrawRegions = true; + + // Habilitar el modo de visualización de análisis de no producción, + // que muestra áreas de una página que se entregan a la GPU con una superposición coloreada. + //Application.Current.Host.Settings.EnableCacheVisualization = true; + + // Impedir que la pantalla se apague mientras se realiza la depuración deshabilitando + // la detección de inactividad de la aplicación. + // Precaución: solo debe usarse en modo de depuración. Las aplicaciones que deshabiliten la detección de inactividad del usuario seguirán en ejecución + // y consumirán energía de la batería cuando el usuario no esté usando el teléfono. + PhoneApplicationService.Current.UserIdleDetectionMode = IdleDetectionMode.Disabled; + } + + } + + // Código para ejecutar cuando la aplicación se inicia (p.ej. a partir de Inicio) + // Este código no se ejecutará cuando la aplicación se reactive + private void Application_Launching(object sender, LaunchingEventArgs e) + { + } + + // Código para ejecutar cuando la aplicación se activa (se trae a primer plano) + // Este código no se ejecutará cuando la aplicación se inicie por primera vez + private void Application_Activated(object sender, ActivatedEventArgs e) + { + } + + // Código para ejecutar cuando la aplicación se desactiva (se envía a segundo plano) + // Este código no se ejecutará cuando la aplicación se cierre + private void Application_Deactivated(object sender, DeactivatedEventArgs e) + { + } + + // Código para ejecutar cuando la aplicación se cierra (p.ej., al hacer clic en Atrás) + // Este código no se ejecutará cuando la aplicación se desactive + private void Application_Closing(object sender, ClosingEventArgs e) + { + } + + // Código para ejecutar si hay un error de navegación + private void RootFrame_NavigationFailed(object sender, NavigationFailedEventArgs e) + { + if (Debugger.IsAttached) + { + // Ha habido un error de navegación; interrumpir el depurador + Debugger.Break(); + } + } + + // Código para ejecutar en excepciones no controladas + private void Application_UnhandledException(object sender, ApplicationUnhandledExceptionEventArgs e) + { + if (Debugger.IsAttached) + { + // Se ha producido una excepción no controlada; interrumpir el depurador + Debugger.Break(); + } + } + + #region Inicialización de la aplicación telefónica + + // Evitar inicialización doble + private bool phoneApplicationInitialized = false; + + // No agregar ningún código adicional a este método + private void InitializePhoneApplication() + { + if (phoneApplicationInitialized) + return; + + // Crear el marco pero no establecerlo como RootVisual todavía; esto permite que + // la pantalla de presentación permanezca activa hasta que la aplicación esté lista para la presentación. + RootFrame = new PhoneApplicationFrame(); + RootFrame.Navigated += CompleteInitializePhoneApplication; + + // Controlar errores de navegación + RootFrame.NavigationFailed += RootFrame_NavigationFailed; + + // Controlar solicitudes de restablecimiento para borrar la pila de retroceso + RootFrame.Navigated += CheckForResetNavigation; + + // Asegurarse de que no volvemos a inicializar + phoneApplicationInitialized = true; + } + + // No agregar ningún código adicional a este método + private void CompleteInitializePhoneApplication(object sender, NavigationEventArgs e) + { + // Establecer el objeto visual raíz para permitir que la aplicación se presente + if (RootVisual != RootFrame) + RootVisual = RootFrame; + + // Quitar este controlador porque ya no es necesario + RootFrame.Navigated -= CompleteInitializePhoneApplication; + } + + private void CheckForResetNavigation(object sender, NavigationEventArgs e) + { + // Si la aplicación ha recibido una navegación 'reset', tenemos que comprobarlo + // en la siguiente navegación para ver si se debe restablecer la pila de páginas + if (e.NavigationMode == NavigationMode.Reset) + RootFrame.Navigated += ClearBackStackAfterReset; + } + + private void ClearBackStackAfterReset(object sender, NavigationEventArgs e) + { + // Anular registro del evento para que no se vuelva a llamar + RootFrame.Navigated -= ClearBackStackAfterReset; + + // Borrar solo la pila de navegaciones 'new' (hacia delante) y 'refresh' + if (e.NavigationMode != NavigationMode.New && e.NavigationMode != NavigationMode.Refresh) + return; + + // Por coherencia de la IU, borrar toda la pila de páginas + while (RootFrame.RemoveBackEntry() != null) + { + ; // no hacer nada + } + } + + #endregion + + // Inicializar la fuente y la dirección de flujo de la aplicación según se define en sus cadenas de recursos traducidas. + // + // Para asegurarse de que la fuente de la aplicación está alineada con sus idiomas admitidos y que + // FlowDirection para todos esos idiomas sigue su dirección tradicional, ResourceLanguage + // y ResourceFlowDirection se debe inicializar en cada archivo resx para que estos valores coincidan con ese + // referencia cultural del archivo. Por ejemplo: + // + // AppResources.es-ES.resx + // El valor de ResourceLanguage debe ser "es-ES" + // El valor de ResourceFlowDirection debe ser "LeftToRight" + // + // AppResources.ar-SA.resx + // El valor de ResourceLanguage debe ser "ar-SA" + // El valor de ResourceFlowDirection debe ser "RightToLeft" + // + // Para obtener más información sobre cómo traducir aplicaciones para Windows Phone, consulte http://go.microsoft.com/fwlink/?LinkId=262072. + // + private void InitializeLanguage() + { + try + { + // Establecer la fuente para que coincida con el idioma definido por + // Cadena de recursos ResourceLanguage para cada idioma admitido. + // + // Recurrir a la fuente del idioma neutro si el idioma + // del teléfono no se admite. + // + // Si se produce un error del compilador, falta ResourceLanguage + // el archivo de recursos. + RootFrame.Language = XmlLanguage.GetLanguage(AppResources.ResourceLanguage); + + // Establecer FlowDirection de todos los elementos del marco raíz según + // en la cadena de recursos ResourceFlowDirection para cada + // idioma admitido. + // + // Si se produce un error del compilador, falta ResourceFlowDirection + // el archivo de recursos. + FlowDirection flow = (FlowDirection)Enum.Parse(typeof(FlowDirection), AppResources.ResourceFlowDirection); + RootFrame.FlowDirection = flow; + } + catch + { + // Si se detecta aquí una excepción, lo más probable es que se deba a + // ResourceLanguage no se ha establecido correctamente en un idioma admitido + // o ResourceFlowDirection se ha establecido en un valor distinto de LeftToRight + // o RightToLeft. + + if (Debugger.IsAttached) + { + Debugger.Break(); + } + + throw; + } + } + } +} \ No newline at end of file diff --git a/WindowsPhone/RemoteAgents/RemoteAgents/Assets/AlignmentGrid.png b/WindowsPhone/RemoteAgents/RemoteAgents/Assets/AlignmentGrid.png new file mode 100644 index 0000000..f7d2e97 Binary files /dev/null and b/WindowsPhone/RemoteAgents/RemoteAgents/Assets/AlignmentGrid.png differ diff --git a/WindowsPhone/RemoteAgents/RemoteAgents/Assets/ApplicationIcon.png b/WindowsPhone/RemoteAgents/RemoteAgents/Assets/ApplicationIcon.png new file mode 100644 index 0000000..7d95d4e Binary files /dev/null and b/WindowsPhone/RemoteAgents/RemoteAgents/Assets/ApplicationIcon.png differ diff --git a/WindowsPhone/RemoteAgents/RemoteAgents/Assets/Tiles/FlipCycleTileLarge.png b/WindowsPhone/RemoteAgents/RemoteAgents/Assets/Tiles/FlipCycleTileLarge.png new file mode 100644 index 0000000..e0c59ac Binary files /dev/null and b/WindowsPhone/RemoteAgents/RemoteAgents/Assets/Tiles/FlipCycleTileLarge.png differ diff --git a/WindowsPhone/RemoteAgents/RemoteAgents/Assets/Tiles/FlipCycleTileMedium.png b/WindowsPhone/RemoteAgents/RemoteAgents/Assets/Tiles/FlipCycleTileMedium.png new file mode 100644 index 0000000..e93b89d Binary files /dev/null and b/WindowsPhone/RemoteAgents/RemoteAgents/Assets/Tiles/FlipCycleTileMedium.png differ diff --git a/WindowsPhone/RemoteAgents/RemoteAgents/Assets/Tiles/FlipCycleTileSmall.png b/WindowsPhone/RemoteAgents/RemoteAgents/Assets/Tiles/FlipCycleTileSmall.png new file mode 100644 index 0000000..550b1b5 Binary files /dev/null and b/WindowsPhone/RemoteAgents/RemoteAgents/Assets/Tiles/FlipCycleTileSmall.png differ diff --git a/WindowsPhone/RemoteAgents/RemoteAgents/Assets/Tiles/IconicTileMediumLarge.png b/WindowsPhone/RemoteAgents/RemoteAgents/Assets/Tiles/IconicTileMediumLarge.png new file mode 100644 index 0000000..686e6b5 Binary files /dev/null and b/WindowsPhone/RemoteAgents/RemoteAgents/Assets/Tiles/IconicTileMediumLarge.png differ diff --git a/WindowsPhone/RemoteAgents/RemoteAgents/Assets/Tiles/IconicTileSmall.png b/WindowsPhone/RemoteAgents/RemoteAgents/Assets/Tiles/IconicTileSmall.png new file mode 100644 index 0000000..d4b5ede Binary files /dev/null and b/WindowsPhone/RemoteAgents/RemoteAgents/Assets/Tiles/IconicTileSmall.png differ diff --git a/WindowsPhone/RemoteAgents/RemoteAgents/LocalizedStrings.cs b/WindowsPhone/RemoteAgents/RemoteAgents/LocalizedStrings.cs new file mode 100644 index 0000000..e9c2ec8 --- /dev/null +++ b/WindowsPhone/RemoteAgents/RemoteAgents/LocalizedStrings.cs @@ -0,0 +1,14 @@ +using Example.RemoteAgents.WindowsPhone.Resources; + +namespace RemoteAgents +{ + /// + /// Proporciona acceso a los recursos de cadena. + /// + public class LocalizedStrings + { + private static AppResources _localizedResources = new AppResources(); + + public AppResources LocalizedResources { get { return _localizedResources; } } + } +} \ No newline at end of file diff --git a/WindowsPhone/RemoteAgents/RemoteAgents/MainPage.xaml b/WindowsPhone/RemoteAgents/RemoteAgents/MainPage.xaml new file mode 100644 index 0000000..e0d53d1 --- /dev/null +++ b/WindowsPhone/RemoteAgents/RemoteAgents/MainPage.xaml @@ -0,0 +1,64 @@ + + + + + + + + + + + + + + + + + + + + +