VisualStateManager не работает с SelectionChanged в CollectionView на Xamarin Forms

#xaml #xamarin.forms #collectionview #visualstatemanager

#xaml #xamarin.forms #collectionview #visualstatemanager

Вопрос:

Когда я добавляю SelectionChanged функцию в представление коллекции, VisualStateManager не работает.

 <ContentPage.Resources>
    <Style TargetType="StackLayout">
        <Setter Property="VisualStateManager.VisualStateGroups">
            <VisualStateGroupList>
                <VisualStateGroup x:Name="CommonStates">
                    <VisualState x:Name="Normal" />
                    <VisualState x:Name="Selected">
                        <VisualState.Setters>
                            <Setter Property="BackgroundColor" Value="LightSkyBlue"/>
                        </VisualState.Setters>
                    </VisualState>
                </VisualStateGroup>
            </VisualStateGroupList>
        </Setter>
    </Style>
</ContentPage.Resources>
  

Когда я добавляю этот код в CollectionView : SelectionChanged="OnCollectionViewSelectionChanged" , VisualStateManager перестает работать. Кто-нибудь знает почему?

Ответ №1:

Проблема заключалась в том, что SelectionChanged не удалось получить выбранный тип элемента, подобный StackLayout или Label . Вы могли бы использовать TapGestureRecognizer вместо этого.

Xaml:

    <ContentPage.Resources>
    <Style TargetType="StackLayout">
        <Setter Property="VisualStateManager.VisualStateGroups">
            <VisualStateGroupList>
                <VisualStateGroup>
                    <VisualState x:Name="Selected">
                        <VisualState.Setters>
                            <Setter Property="BackgroundColor" Value="Accent" />
                        </VisualState.Setters>
                    </VisualState>
                    <VisualState x:Name="UnSelected">
                        <VisualState.Setters>
                            <Setter Property="BackgroundColor" Value="Blue" />
                        </VisualState.Setters>
                    </VisualState>
                </VisualStateGroup>
            </VisualStateGroupList>
        </Setter>
    </Style>
</ContentPage.Resources>
<ContentPage.Content>
    <StackLayout
        Padding="10"
        HorizontalOptions="FillAndExpand"
        VerticalOptions="FillAndExpand">
        <CollectionView
            x:Name="MenuCollection"
            ItemsSource="{Binding Infos}"
            SelectionChanged="MenuCollection_OnSelectionChanged"
            SelectionMode="Single"
            VerticalScrollBarVisibility="Always">

            <CollectionView.ItemsLayout>
                <GridItemsLayout
                    HorizontalItemSpacing="15"
                    Orientation="Vertical"
                    Span="2"
                    VerticalItemSpacing="15" />
            </CollectionView.ItemsLayout>

            <CollectionView.ItemTemplate>
                <DataTemplate>

                    <StackLayout BackgroundColor="Blue">
                        <Label Text="{Binding Title}" />
                        <StackLayout.GestureRecognizers>
                            <TapGestureRecognizer Tapped="TapGestureRecognizer_Tapped" />
                        </StackLayout.GestureRecognizers>
                    </StackLayout>

                </DataTemplate>
            </CollectionView.ItemTemplate>
        </CollectionView>
    </StackLayout>
</ContentPage.Content>
  

Код, лежащий в основе:

  public partial class Page4 : ContentPage
{
    public ObservableCollection<Info> Infos { get; set; }
    public Page4()
    {
        InitializeComponent();
        Infos = new ObservableCollection<Info>
    {
        new Info(){ Title="A"},
        new Info(){ Title="B"},
        new Info(){ Title="B"},
        new Info(){ Title="C"},
        new Info(){ Title="D"}
    };

        this.BindingContext = this;
    }
    StackLayout lastElementSelected;
    private void MenuCollection_OnSelectionChanged(object sender, SelectionChangedEventArgs e)
    {      

     

    }

    private void TapGestureRecognizer_Tapped(object sender, EventArgs e)
    {

        if (lastElementSelected != null)
            VisualStateManager.GoToState(lastElementSelected, "UnSelected");

        VisualStateManager.GoToState((StackLayout)sender, "Selected");

        lastElementSelected = (StackLayout)sender;
    }
}
public class Info
{
    public string Title { get; set; }
}
  

Скриншот:

введите описание изображения здесь