其他分享
首页 > 其他分享> > DevExpress--TreeList节点添加图片

DevExpress--TreeList节点添加图片

作者:互联网

这个过程相对来说比较简单,网上也有不少资料,但是自己在做过之后为了记住,算是给自己写一个博客吧。

下面直接上具体的流程

1、前提

控件使用的都是DevExpress和winform的原生控件两种;

2、所需界面控件

在界面上需要添加两个控件:一是DevExpress的Treelist树,二是winform的imagelist(或者使用DevExpress的imagecollection也可以)

3、为imagelist添加图片

因为是树结构目录的节点图片,因此大小一般要求是16x16的。将需要使用的图片添加到imagelist中。

在这里需要注意的是,如果中途删除了图片,一定要重新确认imagelist中剩余图片的索引,因为imagelist删除图片后会自动变更剩余图片的索引。

4、treelist属性设置

找到treelist控件的SelectImageList属性,将刚刚建立好的imagelist绑定到这个属性上;

5、treelist事件绑定

找到treelist的CustomDrawNodeImages事件,双击建立事件执行方法并添加控制代码:

private void treeList1_CustomDrawNodeImages(object sender, DevExpress.XtraTreeList.CustomDrawNodeImagesEventArgs e)
        {
            //如果有子节点,那么需要根据节点是否展开的状态赋值不同的图片;从而实现节点的展开和关闭是不同图片的功能
            if (e.Node.HasChildren)
                if (e.Node.Expanded)
                    e.SelectImageIndex = 1;
                else
                    e.SelectImageIndex = 0;
            else
                e.SelectImageIndex = 2;
        }

方法中的具体控制代码可以根据需要来实际确认。另外,其中imageIndex的数值就是第三步中imagelist中需要使用的节点图片的索引值。

同时,在非叶子节点的状态下增加是否展开状态的判断,可以实现节点在打开和关闭的不同状态下是不同图片的功能。

**注意**:必须使用SelectImageIndex这个参数,而不能使用e.Node.ImageIndex的方式赋值(此时会出现“集合已修改;可能无法执行枚举操作”的错误,但是目前不理解为什么为出现这个问题,暂时先记住正确的使用方式吧)。

6、结果

经过以上步骤,在程序运行起来后,树节点就会绑定上指定的图片;同时实现节点的打开和关闭状态图标变化的功能。

标签:控件,DevExpress,SelectImageIndex,TreeList,imagelist,节点,图片
来源: https://www.cnblogs.com/qingtian-jlj/p/10679801.html