WPF访问的DependencyObject一个CollectionChanged事件

问题描述:

我有结合了2个DepedenciyProperties的值的用户控制内:WPF访问的DependencyObject一个CollectionChanged事件

INT numberPeople成分列出<>

我想在这些值的更新以重做组合。 我目前的实现使用一个静态变量来跟踪对象实例(objectInstance)。我想知道是否有更干净的方法来做到这一点。

private static DependencyObject objectInstance; 

    public int numberPeople 
    { 
     get { return (int)GetValue(numberPeopleProperty); } 
     set { SetValue(numberPeopleProperty, value); } 
    } 
    public static readonly DependencyProperty numberPeopleProperty = 
     DependencyProperty.Register("numberPeople", typeof(int), typeof(ListDisplayer), new PropertyMetadata(0, Combine)); 


    public ObservableCollection<ListModel> ingredients 
    { 
     get { return (ObservableCollection<ListModel>)GetValue(ingredientsProperty); } 
     set { SetValue(ingredientsProperty, value); } 
    } 
    public static readonly DependencyProperty ingredientsProperty = 
     DependencyProperty.Register("ingredients", typeof(ObservableCollection<ListModel>), typeof(ListDisplayer), new PropertyMetadata(null, AssignCollectionChangedToList)); 
    private static void AssignCollectionChangedToList(DependencyObject d, DependencyPropertyChangedEventArgs e) 
    { 
     var instance = d as ListDisplayer; 
     if (e.OldValue != null) 
     { 
      var coll = (INotifyCollectionChanged)e.OldValue; 
      coll.CollectionChanged -= ItemsSource_CollectionChanged; 
     } 

     if (e.NewValue != null) 
     { 
      instance.ItemsSource = (ObservableCollection<ListModel>)e.NewValue; 
      objectInstance = instance; 
      instance.ItemsSource.CollectionChanged += ItemsSource_CollectionChanged; 
     } 
    } 

    private static void ItemsSource_CollectionChanged(object sender, NotifyCollectionChangedEventArgs e) 
    { 
     // MY PROBLEM: when a new item is added in this list trigger again Combine(), is there 
     // another way to trigger the Combine so that it will process the IngredientList and numberPeople attached to the object ? 
     Combine(objectInstance, new DependencyPropertyChangedEventArgs()); 

    } 




    private static void Combine(DependencyObject d, DependencyPropertyChangedEventArgs e) 
    { 
     // process numberPeople and ingredientList 
    } 

编辑:ItemsSource_CollectionChanged事件处理程序的定义中删除了static关键字和使用“实例”引用它挂:

private static void AssignCollectionChangedToList(DependencyObject d, DependencyPropertyChangedEventArgs e) 
{ 
    var instance = d as ListDisplayer; 
    if (e.OldValue != null) 
    { 
     var coll = (INotifyCollectionChanged)e.OldValue; 
     coll.CollectionChanged -= instance.ItemsSource_CollectionChanged; 
    } 

    if (e.NewValue != null) 
    { 
     instance.ingredients = (ObservableCollection<ListModel>)e.NewValue; 
     objectInstance = instance; 
     instance.ingredients.CollectionChanged += instance.ItemsSource_CollectionChanged; 
    } 
} 

private void ItemsSource_CollectionChanged(object sender, NotifyCollectionChangedEventArgs e) 
{ 
    Combine(this, new DependencyPropertyChangedEventArgs()); 
} 

而且你的依赖属性的CLR包装器没有正确实施。您应该将依赖项属性传递给GetValue和SetValue方法:

public int numberPeople 
{ 
    get { return (int)GetValue(numberPeopleProperty); } 
    set { SetValue(numberPeopleProperty, value); } 
} 
public static readonly DependencyProperty numberPeopleProperty = 
    DependencyProperty.Register("numberPeople", typeof(int), typeof(ListDisplayer), new PropertyMetadata(0, Combine)); 


public ObservableCollection<ListModel> ingredients 
{ 
    get { return (ObservableCollection<ListModel>)GetValue(ingredientsProperty); } 
    set { SetValue(ingredientsProperty, value); } 
} 
public static readonly DependencyProperty ingredientsProperty = 
    DependencyProperty.Register("ingredients", typeof(ObservableCollection<ListModel>), typeof(ListDisplayer), new PropertyMetadata(null, AssignCollectionChangedToList)); 
+0

更新了代码以及代码中的注释。注释现在位于方法ItemsSource_CollectionChanged中。希望我已经设法很好地解释我这个问题是什么。 –