IndexToArrayItemConverter
O IndexToArrayItemConverter
é um conversor que permite que os usuários convertam uma associação de valor int
em um item em uma matriz. O valor int
associado a dados representa o indexador usado para acessar a matriz. A matriz é passada por meio da ConverterParameter
.
Propriedades BaseConverter
As seguintes propriedades são implementadas na classe base: public abstract class BaseConverter
Propriedade | Descrição |
---|---|
DefaultConvertReturnValue |
Valor padrão a ser retornado quando IValueConverter.Convert(object?, Type, object?, CultureInfo?) lança um Exception . Esse valor é usado quando CommunityToolkit.Maui.Options.ShouldSuppressExceptionsInConverters é definido como true . |
DefaultConvertBackReturnValue |
Valor padrão a ser retornado quando IValueConverter.ConvertBack(object?, Type, object?, CultureInfo?) lança um Exception . Esse valor é usado quando CommunityToolkit.Maui.Options.ShouldSuppressExceptionsInConverters é definido como true . |
Propriedades ICommunityToolkitValueConverter
As seguintes propriedades são implementadas no public interface ICommunityToolkitValueConverter
:
Propriedade | Type | Descrição |
---|---|---|
DefaultConvertReturnValue |
object? |
Valor padrão a ser retornado quando IValueConverter.Convert(object?, Type, object?, CultureInfo?) lança um Exception . Esse valor é usado quando CommunityToolkit.Maui.Options.ShouldSuppressExceptionsInConverters é definido como true . |
DefaultConvertBackReturnValue |
object? |
Valor padrão a ser retornado quando IValueConverter.ConvertBack(object?, Type, object?, CultureInfo?) lança um Exception . Esse valor é usado quando CommunityToolkit.Maui.Options.ShouldSuppressExceptionsInConverters é definido como true . |
Sintaxe
XAML
Incluir o namespace XAML
Para usar o kit de ferramentas no XAML, o xmlns
a seguir precisa ser adicionado à sua página ou exibição:
xmlns:toolkit="http://schemas.microsoft.com/dotnet/2022/maui/toolkit"
Portanto, o seguinte:
<ContentPage
x:Class="CommunityToolkit.Maui.Sample.Pages.MyPage"
xmlns="http://schemas.microsoft.com/dotnet/2021/maui"
xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml">
</ContentPage>
Seria modificado para incluir o xmlns
conforme o seguinte:
<ContentPage
x:Class="CommunityToolkit.Maui.Sample.Pages.MyPage"
xmlns="http://schemas.microsoft.com/dotnet/2021/maui"
xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
xmlns:toolkit="http://schemas.microsoft.com/dotnet/2022/maui/toolkit">
</ContentPage>
Como usar o IndexToArrayItemConverter
O IndexToArrayItemConverter
pode ser usado da seguinte maneira em XAML:
<ContentPage xmlns="http://schemas.microsoft.com/dotnet/2021/maui"
xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
xmlns:toolkit="http://schemas.microsoft.com/dotnet/2022/maui/toolkit"
x:Class="MyLittleApp.MainPage">
<ContentPage.Resources>
<ResourceDictionary>
<toolkit:IndexToArrayItemConverter x:Key="IndexToArrayItemConverter" />
<x:Array x:Key="MyArray" Type="x:String">
<x:String>Value 1</x:String>
<x:String>Value 2</x:String>
<x:String>Value 3</x:String>
<x:String>Value 4</x:String>
<x:String>Value 5</x:String>
</x:Array>
</ResourceDictionary>
</ContentPage.Resources>
<StackLayout>
<Label Text="{Binding MyIntegerValue, Converter={StaticResource IndexToArrayItemConverter}, ConverterParameter={StaticResource MyArray}}" />
</StackLayout>
</ContentPage>
C#
O IndexToArrayItemConverter
pode ser usado da seguinte maneira em C#:
class IndexToArrayItemConverter : ContentPage
{
public IndexToArrayItemConverter()
{
var array = new string[] { "Value 1", "Value 2", "Value 3", "Value 4", "Value 5" };
var label = new Label();
label.SetBinding(
Label.TextProperty,
new Binding(
static (ViewModel vm) => vm.MyIntegerValue,
converter: new IndexToArrayItemConverter(),
converterParameter: array));
Content = label;
}
}
Markup do C#
Nosso pacote CommunityToolkit.Maui.Markup
fornece uma maneira muito mais concisa de usar esse conversor no C#.
using CommunityToolkit.Maui.Markup;
class IndexToArrayItemConverter : ContentPage
{
public IndexToArrayItemConverter()
{
var array = new string[] { "Value 1", "Value 2", "Value 3", "Value 4", "Value 5" };
Content = new Label()
.Bind(
Label.TextProperty,
static (ViewModel vm) => vm.MyIntegerValue,
converter: new IndexToArrayItemConverter(),
converterParameter: array);
}
}
Exemplos
Você pode encontrar um exemplo desse comportamento em ação no Aplicativo de amostra do Kit de Ferramentas da Comunidade .NET MAUI.
API
O código-fonte do IndexToArrayItemConverter
pode ser encontrado no repositório GitHub do .NET MAUI Community Toolkit.
.NET MAUI Community Toolkit