StateToBooleanConverter
Jest StateToBooleanConverter
to jeden ze sposobów konwerter, który zwraca boolean
wynik na podstawie tego, czy podana wartość jest określona LayoutState
.
Metoda Convert
zwraca boolean
wynik na podstawie tego, czy podana wartość jest określoną LayoutState
wartością . Wyliczenie LayoutState
jest udostępniane przez zestaw narzędzi i oferuje możliwe wartości:
None
Loading
Saving
Success
Error
Empty
Custom
Uwaga
Należy pamiętać, że oczekiwaną LayoutState
wartość można podać w następującej kolejności pierwszeństwa:
ConverterParameter
jako w powiązaniu konwerteraStateToCompare
; zastępuje to właściwośćStateToCompare
jako właściwość w konwerterze
Metoda nie jest obsługiwana ConvertBack
.
Właściwości obiektu BaseConverter
Następujące właściwości są implementowane w klasie bazowej: public abstract class BaseConverter
Właściwości | opis |
---|---|
DefaultConvertReturnValue |
Wartość domyślna, która ma być zwracana, gdy IValueConverter.Convert(object?, Type, object?, CultureInfo?) zgłasza wartość Exception . Ta wartość jest używana, gdy właściwość CommunityToolkit.Maui.Options.ShouldSuppressExceptionsInConverters jest ustawiona na true wartość . |
DefaultConvertBackReturnValue |
Wartość domyślna, która ma być zwracana, gdy IValueConverter.ConvertBack(object?, Type, object?, CultureInfo?) zgłasza wartość Exception . Ta wartość jest używana, gdy właściwość CommunityToolkit.Maui.Options.ShouldSuppressExceptionsInConverters jest ustawiona na true wartość . |
Właściwości ICommunityToolkitValueConverter
Następujące właściwości są implementowane w pliku public interface ICommunityToolkitValueConverter
:
Właściwość | Type | Opis |
---|---|---|
DefaultConvertReturnValue |
object? |
Wartość domyślna, która ma być zwracana, gdy IValueConverter.Convert(object?, Type, object?, CultureInfo?) zgłasza wartość Exception . Ta wartość jest używana, gdy właściwość CommunityToolkit.Maui.Options.ShouldSuppressExceptionsInConverters jest ustawiona na true wartość . |
DefaultConvertBackReturnValue |
object? |
Wartość domyślna, która ma być zwracana, gdy IValueConverter.ConvertBack(object?, Type, object?, CultureInfo?) zgłasza wartość Exception . Ta wartość jest używana, gdy właściwość CommunityToolkit.Maui.Options.ShouldSuppressExceptionsInConverters jest ustawiona na true wartość . |
Składnia
W poniższym przykładzie pokazano, jak za pomocą konwertera zmienić widoczność Label
kontrolki na LayoutState
podstawie właściwości zmodyfikowanej Button
Command
na obiekcie .
XAML
Dołączanie przestrzeni nazw XAML
Aby można było używać zestawu narzędzi w języku XAML, należy dodać następujące xmlns
elementy do strony lub widoku:
xmlns:toolkit="http://schemas.microsoft.com/dotnet/2022/maui/toolkit"
W związku z tym następujące elementy:
<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>
Zostanie zmodyfikowana tak, aby zawierała następujące xmlns
elementy:
<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>
Używanie elementu StateToBooleanConverter
Można StateToBooleanConverter
go użyć w następujący sposób w języku 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="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#
Można StateToBooleanConverter
go użyć w następujący sposób w języku C#:
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
}
};
}
}
Znaczniki języka C#
Nasz CommunityToolkit.Maui.Markup
pakiet zapewnia znacznie bardziej zwięzły sposób używania tego konwertera w języku C#.
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)
}
};
}
}
Przykłady
Przykład tego konwertera można znaleźć w aplikacji przykładowej zestawu narzędzi .NET MAUI Community Toolkit.
interfejs API
Kod źródłowy można StateToBooleanConverter
znaleźć w repozytorium GitHub zestawu narzędzi .NET MAUI Community Toolkit.
.NET MAUI Community Toolkit