Отредактировано:Я создал новое приложение VS2010 WPF всего с 3 файлами MainWindow.xaml, MainWindow.xaml.cs и MainWindowViewModel.cs(Перечисленные ниже ). Если кто-то чувствует себя действительно полезным, вы можете воссоздать проблему за несколько секунд (копировать/вставить). Когда вы запустите приложение, DataGrid отобразит неверную строку «OldCollection». Если вы измените привязку ItemsSource на MyCollection, она отобразит «NewCollection», что является правильным.
Полное описание: Сначала у меня был DataGrid с его ItemsSource, привязанным к MyCollection. У меня есть/нужен метод UpdateCollection, который присваивает MyCollection новый ObservableCollection<>. С добавлением NotifyPropertyChange в MyCollection обновляется пользовательский интерфейс.
Затем стало необходимо ввести CollectionViewSource, чтобы включить группировку. Теперь, когда пользовательский интерфейс привязан к MyCollectionView, вызовы UpdateCollection не имеют никакого эффекта. Отладчик подтверждает, что MyCollectionView всегда содержит начальную коллекцию MyCollection. Как я могу заставить свою NewCollection отражаться в представлении? Я пробовал View.Refresh(), Binding CollectionViewSource и множество других стратегий.
Примечание:В первую очередь другие касаются изменений в элементах коллекции, не обновляющих вид (группировки/сортировки)без вызова Refresh. Моя проблема в том, что я назначаю новую коллекцию CollectionViewSource, и представление/пользовательский интерфейс никогда не меняется.
// MainWindow.xaml
<Window x:Class="CollectionView.MainWindow"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
Title="MainWindow" Height="350" Width="525">
<Grid>
<DataGrid Name="grid" ItemsSource="{Binding MyCollectionView}" />
</Grid>
</Window>
//MainWindow.xaml.cs
using System;
using System.Collections.Generic;
using System.Linq;
using System.Windows;
namespace CollectionView
{
/// <summary>
/// Interaction logic for MainWindow.xaml
/// </summary>
public partial class MainWindow : Window
{
public MainWindow()
{
InitializeComponent();
DataContext = new MainWindowViewModel();
}
}
}
//MainWindowViewModel.cs:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Collections.ObjectModel;
using System.Windows.Data;
using System.ComponentModel;
namespace CollectionView
{
class MainWindowViewModel : INotifyPropertyChanged
{
public MainWindowViewModel()
{
MyCollection = new ObservableCollection<MyObject>() { new MyObject() { TestString = "OldCollection" } };
MyCollectionViewSource = new CollectionViewSource();
// Bind CollectionViewSource.Source to MyCollection
Binding MyBind = new Binding() { Source = MyCollection };
BindingOperations.SetBinding(MyCollectionViewSource, CollectionViewSource.SourceProperty, MyBind);
// The DataGrid is bound to this ICollectionView
MyCollectionView = MyCollectionViewSource.View;
// This assignment here to demonstrate that View/UI does not update to show "NewCollection"
MyCollection = new ObservableCollection<MyObject>() { new MyObject() { TestString = "NewCollection" } };
}
// Collection Property
// NotifyPropertyChanged added specifically to notify of MyCollection re-assignment
ObservableCollection<MyObject> _MyCollection;
public ObservableCollection<MyObject> MyCollection
{
get { return _MyCollection; }
set
{
if (value != _MyCollection)
{
_MyCollection = value;
NotifyPropertyChanged("MyCollection");
}
}
}
public CollectionViewSource MyCollectionViewSource { get; private set; }
public ICollectionView MyCollectionView { get; private set; }
// Method updates MyCollection itself (Called via ICommand from another ViewModel)
public void UpdateCollection(ObservableCollection<MyObject> NewCollection)
{
MyCollection = NewCollection;
}
public event PropertyChangedEventHandler PropertyChanged;
private void NotifyPropertyChanged(String info)
{
if (PropertyChanged != null)
{
PropertyChanged(this, new PropertyChangedEventArgs(info));
}
}
}
class MyObject
{
public string TestString { get; set; }
}
}
Спасибо,