EnumToBoolConverter
Jedná se EnumToBoolConverter
o jednosměrný převaděč, který umožňuje převést na Enum
odpovídající bool
na základě toho, zda se rovná sadě zadaných výčtových hodnot. Je užitečné při vytváření vazby kolekce hodnot představující typ výčtu k logické vlastnosti ovládacího prvku, jako je IsVisible
vlastnost.
Metoda Convert
vrátí zadaný value
převedený na bool
základě toho, zda value
je roven některému z definovaných TrueValues
nebo zadaných CommandParameter
.
Metoda ConvertBack
není podporována.
Poznámka:
Všimněte si, že hodnotu true, která se má porovnat, lze zadat následujícími způsoby:
TrueValue
jako vlastnost v převaděči.ConverterParameter
jako v vazbě převaděče,
Všimněte si, že TrueValues
vlastnost bude mít přednost před ConverterParameter
možností.
BaseConverter – vlastnosti
V základní třídě jsou implementovány následující vlastnosti: public abstract class BaseConverter
Vlastnost | Popis |
---|---|
DefaultConvertReturnValue |
Výchozí hodnota, která se má vrátit při IValueConverter.Convert(object?, Type, object?, CultureInfo?) vyvolání .Exception Tato hodnota se používá, když Je nastavena možnost true CommunityToolkit.Maui.Options.ShouldSuppressExceptionsInConverters . |
DefaultConvertBackReturnValue |
Výchozí hodnota, která se má vrátit při IValueConverter.ConvertBack(object?, Type, object?, CultureInfo?) vyvolání .Exception Tato hodnota se používá, když Je nastavena možnost true CommunityToolkit.Maui.Options.ShouldSuppressExceptionsInConverters . |
ICommunityToolkitValueConverter – vlastnosti
Následující vlastnosti jsou implementovány v public interface ICommunityToolkitValueConverter
:
Vlastnost | Type | Popis |
---|---|---|
DefaultConvertReturnValue |
object? |
Výchozí hodnota, která se má vrátit při IValueConverter.Convert(object?, Type, object?, CultureInfo?) vyvolání .Exception Tato hodnota se používá, když Je nastavena možnost true CommunityToolkit.Maui.Options.ShouldSuppressExceptionsInConverters . |
DefaultConvertBackReturnValue |
object? |
Výchozí hodnota, která se má vrátit při IValueConverter.ConvertBack(object?, Type, object?, CultureInfo?) vyvolání .Exception Tato hodnota se používá, když Je nastavena možnost true CommunityToolkit.Maui.Options.ShouldSuppressExceptionsInConverters . |
Syntaxe
Každý z následujících příkladů používá následující definici výčtu:
namespace MyLittleApp;
public enum MyDevicePlatform
{
Android,
iOS,
macOS,
Tizen,
Windows
}
XAML
Zahrnutí oboru názvů XAML
Pokud chcete použít sadu nástrojů v XAML, musíte do stránky nebo zobrazení přidat následující xmlns
položky:
xmlns:toolkit="http://schemas.microsoft.com/dotnet/2022/maui/toolkit"
Proto platí následující:
<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>
Bylo by změněno tak, aby zahrnovalo xmlns
následující:
<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>
Použití enumToBoolConverter
V XAML je možné ho EnumToBoolConverter
použít následujícím způsobem:
<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"
xmlns:mylittleapp="clr-namespace:MyLittleApp"
x:Class="MyLittleApp.MainPage">
<ContentPage.Resources>
<ResourceDictionary>
<toolkit:EnumToBoolConverter x:Key="MobileConverter">
<toolkit:EnumToBoolConverter.TrueValues>
<mylittleapp:MyDevicePlatform>Android</mylittleapp:MyDevicePlatform>
<mylittleapp:MyDevicePlatform>iOS</mylittleapp:MyDevicePlatform>
</toolkit:EnumToBoolConverter.TrueValues>
</toolkit:EnumToBoolConverter>
</ResourceDictionary>
</ContentPage.Resources>
<VerticalStackLayout>
<Picker ItemsSource="{Binding Platforms}"
SelectedItem="{Binding SelectedPlatform}" />
<Label IsVisible="{Binding SelectedPlatform, Converter={StaticResource MobileConverter}}"
Text="I am visible when the Picker value is Android or iOS."/>
</VerticalStackLayout>
</ContentPage>
Je také možné předat parametr převaděče:
<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:EnumToBoolConverter x:Key="PlatformConverter" />
</ResourceDictionary>
</ContentPage.Resources>
<VerticalStackLayout>
<Picker ItemsSource="{Binding Platforms}"
SelectedItem="{Binding SelectedPlatform}" />
<Label IsVisible="{Binding SelectedPlatform, Converter={StaticResource PlatformConverter}, ConverterParameter={x:Static vm:MyDevicePlatform.Tizen}}"
Text="I am visible when the Picker value is Tizen."/>
</VerticalStackLayout>
</ContentPage>
C#
V EnumToBoolConverter
jazyce C# je možné ho použít následujícím způsobem:
class EnumToBoolConverterPage : ContentPage
{
public EnumToBoolConverterPage()
{
var picker = new Picker();
picker.SetBinding(Picker.ItemsSourceProperty, nameof(ViewModel.Platforms));
picker.SetBinding(Picker.SelectedItemProperty, nameof(ViewModel.SelectedPlatform));
var label = new Label
{
Text = "I am visible when the Picker value is Tizen."
};
label.SetBinding(
Label.IsVisibleProperty,
new Binding(
nameof(ViewModel.SelectedPlatform),
converter: new EnumToBoolConverter(),
converterParameter: MyDevicePlatform.Tizen));
Content = new VerticalStackLayout
{
Children = { picker, label }
};
}
}
Revize jazyka C#
Náš CommunityToolkit.Maui.Markup
balíček nabízí mnohem stručnější způsob použití tohoto převaděče v jazyce C#.
using CommunityToolkit.Maui.Markup;
class EnumToBoolConverterPage : ContentPage
{
public EnumToBoolConverterPage()
{
Content = new VerticalStackLayout
{
Children =
{
new Picker()
.Bind(
Picker.ItemsSourceProperty,
static (ViewModel vm) => vm.Platforms)
.Bind(
Picker.SelectedItemProperty,
static (ViewModel vm) => vm.SelectedPlatform),
new Label()
.Text("I am visible when the Picker value is Tizen.")
.Bind(
Label.IsVisibleProperty,
static (ViewModel vm) => vm.SelectedPlatform,
converter: new EnumToBoolConverter(),
converterParameter: MyDevicePlatform.Tizen)
}
};
}
}
Vlastnosti
Vlastnost | Type | Popis |
---|---|---|
TrueValues | IList<Enum> |
Výčtové hodnoty, které se převedou na true (volitelné). |
Příklady
Příklad tohoto převaděče najdete v akci v ukázkové aplikaci .NET MAUI Community Toolkit.
rozhraní API
Zdrojový kód EnumToBoolConverter
najdete v úložišti .NET MAUI Community Toolkit na GitHubu.
.NET MAUI Community Toolkit