Dev TreeList 添加节点图标问题

1. 在设计界面添加imageCollection控件,在属性页设置图标(可Load from disk,也可从Load from dev gallery)

2. TreeList控件有一个叫做CustomDrawNodeImages 的事件,双击该事件编写后台代码。

3. 添加节点图标需要用到TreeList 的SelectImageList属性,该属性是指当节点被选中时显示的图标(相应的还有另外两个ColumnImageList和StateImageList属性)

4. 最开始思考这个问题是,我是这样想的,如果是叶子节点的话显示图标3,否则对于非叶子结点,若展开了显示图标2,未展开显示图标1。

方法一代码如下:

            if (e.Node.Nodes.Count > 0)
            {
                if (e.Node.Expanded)
                {
                    e.SelectImageIndex = 2;
                    return;
                }
                e.SelectImageIndex = 1;
            }
            else
            {
                e.SelectImageIndex = 3;
            }

 5. 我的需求是一个六层的导航树,后来又想让每一层的结点图标都不一样,于是又想到了第二种方法,这个方法用到了结点的level属性,它代表当前节点所在的层数。这样可以根据当前level的不同来给每一层节点添加图标。

        //方法1:node.level 代表当前节点所在的层数,借此可以实现给每一层节点添加不同的图标
            switch (e.Node.Level)
            {
                case 0:
                    e.SelectImageIndex = 0;
                    break;
                case 1:
                case 2:
                case 3:
                case 4:
                    if (e.Node.Expanded)
                    {
                        e.SelectImageIndex = 2;
                    }
                    else
                    {
                        e.SelectImageIndex = 1;
                    }
                    break;
                case 5:
                    e.SelectImageIndex = 3;
                    break;
                default:
                    break;
            }

猜你喜欢

转载自www.cnblogs.com/Alex1994/p/9849961.html
Dev