先上效果:
这是一个TreeView控件的效果。
控件的用法就不多说了,具体参考:
http://msdn.microsoft.com/zh-cn/library/vstudio/system.windows.forms.treeview(v=vs.100).aspx
其中,默认是没有图片的,当需要在每一个节点加图片时,首先需要设置图片列表,然后再引用。
具体操作如下:
1. 初始化图片列表
初始化图片列表的用处是,把图片加入到控件的ImageList属性列表中,以便每个树节点调用。
类似代码如下:
private void InitImageList()
{
treeView.ImageList = new ImageList();
treeView.ImageList.Images.Add("GdbSource", Resource.GdbSource);
treeView.ImageList.Images.Add("Database", Resource.GdbConnection16);
treeView.ImageList.Images.Add("FeatureEmpty", Resource.GdbFeatureClassEmpty16);
treeView.ImageList.Images.Add("FeatureLine", Resource.GdbFeatureClassLine16);
treeView.ImageList.Images.Add("FeaturePoint", Resource.GdbFeatureClassPoint16);
treeView.ImageList.Images.Add("FeaturePolygon", Resource.GdbFeatureClassPolygon16);
treeView.ImageList.Images.Add("Dataset", Resource.GdbFeatureDataset16);
}
Resource.***是引用的资源文件,你也可以引用文件夹路径文件,Add方法后面的参数是Image类型。
关于引用资源文件,参考:http://blog.csdn.net/zy332719794/article/details/8971154
2. 树节点引用图片
因为在第一步我们已经设置好了图片列表,下面我们只需要在添加树节点时,直接掉用就可以了
类似代码如下:
private void NodeAddFeatureClass(TreeNode node, IFeatureClass featureClass)
{
switch (featureClass.ShapeType)
{
case ESRI.ArcGIS.Geometry.esriGeometryType.esriGeometryPoint:
node.Nodes.Add("FeaturePoint", featureClass.AliasName, "FeaturePoint", "FeaturePoint");
break;
case ESRI.ArcGIS.Geometry.esriGeometryType.esriGeometryPolyline:
node.Nodes.Add("FeatureLine", featureClass.AliasName, "FeatureLine", "FeatureLine");
break;
case ESRI.ArcGIS.Geometry.esriGeometryType.esriGeometryPolygon:
node.Nodes.Add("FeaturePolygon", featureClass.AliasName, "FeaturePolygon", "FeaturePolygon");
break;
default:
node.Nodes.Add("FeatureEmpty", featureClass.AliasName, "FeatureEmpty", "FeatureEmpty");
break;
}
}
添加节点时,有以下几个方法
Add(String) --- 将具有指定标签文本的新树节点添加到当前树节点集合的末尾。
Add(TreeNode) ---将先前创建的树节点添加到树节点集合的末尾。
Add(String, String) ---指定节点KEY和显示文本。
Add(String, String, Int32) ---指定节点KEY,显示文本,图片编号
Add(String, String, String) ---指定节点KEY,显示文本,图片KEY
Add(String, String, Int32, Int32) ---指定节点KEY,显示文本,图片编号,选中时图片编号
Add(String, String, String, String) ---指定节点KEY,显示文本,图片编号,选中时图片KEY
3. 注意
(1) 我们在添加图片到 ImageList 的时候,可以选择不添加KEY的Add方法,但后面调用时,就必须用Add(String, String, Int32)或者Add(String, String, Int32, Int32)的方法添加树节点。
(2) 如果我们添加了图片列表,但在添加子节点时没有调用具体的图片,那么每个节点会默认添加上ImageList第一个(默认)图片。
(3) 如果添加树节点时,没有设置选中时(第四个参数)图片编号或key,那么会在选中时,图标会变成ImageList第一个(默认)图片。