Introducción
Las extensiones de marcado son una forma de obtener un valor que no sea específico de tipo primitivo o un objeto XAML. Mediante la apertura y cierre de llaves, se define en su interior lo que se conoce como extensión de marcado.
En este artículo, vamos a conocer como crear nuestras propias extensiones de marcado.
RECUERDA: Ya vimos en un artículo anterior el concepto de extensión de marcado así como las extensiones de marcado disponibles.
Extensiones de marcado personalizadas
Las extensiones de marcado implementan la interfaz IMarkupExtension. Esta interfaz sólo cuenta con un método a implementar:
public object ProvideValue(IServiceProvider serviceProvider)
Cuando se realiza el análisis del código XAML y el compilador encuentra una extensión de marcado, se lanza este método antes de establecer el valor de la extensión.
Crear extensiones
Vamos a realizar una de las extensiones de marcado más sencillas posibles con el objetivo de centrarnos a fondo en los conceptos clave de la extensión. Nuestra extensión nos permitirá utilizar colores RGB estableciendo directamente los valores para rojo, verde y azul.
En el método ProvideValue, por defecto, no obtenemos valores con IServiceProvider. Por lo tanto, para obtener los valores necesarios en nuestra extensión (rojo, verde y azul) vamos a necesitar utilizar propiedades.
public class RGBColor : IMarkupExtension { public int Red { get; set; } public int Green { get; set; } public int Blue { get; set; } public object ProvideValue(IServiceProvider serviceProvider) { return Color.FromRgb(Red, Green, Blue); } }
Creamos una clase que hereda de IMarkupExtension, implementamos el método ProvideValue que se lanzará a la hora de evaluar la expresión. Gracias a propiedades capturamos los valores deseados. La lógica del método ProvideValue se encarga de crear el valor devuelto deseado, un color.
Todo listo!
Utilizar extensiones
Utilizar la extensión es sencillo. Necesitamos acceder a la misma, por lo tanto, debemos declarar el espacio de nombres en XAML en el lugar a utilizar:
xmlns:extensions="clr-namespace:CustomMarkupExtension.Extensions;assembly=CustomMarkupExtension"
Y utilizarlo:
<Label Text="Test" TextColor="{extensions:RGBColor Red=255, Green=0, Blue=255}" BackgroundColor="{extensions:RGBColor Red=200, Green=100, Blue = 0}" />
Fíjate que todo el código queda bastante simple y muy legible. Tenéis el código fuente del ejemplo utilizado disponible en GitHub:
Mediante la implementación de IMarkupExtension podemos crear nuestras propias extensiones de marcado. Las extensiones de marcado personalizadas nos dan una forma sencilla y potente de ejecutar código, realizar validaciones y conversiones de valores antes de establecer el valor de una propiedad.
Más información
- Documentación Xamarin: XAML Markup Extensions
- Documentación Xamarin: IMarkupExtension
- Code Mill Blog: XAML Markup Extensions