WPF列表框按子串分组

时间:2013-03-19 20:29:18

标签: wpf listbox wpf-controls wpf-4.0

我的对象具有存储由分隔符分隔的更多字符串的属性。 我想在启用分组的WPF列表框中显示此类对象的列表。我需要的是根据子串创建组。

Object1:Property =“string1; string2; string3”

Object2:Property =“string2; string3”

我希望列表框显示如下:

字符串1

对象1

对象2

字符串2

对象1

STRING3

对象1

对象2

这可能吗?

感谢您的帮助。

1 个答案:

答案 0 :(得分:1)

创建一个包装类。

class MyGroup
{
 public string GroupID;
 public object SomeObject;
}

构建该包装类的平面列表。

private List<MyGroup> BuildItemsSourceTogether()
{
 List<MyGroup>itemsSource = new List<MyGroup>();
 foreach(var obj in myListWithObjectsWhichPropertiesAreStringsWhichFuthermoreContainSubstrings)
 {
   var stringArray = obj.Property123.Split(';');
   foreach(var str in stringArray)
   {
    itemsSource.Add(new MyGroup () { GroupID = str, SomeObject = obj});
   }
 }
 return itemsSource;
}

告诉您的包装器类中的哪个属性应该用于分组。

class Window1
{
  public Window1()
  {
    InitalizeComponents();
    var finalData = new ListCollectionView(BuildItemsSourceTogether());
    finalData.GroupDescriptions.Add(new PropertyGroupDescription("GroupID"));
    this.DataContext = finalData;
  }
}

在XAML中设置组的外观,让WPF为您分配那些平面的ID列表。

我在列中使用了DataGrid。您可以使用ListBox。

<DataGrid ItemsSource="{Binding}">
      <DataGrid.GroupStyle>
        <GroupStyle>
            <GroupStyle.HeaderTemplate>
                <DataTemplate>
                    <StackPanel>
                        <TextBlock Text="{Binding Path=Name}" />
                    </StackPanel>
                </DataTemplate>
            </GroupStyle.HeaderTemplate>
            <GroupStyle.ContainerStyle>
                <Style TargetType="{x:Type GroupItem}">
                    <Setter Property="Template">
                        <Setter.Value>
                            <ControlTemplate TargetType="{x:Type GroupItem}">
                                <Expander>
                                    <Expander.Header>
                                        <StackPanel Orientation="Horizontal">
                                          <TextBlock Text="{Binding Path=Name}" />
                                          <TextBlock Text="{Binding Path=ItemCount}"/>
                                          <TextBlock Text="Items"/>
                                        </StackPanel>
                                    </Expander.Header>
                                    <ItemsPresenter />
                                </Expander>
                            </ControlTemplate>
                        </Setter.Value>
                    </Setter>
                </Style>
            </GroupStyle.ContainerStyle>
        </GroupStyle>
    </DataGrid.GroupStyle>
    <DataGrid.Columns>
        <DataGridTextColumn Header="header1" Binding="{Binding SomeObject.Property321}" />
        <DataGridTextColumn Header="header2" Binding="{Binding SomeObject.Property678}" />
    </DataGrid.Columns>
</DataGrid>

玩得开心。