0

如何在弹性树组件上指示访问历史记录?我想将点击/访问过的节点突出显示为不同的颜色,之后不会改变,这样所有访问过的节点都将是一种颜色。

我尝试通过

var selected:XML=app.treeObj.selectedItem as XML;
if(!selected.hasOwnProperty("visited"))
{
    selected.@visited = "true";

}

并为树有一个 itemrenderer,如下所示。

public class CustomTreeItemRenderer extends TreeItemRenderer
    {
        public function CustomTreeItemRenderer()
        {
            super();
        }

        override public function set data(value:Object):void
        {
            if(value !=null)
            {

                super.data = value;
                if(value.@visited=="true")
                {
                    setStyle("color", 0x000000);
                }

                invalidateDisplayList()

            }
        }

    }

此代码确实保留了新颜色,但它也更改了根本未访问的节点的颜色。我在这里做错了什么?有没有更好的方法来实现这一目标?

维平

4

1 回答 1

2

在您设置的数据中,如果未访问,则需要将样式设置回原始样式,否则当渲染器被回收到未访问的节点时,它会保留已访问的颜色。

尝试...

override public function set data(value:Object):void
    {
            if(value !=null)
            {

                    super.data = value;
                    if(value.@visited=="true")
                    {
                            setStyle("color", 0x000000);
                    } 
                    else 
                    {
                            setStyle("color", originalColor);
                    }

                    invalidateDisplayList()

            }
    }

不是最有效的方法(即使您不需要设置颜色,并且 setStyle 是一项昂贵的操作),但它会起作用。

于 2009-10-26T07:50:07.897 回答