我有一个CollectionViewSource
,其来源是ObservableCollection。
在List
或ObservableCollection
上,我可以使用linq对对象进行分组,并对它们的数量求和,但是如何在CollectionViewSource上做到这一点(如果可能),我在任何地方都看不到任何文档。
目前,我只能使用来管理分组:
ProductsView.GroupDescriptions.Add(new PropertyGroupDescription("Group"));
但是我看不到任何信息如何显示字段的总和或最大值/最小值?
编辑:
具体来说,我想做些等效的事情:
liste_ass = liste_ass.GroupBy(l => l.Name)
.Select(cl => new Assemblage
{
Quantite = cl.Sum(c => c.Quantite),
ID = 0,
IdAffaire = cl.First().IdAffaire,
Name = cl.First().Name,
Priorite = 0,
Dessin = cl.First().Dessin,
Groupe = cl.First().Groupe,
Priorite = cl.Max(c=>c.Priorite),
ListeIdOperations = cl.First().ListeIdOperations,
}).ToList();
这就是我在linq中要做的。 但是,在阅读有关ICollectionView的内容后,似乎无法在ICollectionView上执行此操作,因为它是一个视图,并且无法对其进行任何操作。
答案 0 :(得分:1)
您可以访问每个CollectionViewGroup
至ItemCount
属性,其中包含所有古尔普信息,包括CollectionView.Groups
。如果要创建自定义组标题并将其显示在UI上,请参考以下示例:
<ListBox ItemsSource="{Binding your view}">
<ListBox.Resources>
<local:ToAssemblageConverter x:Key="toAssemblageConverter"/>
</ListBox.Resources>
<ListBox.GroupStyle>
<GroupStyle HidesIfEmpty="True">
<GroupStyle.HeaderTemplate>
<DataTemplate>
<StackPanel Orientation="Horizontal"
DataContext="{Binding Items, Converter={StaticResource ResourceKey=toAssemblageConverter}}">
<TextBlock Margin="5 0" Text="{Binding Quantite}"/>
<TextBlock Margin="5 0" Text="{Binding Id}"/>
...
</StackPanel>
</DataTemplate>
</GroupStyle.HeaderTemplate>
</GroupStyle>
</ListBox.GroupStyle>
</ListBox>
public class ToAssemblageConverter : IValueConverter
{
public object Convert (object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
{
var cl = (IEnumerable)value;
return new Assemblage() {
Quantite = cl.Sum(c => c.Quantite),
ID = 0,
IdAffaire = cl.First().IdAffaire,
Name = cl.First().Name,
Priorite = 0,
Dessin = cl.First().Dessin,
Groupe = cl.First().Groupe,
Priorite = cl.Max(c=>c.Priorite),
ListeIdOperations = cl.First().ListeIdOperations,
}
}
}
答案 1 :(得分:1)
您可以使用DynamicData:
var sourceList = new SourceList<YourType>(); // use this instead of ObservableCollection
sourceList.Connect()
.AutoRefres(x => x.Quantite) // refresh when this property changes
.ToCollection()
.Select(col =>
col
.GroupBy(l => l.Name)
.Select(cl => new Assemblage
{
Quantite = cl.Sum(c => c.Quantite),
ID = 0,
IdAffaire = cl.First().IdAffaire,
Name = cl.First().Name,
Priorite = 0,
Dessin = cl.First().Dessin,
Groupe = cl.First().Groupe,
Priorite = cl.Max(c=>c.Priorite),
ListeIdOperations = cl.First().ListeIdOperations,
}).ToList()
)
.Subscribe(col => PublicPropertyWithChangeNotification = col);
当您在源列表中添加或删除项目时,item.Quantite
发生更改(如果它实现了INPC),它将自动更新结果