Compartir vía


IndicatorView

Browse sample. Examina el ejemplo

.NET Multi-platform App UI (.NET MAUI) IndicatorView es un control que muestra indicadores que representan el número de elementos y la posición actual, en CarouselView:

Screenshot of a CarouselView and IndicatorView.

IndicatorView define las siguientes propiedades:

  • Count, de tipo int, el número de indicadores.
  • HideSingle, de tipo bool, indica si el indicador debe ocultarse cuando solo existe uno. El valor predeterminado es true.
  • IndicatorColor, de tipo Color, el color de los indicadores.
  • IndicatorSize, de tipo double, el tamaño de los indicadores. El valor predeterminado es 6.0.
  • IndicatorLayout, de tipo Layout<View>, define la clase de diseño utilizada para representar IndicatorView. .NET MAUI establece esta propiedad y normalmente no es necesario que los desarrolladores establezcan esta propiedad.
  • IndicatorTemplate, de tipo DataTemplate, la plantilla que define la apariencia de cada indicador.
  • IndicatorsShape, de tipo IndicatorShape, la forma de cada indicador.
  • ItemsSource, de tipo IEnumerable, la colección en la que se mostrarán los indicadores. Esta propiedad se establecerá automáticamente cuando se establezca la propiedad CarouselView.IndicatorView.
  • MaximumVisible, de tipo int, el número máximo de indicadores visibles. El valor predeterminado es int.MaxValue.
  • Position, de tipo int, el índice de indicador seleccionado actualmente. Esta propiedad usa un enlace TwoWay. Esta propiedad se establecerá automáticamente cuando se establezca la propiedad CarouselView.IndicatorView.
  • SelectedIndicatorColor, de tipo Color, el color del indicador que representa el elemento actual en CarouselView.

Estas propiedades están respaldadas por objetos BindableProperty, lo que significa que pueden ser destinos de los enlaces de datos, y con estilo.

Creación de IndicatorView

Para agregar indicadores a una página, crea un objeto IndicatorView y establece sus propiedades IndicatorColor y SelectedIndicatorColor. Además, establece la propiedad CarouselView.IndicatorView en el nombre del objeto IndicatorView.

En el siguiente ejemplo se muestra cómo crear IndicatorView en XAML:

<Grid RowDefinitions="*,Auto">
    <CarouselView ItemsSource="{Binding Monkeys}"
                  IndicatorView="indicatorView">
        <CarouselView.ItemTemplate>
            <!-- DataTemplate that defines item appearance -->
        </CarouselView.ItemTemplate>
    </CarouselView>
    <IndicatorView x:Name="indicatorView"
                   Grid.Row="1"
                   IndicatorColor="LightGray"
                   SelectedIndicatorColor="DarkGray"
                   HorizontalOptions="Center" />
</Grid>

En este ejemplo, IndicatorView se representa debajo de CarouselView, con un indicador para cada elemento de CarouselView. IndicatorView se rellena con datos estableciendo la propiedad CarouselView.IndicatorView en el objeto IndicatorView. Cada indicador es un círculo gris claro, mientras que el indicador que representa el elemento actual en CarouselView es gris oscuro.

Importante

Establecer la propiedad CarouselView.IndicatorView da como resultado el enlace de la propiedad IndicatorView.Position a la propiedad CarouselView.Position y el enlace de la propiedad IndicatorView.ItemsSource a la propiedad CarouselView.ItemsSource.

Cambio de forma del indicador

La IndicatorView clase tiene una propiedad IndicatorsShape que determina la forma de los indicadores. La propiedad se puede establecer en uno de los miembros de enumeración IndicatorShape:

  • Circle especifica que las formas del indicador serán circulares. Se trata del valor predeterminado de la propiedad IndicatorView.IndicatorsShape.
  • Square indica que las formas del indicador serán cuadradas.

En el ejemplo siguiente se muestra una clase IndicatorView configurada para usar indicadores cuadrados:

<IndicatorView x:Name="indicatorView"
               IndicatorsShape="Square"
               IndicatorColor="LightGray"
               SelectedIndicatorColor="DarkGray" />

Cambio del tamaño del indicador

La clase IndicatorView tiene una propiedad IndicatorSize, de tipo double, que determina el tamaño de los indicadores en unidades independientes del dispositivo. El valor predeterminado de esta propiedad es 6.0.

En el ejemplo siguiente se muestra una clase IndicatorView configurada para mostrar indicadores más grandes:

<IndicatorView x:Name="indicatorView"
               IndicatorSize="18" />

Limitación del número de indicadores mostrados

La clase IndicatorView tiene una propiedad MaximumVisible, de tipo int, que determina el número máximo de indicadores visibles.

En el ejemplo siguiente se muestra una clase IndicatorView configurada para mostrar un máximo de seis indicadores:

<IndicatorView x:Name="indicatorView"
               MaximumVisible="6" />

Definición de la apariencia del indicador

Se puede personalizar la apariencia de cada indicador estableciendo la propiedad IndicatorView.IndicatorTemplate en DataTemplate:

<Grid RowDefinitions="*,Auto">
    <CarouselView ItemsSource="{Binding Monkeys}"
                  IndicatorView="indicatorView">
        <CarouselView.ItemTemplate>
            <!-- DataTemplate that defines item appearance -->
        </CarouselView.ItemTemplate>
    </CarouselView>
    <IndicatorView x:Name="indicatorView"
                   Grid.Row="1"
                   Margin="0,0,0,40"
                   IndicatorColor="Transparent"
                   SelectedIndicatorColor="Transparent"
                   HorizontalOptions="Center">
        <IndicatorView.IndicatorTemplate>
            <DataTemplate>
                <Label Text="&#xf30c;"
                       FontFamily="ionicons"
                       FontSize="12" />
            </DataTemplate>
        </IndicatorView.IndicatorTemplate>
    </IndicatorView>
</Grid>

Los elementos especificados en DataTemplate definen la apariencia de cada indicador. En este ejemplo, cada indicador es un Label que muestra un icono de fuente.

En la captura de pantalla siguiente se muestran los indicadores representados mediante un icono de fuente:

Screenshot of a templated IndicatorView.

Establecimiento de estados visuales

IndicatorView tiene un estado visual Selected que se puede usar para iniciar un cambio visual en el indicador de la posición actual en IndicatorView. Un caso de uso común para este VisualState es cambiar el color del indicador que representa la posición actual:

<ContentPage ...>
    <ContentPage.Resources>
        <Style x:Key="IndicatorLabelStyle"
               TargetType="Label">
            <Setter Property="VisualStateManager.VisualStateGroups">
                <VisualStateGroupList>
                    <VisualStateGroup x:Name="CommonStates">
                        <VisualState x:Name="Normal">
                            <VisualState.Setters>
                                <Setter Property="TextColor"
                                        Value="LightGray" />
                            </VisualState.Setters>
                        </VisualState>
                        <VisualState x:Name="Selected">
                            <VisualState.Setters>
                                <Setter Property="TextColor"
                                        Value="Black" />
                            </VisualState.Setters>
                        </VisualState>
                    </VisualStateGroup>
                </VisualStateGroupList>
            </Setter>
        </Style>
    </ContentPage.Resources>

    <Grid RowDefinitions="*,Auto">
        ...
        <IndicatorView x:Name="indicatorView"
                       Grid.Row="1"
                       Margin="0,0,0,40"
                       IndicatorColor="Transparent"
                       SelectedIndicatorColor="Transparent"
                       HorizontalOptions="Center">
            <IndicatorView.IndicatorTemplate>
                <DataTemplate>
                    <Label Text="&#xf30c;"
                           FontFamily="ionicons"
                           FontSize="12"
                           Style="{StaticResource IndicatorLabelStyle}" />
                </DataTemplate>
            </IndicatorView.IndicatorTemplate>
        </IndicatorView>
    </Grid>
</ContentPage>

En este ejemplo, el estado visual Selected especifica que el indicador que representa la posición actual tendrá su TextColor establecido en negro. De lo contrario, el TextColor del indicador será gris claro:

Screenshot of IndicatorView selected visual state.

Para más información sobre los estados visuales, consulta Estados visuales.