为了增加 TreeView 控件的美观,设置了 TreeView 控件的 ImageList,实现每个节点都绑定一个 Image。因为多个地方都是这样,将 TreeView 控件放在自定义控件中,从而避免了重复代码。
namespace ControlLibs
{
public partial class TreeViewPro : UserControl
{
public TreeViewPro()
{
InitializeComponent();
}
// 其它代码
private void InitializeComponent()
{
this.components = new System.ComponentModel.Container();
this.treeView1 = new System.Windows.Forms.TreeView();
this.imageList1 = new System.Windows.Forms.ImageList(this.components);
// ...
}
}
}
但因为 TreeView 的 AfterSelect 事件 和 BeforeSelection 事件要在 UI 中调用,因为逻辑各自不同。这样就有一个需求,在 TreeViewPro 的实例中需要能访问到 TreeView 控件的事件。不知为什么,网上介绍该内容的材料特别少。其实还是蛮简单的,微软很贴心。首先定义两个 event:
public event TreeViewCancelEventHandler BeforeSelect
{
add { treeView1.BeforeSelect += value; }
remove { treeView1.BeforeSelect -= value; }
}
public event TreeViewEventHandler AfterSelect
{
add { treeView1.AfterSelect += value; }
remove { treeView1.AfterSelect -= value; }
}
注意这两个 event 的类型需要与 TreeView 控件的事件类型保持一致。这样,在 UI 中,TreeViewPro 控件就有了 BeforeSelect 事件和 AfterSelect 事件,如下图:
在这里可以编写代码,实现 TreeView 节点选中时的功能。