在 WPF 中使用扩展器创建全部展开和折叠所有按钮

Creating an Expand All and Collapse All Buttons with Expander in WPF

我在 Visual Studio 2013 年在 WPF (C#) 中工作,我有以下代码从我的 xml 创建一个扩展器。它目前运行良好,但我想包括一个展开所有和折叠所有按钮。我找遍了,似乎找不到解决办法。

这里是创建扩展器的地方。我知道我只需要遍历项目列表并将 属性="IsExpanded" 更改为 Value="True" 以创建全部展开。

       <DataTemplate x:Key="dtListTemplate" >
            <StackPanel>
                <Expander LostFocus="CollapseExpander" ExpandDirection="Down" Width="Auto">
                    <Expander.Style>
                        <Style TargetType="Expander">
                            <Setter Property="IsExpanded" Value="False" />
                            <Setter Property="Header" Value="{Binding XPath=@Name}" />
                            <Setter Property="FontWeight" Value="Bold"/>

                            <Style.Triggers>
                                <DataTrigger Binding="{Binding IsExpanded,RelativeSource={RelativeSource Self}}" Value="True">
                                </DataTrigger>
                            </Style.Triggers>
                        </Style>
                    </Expander.Style>
                    <ListBox Name="itemsList"
                        ItemsSource="{Binding XPath=UpgradeAction}"
                        ItemTemplate="{StaticResource dtListItemTemplate}"
                        SelectionChanged="listItems_SelectionChanged"
                        Style="{StaticResource styleListBoxUpgradeAction}"
                        ItemContainerStyle="{StaticResource styleListBoxItemUpgradeAction}">
                    </ListBox>
                </Expander>
            </StackPanel>
        </DataTemplate>

这是调用 DataTemplate 的代码,其中包含来自 Xml 的信息。

<StackPanel>
        <StackPanel Orientation="Horizontal" HorizontalAlignment="Right">
            <Border Grid.Column="0" Grid.Row="0" Width="790" Height="40" Padding="5" Background="#4E87D4">
                <Label VerticalAlignment="Center" FontSize="16" FontWeight="Bold" Foreground="White">Test</Label>
            </Border>
            <Button Name="ExpandBttn" Width="100" Height="40" FontSize="16" FontWeight="Bold" Content="Expand All" DataContext="{Binding}" Click="Expand_Button_Click"/>
            <Button Name="ColapseBttn" Width="100" Height="40" FontSize="16" FontWeight="Bold" Content="Colapse All" DataContext="{Binding}" Click="Collapse_Button_Click"/>
        </StackPanel>
        <ListView Name="listItems" Grid.Column="0" Grid.Row="1" Background="Wheat"
             ItemsSource="{Binding Source={StaticResource xmldpUpgradeActions}, XPath=ActionGroup}"
             ItemTemplate="{StaticResource dtListTemplateRichards}"
             SelectionChanged="listItems_SelectionChanged">
        </ListView>
    </StackPanel>

这是我在 .cs 文件中尝试展开所有部分的内容。

  private void Expand_Button_Click(object sender, RoutedEventArgs e)
  {
      foreach(var item in listItems.Items)
      {
          var listBoxItem = listItems.ItemContainerGenerator.ContainerFromItem(item) as ListBoxItem;
          var itemExpander = (Expander)GetExpander(listBoxItem);
          if (itemExpander != null)
              itemExpander.IsExpanded = true;
      }
  }

  private static DependencyObject GetExpander(DependencyObject container)
  {
      if (container is Expander) return container;

      for (var i = 0; i < VisualTreeHelper.GetChildrenCount(container); i++)
      {
          var child = VisualTreeHelper.GetChild(container, i);

          var result = GetExpander(child);
          if (result != null)
          {
              return result;
          }
      }

      return null;
  }

非常感谢任何帮助!

xmldpUpgradeActions 是 CollectionViewSource 吗?

集合中的任何 class 都应该实现 INotifyPropertyChanged

给它一个 IsExpanded 属性 ,当它的值改变时在它的 setter 中引发 PropertyChanged ,并将其绑定到模板中的 Expander.IsExpanded

<Expander 
    IsExpanded="{Binding IsExpanded}"
    LostFocus="CollapseExpander" 
    ExpandDirection="Down" 
    Width="Auto">

编写一个循环遍历集合中所有项目并在每个项目上设置 item.IsExpanded = false; 的命令。