C#中TreeView树配图片

简介: 版权声明:欢迎评论和转载,转载请注明来源。 https://blog.csdn.net/zy332719794/article/details/9013691 先上效果:这是一个TreeView控件的效果。
版权声明:欢迎评论和转载,转载请注明来源。 https://blog.csdn.net/zy332719794/article/details/9013691

先上效果:


这是一个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第一个(默认)图片。







相关文章
|
10月前
|
C# 数据库
40.c#:TreeView 控件
40.c#:TreeView 控件
94 1
|
6月前
|
数据采集 JavaScript C#
C#图像爬虫实战:从Walmart网站下载图片
C#图像爬虫实战:从Walmart网站下载图片
C#WPF 图片在显示时没有问题,但在运行时图片显示不出来的解决
选中项目,点击右上角的显示全部文件按钮,会将默认隐藏的文件显示出来,选中所需图片,右键,添加到项目,然后选择图片查看属性,生成操作选择resource。完毕。本人目前的解决方案。
586 41
C#WPF 图片在显示时没有问题,但在运行时图片显示不出来的解决
|
10月前
|
SQL 存储 C#
C# Web控件与数据感应之 TreeView 类
C# Web控件与数据感应之 TreeView 类
|
10月前
|
存储 算法 C#
C# 生成指定图片的缩略图
C# 生成指定图片的缩略图
|
10月前
|
C# 开发工具 数据安全/隐私保护
C# 给图片添加文字水印
C# 给图片添加文字水印
|
10月前
|
开发框架 .NET C#
C# 自动填充文字内容到指定图片
C# 自动填充文字内容到指定图片
|
10月前
|
API C# 数据安全/隐私保护
C# 实现网页内容保存为图片并生成压缩包
C# 实现网页内容保存为图片并生成压缩包
|
10月前
|
存储 C# 开发者
C# | 通过反射将对象属性展示在TreeView中
在编程过程中,我们经常需要处理复杂的对象和数据结构。将这些数据结构展示在UI界面上是很有用的,可以帮助开发者更好地理解和分析数据。 而TreeView作为一种常见的控件,可以以树状结构的方式展示数据,非常适合用于展示层次化的对象。 本文将介绍如何使用TreeView控件展示一个对象,并且可以动态处理对象中的属性和子对象。通过本文的学习,您将学会如何更好地理解和展示数据,提高编程效率。
90 0
C# | 通过反射将对象属性展示在TreeView中