StateToBooleanConverter
StateToBooleanConverter
ist ein unidirektionaler Konverter, der ein boolean
-Ergebnis basierend darauf zurückgibt, ob der bereitgestellte Wert einem bestimmten LayoutState
entspricht.
Die Convert
-Methode gibt ein boolean
-Ergebnis basierend darauf zurück, ob der bereitgestellte Wert einem bestimmten LayoutState
entspricht. Die LayoutState
-Enumeration wird vom Toolkit bereitgestellt und bietet die möglichen Werte:
None
Loading
Saving
Success
Error
Empty
Custom
Hinweis
Beachten Sie, dass die erwartete LayoutState
in der folgenden Rangfolge angegeben werden kann:
- als
ConverterParameter
in der Konverterbindung; dadurch wird die EigenschaftStateToCompare
ersetzt - als
StateToCompare
-Eigenschaft im Konverter
Die Methode ConvertBack
wird nicht unterstützt.
BaseConverter-Eigenschaften
Die folgenden Eigenschaften werden in der Basisklasse public abstract class BaseConverter
implementiert:
Eigenschaft | Beschreibung |
---|---|
DefaultConvertReturnValue |
Standardwert, der zurückgegeben werden soll, wenn IValueConverter.Convert(object?, Type, object?, CultureInfo?) eine Exception auslöst. Dieser Wert wird verwendet, wenn CommunityToolkit.Maui.Options.ShouldSuppressExceptionsInConverters auf true festgelegt ist. |
DefaultConvertBackReturnValue |
Standardwert, der zurückgegeben werden soll, wenn IValueConverter.ConvertBack(object?, Type, object?, CultureInfo?) eine Exception auslöst. Dieser Wert wird verwendet, wenn CommunityToolkit.Maui.Options.ShouldSuppressExceptionsInConverters auf true festgelegt ist. |
ICommunityToolkitValueConverter-Eigenschaften
Die folgenden Eigenschaften werden im public interface ICommunityToolkitValueConverter
implementiert:
Eigenschaft | Typ | Beschreibung |
---|---|---|
DefaultConvertReturnValue |
object? |
Standardwert, der zurückgegeben werden soll, wenn IValueConverter.Convert(object?, Type, object?, CultureInfo?) eine Exception auslöst. Dieser Wert wird verwendet, wenn CommunityToolkit.Maui.Options.ShouldSuppressExceptionsInConverters auf true festgelegt ist. |
DefaultConvertBackReturnValue |
object? |
Standardwert, der zurückgegeben werden soll, wenn IValueConverter.ConvertBack(object?, Type, object?, CultureInfo?) eine Exception auslöst. Dieser Wert wird verwendet, wenn CommunityToolkit.Maui.Options.ShouldSuppressExceptionsInConverters auf true festgelegt ist. |
Syntax
Im folgenden Beispiel wird veranschaulicht, wie Sie den Konverter verwenden, um die Sichtbarkeit eines Label
-Steuerelements basierend auf der LayoutState
-Eigenschaft zu ändern, die in Button
Command
geändert wird.
XAML
Einbinden des XAML-Namespace
Um das Toolkit in XAML verwenden zu können, muss der folgende xmlns
-Abschnitt zu Ihrer Seite oder Ansicht hinzugefügt werden:
xmlns:toolkit="http://schemas.microsoft.com/dotnet/2022/maui/toolkit"
Der folgende Abschnitt:
<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>
Würde dann geändert werden, um xmlns
einzubinden:
<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>
Verwenden des StateToBooleanConverter
StateToBooleanConverter
kann wie folgt in XAML verwendet werden:
<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="CommunityToolkit.Maui.Sample.Pages.Converters.StateToBooleanConverterPage">
<ContentPage.Resources>
<ResourceDictionary>
<toolkit:StateToBooleanConverter x:Key="StateToBooleanConverter" StateToCompare="Success" />
</ResourceDictionary>
</ContentPage.Resources>
<VerticalStackLayout VerticalOptions="Center">
<Label
HorizontalOptions="Center"
IsVisible="{Binding LayoutState, Converter={StaticResource StateToBooleanConverter}}"
Text="The state is Success!"
VerticalOptions="Center" />
<Button Command="{Binding ChangeLayoutCommand}" Text="Change state" />
</VerticalStackLayout>
</ContentPage>
C#
StateToBooleanConverter
kann wie folgt in C# verwendet werden:
class StateToBooleanConverterPage : ContentPage
{
public StateToBooleanConverterPage()
{
var label = new Label
{
HorizontalOptions = LayoutOptions.Center,
Text = "The state is Success!",
VerticalOptions = LayoutOptions.Center
};
label.SetBinding(
Label.IsVisibleProperty,
new Binding(
static (ViewModel vm) => vm.LayoutState,
converter: new StateToBooleanConverter { StateToCompare = LayoutState.Success }));
var button = new Button
{
Text = "Change state"
};
button.SetBinding(
Button.CommandProperty,
nameof(ViewModel.ChangeLayoutCommand));
Content = new VerticalStackLayout
{
Children =
{
label,
button
}
};
}
}
C#-Markup
Das Paket CommunityToolkit.Maui.Markup
bietet eine viel präzisere Möglichkeit, diesen Konverter in C# zu verwenden.
using CommunityToolkit.Maui.Markup;
class StateToBooleanConverterPage : ContentPage
{
public StateToBooleanConverterPage()
{
Content = new VerticalStackLayout
{
Children =
{
new Label()
.Text("The state is Success!")
.CenterHorizontal()
.CenterVertical()
.Bind(
Label.IsVisibleProperty,
static (ViewModel vm) => vm.LayoutState,
converter: new StateToBooleanConverter { StateToCompare = LayoutState.Success }),
new Button()
.Text("Change state")
.BindCommand(static (ViewModel vm) => vm.ChangeLayoutCommand)
}
};
}
}
Beispiele
Ein Beispiel für diesen Konverter in Aktion finden Sie in der Beispielanwendung für das .NET MAUI Community Toolkit.
API
Sie finden den Quellcode für StateToBooleanConverter
über das GitHub-Repository für das .NET MAUI Community Toolkit.
.NET MAUI Community Toolkit