如何方便的让你的集合引发改变事件

简介:
在我们开发自定义 控件 的过程中,我们常常会给 控件 添加集合属性。比如定制Grid 控件 就会有Column集合。当集合属性发生变化时,比如添加新元素,删除新元素,我们要通知 控件 去重绘以反映新的变化。我们可以创建一个集合类,在类里添加一个新的事件,并在集合发生变化时触发事件。.Net框架已经为我们提供了现成的委托声明,下面我们来看看怎么使用。
      我创建一个名字叫HeaderCollection的类,派生于System.System.Collections.ObjectModel.Collection<ColumnHeader>。利用.Net已经声明的CollectionChangeEventHandler委托来声明一个事件,如下:      
public   delegate   void  CollectionChangeEventHandler (
 Object sender,
 CollectionChangeEventArgs e
)
CollecionChangeEventArgs的构造函数需要两个参数,一个枚举类型CollectionChangeAction,用它来指出发生了什么变化,包含添加,删除,整个集合发生变化三种动作,第二个参数传递发生变化的元素。
      接下来我们重载Collection<T>的几个方法:InsertItem,ClearItems,RemoveItem在这些方法里触发事件,下边是这个类的完整描述:
      
using  System;
using  System.Collections.Generic;
using  System.Text;
using  System.Collections;
using  System.Collections.ObjectModel;
using  System.ComponentModel;

namespace  CPI.DataProcess.Forms
{
[Serializable]
public class HeaderCollection:Collection<ColumnHeader>
{

public event CollectionChangeEventHandler ItemChanged;

public HeaderCollection()
{
}


protected override void InsertItem(int index, ColumnHeader item)

base.InsertItem(index, item);
ItemChanged(
this,new CollectionChangeEventArgs(CollectionChangeAction.Add,item));
}


protected override void ClearItems()
{
base.ClearItems();
ItemChanged(
thisnew CollectionChangeEventArgs(CollectionChangeAction.Refresh, null));
}


protected override void RemoveItem(int index)
{
base.RemoveItem(index);
ItemChanged(
thisnew CollectionChangeEventArgs(CollectionChangeAction.Remove, this[index]));
}


protected override void SetItem(int index, ColumnHeader item)

base.SetItem(index, item);
ItemChanged(
thisnew CollectionChangeEventArgs(CollectionChangeAction.Refresh, null));
}


private void OnItemPropertyChanged(Object sender)
{
ItemChanged(sender,
null);
}

}

}


这样我们的Collection就暴露出一个改变事件,在使用它的地方给它添加委托就可以了,例如:
   
public   void  OnCollectionPropertyChanged(Object sender,CollectionChangeEventArgs e)
{
Invalidate();
}

private  HeaderCollection _Headers  = new  HeaderCollection();
Headers.ItemChanged
+= new  CollectionChangeEventHandler(OnCollectionPropertyChanged);
      当集合属性发生变化时就会触发事件通知自定义 控件 重绘。





本文转自纶巾客博客园博客,原文链接:http://www.cnblogs.com/guanjinke/archive/2006/12/04/582094.html,如需转载请自行联系原作者
目录
相关文章
|
4月前
|
前端开发 开发者 数据格式
|
7月前
|
前端开发 JavaScript
如何处理用户的拖拽排序操作
这个示例展示了如何使用JavaScript处理HTML列表的拖拽排序。通过监听`dragstart`、`dragend`、`dragenter`、`dragleave`、`dragover`和`drop`事件,实现拖拽元素时的视觉反馈和元素位置交换。当用户拖放列表项时,相关事件触发,更新列表顺序,提供直观的交互体验。
|
JavaScript 前端开发
计算属性和监视属性的区别
计算属性和监视属性的区别
|
前端开发
前端学习笔记202305学习笔记第二十八天-数组结构之列表拖拽改变顺序4
前端学习笔记202305学习笔记第二十八天-数组结构之列表拖拽改变顺序4
44 0
|
7月前
|
JavaScript
【sgDrag】自定义组件:基于Vue开发支持批量声明拖拽元素、被碰撞元素,拖拽全过程监听元素碰撞检测并返回拖拽原始元素、克隆元素及其getBoundingClientRect对象和碰撞接触元素数组。
【sgDrag】自定义组件:基于Vue开发支持批量声明拖拽元素、被碰撞元素,拖拽全过程监听元素碰撞检测并返回拖拽原始元素、克隆元素及其getBoundingClientRect对象和碰撞接触元素数组。
|
前端开发
前端学习笔记202305学习笔记第二十八天-数组结构之列表拖拽改变顺序1
前端学习笔记202305学习笔记第二十八天-数组结构之列表拖拽改变顺序1
45 0
|
前端开发
前端学习笔记202305学习笔记第二十八天-数组结构之列表拖拽改变顺序3
前端学习笔记202305学习笔记第二十八天-数组结构之列表拖拽改变顺序3
56 0
|
前端开发
前端学习笔记202305学习笔记第二十八天-数组结构之列表拖拽改变顺序2
前端学习笔记202305学习笔记第二十八天-数组结构之列表拖拽改变顺序2
58 0
|
前端开发
【React工作记录三十八】对象的属性和值转换
【React工作记录三十八】对象的属性和值转换
75 0
改变状态和改变指定回调顺序的方法
改变状态和改变指定回调顺序的方法
84 0