Pues eso… que estoy probando esto de la creación de aplicaciones para Windows 8 (para la tienda de Windows o Windows store) y quería crear un programa simple que mostrase la fecha y la hora y se fuese actualizando cada segundo…
Esto en una aplicación de escritorio no es nada complicado… y en una aplicación XAML para la tienda de Windows 8 tampoco lo tendría que ser… el problema es que no encontraba la definición del control Timer (no existe) ni la definición de la clase Timer (definida en System.Timers o en System.Threading) que en una aplicación para Windows store no están definidas.
Buscando buscando me encontré con varias clases, dos de ellas algo "liantes" de usar (además de que sin ejemplos para Visual Basic), me refiero a las clases definidas en Windows.System.Threading: ThreadPoolTimer (y otra de la que ya ni me acuerdo).
La cuestión es que también me encontré con la que he usado en este primer ejemplo, esta clase se llama DispatcherTimer y está definida en el espacio de nombres Windows.UI.Xaml, y es más sencilla de utilizar sobre todo para todo lo relacionado con la creación del método de evento, ya que se puede usar WithEvents para la definición de la variable y crear fácilmente dicho método de evento; aunque en este ejemplo usaré AddHandler para indicar cuál es el método de evento (el que se ejecutará cada vez que pase el tiempo indicado en el intervalo), esto lo hago así de "complicado" porque después publicaré el código para los que le gusten usar los puntos y comas, es decir, el código para C#.
El ejemplo es muy simple, tendremos un par de bloques de texto y un botón para iniciar/detener el temporizador.
Primero te muestro el código XAML del fichero MainPage.xaml y después veremos el código de Visual Basic (cuando lo tenga publicado te pondré el enlace a la versión de C#).
MainPage.xaml:
<Page x:Class="Reloj_Windows_8.MainPage" xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" xmlns:local="using:Reloj_Windows_8" xmlns:d="http://schemas.microsoft.com/expression/blend/2008" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" mc:Ignorable="d"> <Grid Background="{StaticResource ApplicationPageBackgroundThemeBrush}"> <StackPanel Orientation="Vertical" Margin="10" HorizontalAlignment="Stretch" VerticalAlignment="Center"> <TextBlock x:Name="txtHora" Margin="20" Text="19:47:00" TextAlignment="Center" Foreground="Lime" FontWeight="Bold" FontFamily="Consolas" FontSize="72" /> <TextBlock x:Name="txtFecha" Margin="10" Text="viernes 30 noviembre 2012" TextAlignment="Center" Foreground="Lime" FontWeight="Bold" FontFamily="Consolas" FontSize="36" /> <StackPanel HorizontalAlignment="Center" Margin="10"> <Button x:Name="btnStop" Content="Stop" Margin="20"/> </StackPanel> </StackPanel> </Grid> </Page>
MainPage.xaml.vb:
Public NotInheritable Class MainPage Inherits Page Private intervalo As Integer = 900 ' La clase DispatcherTimer está definida en el espacio de nombres: ' Windows.UI.Xaml Private timer1 As DispatcherTimer ''' <summary> ''' Invoked when this page is about to be displayed in a Frame. ''' </summary> ''' <param name="e">Event data that describes how this page was reached. The Parameter ''' property is typically used to configure the page.</param> Protected Overrides Sub OnNavigatedTo(e As Navigation.NavigationEventArgs) actualizarHora() btnStop.Content = "Start" btnStop_Click(btnStop, Nothing) End Sub ''' <summary> ''' Asigna la fecha y hora en las cajas de texto ''' </summary> Private Sub actualizarHora() Me.txtHora.Text = DateTime.Now.ToString("HH:mm:ss") Me.txtFecha.Text = DateTime.Now.ToString("dddd, dd MMMM yyyy") End Sub ''' <summary> ''' Este evento es del temporizador y ''' se ejecutará en cada intervalo. ''' </summary> ''' <remarks> ''' Es conveniente no usar un valor muy pequeño para el intervalo ''' lo recomendable es un poco menos de 1 segundo (1000 milisegundos) ''' En el programa utilizo un valor de 900 milisegundos ''' </remarks> Private Sub timer1_Tick(sender As Object, e As Object) 'Handles timer1.Tick actualizarHora() End Sub ''' <summary> ''' Parar o iniciar el temporizador ''' </summary> ''' <remarks></remarks> Private Sub btnStop_Click(sender As Object, e As RoutedEventArgs) Handles btnStop.Click If btnStop.Content.ToString = "Stop" Then timer1.Stop() btnStop.Content = "Start" Else timer1.Start() btnStop.Content = "Stop" End If End Sub Public Sub New() ' This call is required by the designer. InitializeComponent() ' Add any initialization after the InitializeComponent() call. ' crear el temporizador timer1 = New DispatcherTimer AddHandler timer1.Tick, AddressOf timer1_Tick ' el intervalo: 900 milisegundos (algo menos de 1 segundo (1seg = 1000ms)) timer1.Interval = New TimeSpan(0, 0, 0, 0, intervalo) 'timer1.Start() End Sub
Espero que te sea de utilidad.
¡esa es la intención! 😉
Por cierto, esta aplicación la publicaré en el Windows Store y allí la iré actualizando (ya te avisaré cuando esté publicada, si es que la publican, claro).
Como me gusta que las cosas sean "gratis" el precio será de 0 euros, pero como también sé que hay gente que le gusta colaborar (económicamente) con mi(s) sitio(s) (o conmigo para que siga manteniendo mis sitios), y eso de usar PayPal no les gusta mucho, he pensado que también habrá una versión de pago (algo simbólico, supongo que medio euro o un USD dólar o algo así).
Ya te avisaré también… ¡que a todos nos hace falta seguir manteniéndonos! jeje
Nos vemos.
Guillermo
Enlaces a los otros artículos de este "paso a paso":
- Usar un temporizador en las aplicaciones de Windows store (Visual Basic)
- Usar un temporizador en las aplicaciones de Windows store (C#)
- Pon una AppBar en tu aplicación de Windows Store
- Acceder a los recursos de una aplicación de Windows Store desde código (vb, c#, xaml)
- Actualizar el icono (tile) de una aplicación de Windows Store (cada minuto)
- Saber cuando la aplicación está en modo Snapped y actuar en consecuencia
…