CalendarView
Explicación del concepto de CalendarView.
Last updated
Explicación del concepto de CalendarView.
Last updated
Hereda de:
Esta clase presenta un calendario para seleccionar fechas. El rango de fechas soportado por el calendario es configurable.
La apariencia exacta y la interacción concreta con esta View puede variar entre Versiones de Sistema Operativo y temas instalados en el equipo.
De manera general un usuario puede seleccionar una fecha pinchando en ella y puede moverse entre meses scroleando.
Define la apariencia del texto que representa los números de los días en el calendario.
Representa el primer día de la semana de acuerdo con la clase java.util.Calendar
.
La clase java.util.Calendar
es una clase abstracta que proporciona métodos para la conversión de un momento concreto en el tiempo a un conjunto de datos que puedan ser representados como una fecha (Año, Mes, Dia del mes, Hora...).
Esta clase provee muchos métodos pero lo que nos interesa para este atributo concreto es como conseguir que el primer día de la semana sea Lunes y no Domingo.
Esto lo veremos más adelante, en el apartado Personalización.
El color de la fecha que se encuentra seleccionada en el mes que tiene el foco.
Este atributo ha sido deprecado en la API Level 23. Debido a la inclusión de Material Design.
Define la fecha máxima que se puede mostrar en formato MM/DD/YYYY
.
Define la fecha mínima que se puede mostrar en formato MM/DD/YYYY
.
Define el drawable de las barras verticales que se muestran al inicio y al final de la fecha elegida.
Este atributo ha sido deprecado en la API Level 23. Debido a la inclusión de Material Design.
Define el color de fondo de la semana elegida.
Este atributo ha sido deprecado en la API Level 23. Debido a la inclusión de Material Design.
Define si se muestra el número de la semana o no.
Este atributo ha sido deprecado en la API Level 23. Debido a la inclusión de Material Design.
Define el número de semanas que se van a mostrar.
Este atributo ha sido deprecado en la API Level 23. Debido a la inclusión de Material Design.
El color de la fecha que se encuentra seleccionada en el mes que NO tiene el foco.
Este atributo ha sido deprecado en la API Level 23. Debido a la inclusión de Material Design.
Define la apariencia del texto que representa las iniciales de los días de la semana en el calendario.
Define el color del número de semana.
Este atributo ha sido deprecado en la API Level 23. Debido a la inclusión de Material Design.
Define el color de la linea que separa las semanas.
Este atributo ha sido deprecado en la API Level 23. Debido a la inclusión de Material Design.
Lo más importante de un CalendarView es ser capaz de ejecutar código al seleccionar una fecha. En este caso, podemos definir un Listener del tipo setOnDateChangeListener(CalendarView, year, month, day)
.
Es importante tener en cuenta que el mes se maneja como un Array y por lo tanto, los meses van de 0 a 11 a nivel interno.
En ocasiones, las opciones del calendario se deben limitar para mejorar la experiencia de usuario.
Por ejemplo, si hay que coger un tren de ida y otro de vuelta, la fecha de regreso no puede ser menor que la de ida. Tampoco se puede reservar un tren anterior a la fecha de hoy ni dentro de un año y medio.
Todo esto, hemos visto que se puede limitar desde XML con atributos, pero lo ideal es limitarlo dinámicamente desde código.
Para hacer esto, hacemos lo siguiente:
Generamos una instancia de la clase java.util.Calendar()
.
Generamos una variable que almacene el día de hoy, ayudados por la instancia de Calendar()
, y la almacenamos en el atributo minDate
:
Seteamos la instancia de Calendar() en el último día permitido (en este caso el 31/12/2023).
Generamos una variable que almacene el último día permitido, ayudados por la instancia de Calendar()
, y la almacenamos en el atributo maxDate
:
Como vemos arriba, es fundamental mostrar las fechas en milisegundos.
Esta es la forma estandarizada de referirse a las fechas en computación, se denomina tiempo Epoch o tiempo UNIX y referencia exactamente a los milisegundos que han pasado desde el 1 de enero de 1970.
Para iOS el tiempo Epoch comienza desde el 1 de enero de 1904.
Para Microsoft el tiempo Epoch comienza desde el 1 de enero de 1601.
Normalmente se utiliza de manera estandarizada el tiempo UNIX.
De esta manera el código queda como sigue:
Como vemos en los ejemplos superiores, el primer día de la semana está referenciado como Domingo mientras que en España, por ejemplo, se empiezan a contar (de manera general) desde el lunes.
Para cambiar esto, vamos a modificar el valor de android:firstDayOfWeek desde código, sin embargo, se va a tener que realizar un calculo concreto: