flex4 mx|Tree - 当我折叠和展开项目时项目顺序发生变化

发布于 2024-10-19 14:17:50 字数 3756 浏览 4 评论 0原文

使用 Flex 4.1,我尝试使用自定义 ItemRenderer (MXTreeItemRenderer) 创建一个 Tree 元素。我的问题是,每当我折叠和展开根项目时,项目的顺序都会发生变化..这很奇怪,就像 XML 格式不正确一样。

有什么想法吗?

我的 Main.mxml 文件:

<?xml version="1.0" encoding="utf-8"?>
<s:Application xmlns:fx="http://ns.adobe.com/mxml/2009" 
           xmlns:s="library://ns.adobe.com/flex/spark" 
           xmlns:mx="library://ns.adobe.com/flex/mx" minWidth="955" minHeight="600">

<!-- Launch your application by right clicking within this class and select Debug As > FDT SWF Application -->

<fx:Declarations>
 <fx:XML id="moshe">
 <notifications>
     <root label="a" state="root_item">
      <node state="item" label="moshe"/>
      <node state="item" label="moshe"/>
     </root>
   <root label="b" state="root_item"/>
   <root label="c" state="root_item"/>
   <root label="d" state="root_item"/>
   <root label="e" state="root_item"/>
  </notifications>
    </fx:XML>
</fx:Declarations>  
<mx:Tree dataProvider="{moshe}"  width="500" itemRenderer="TheRenderer" labelField="@label" showRoot="false" folderClosedIcon="{null}" defaultLeafIcon="{null}"
     folderOpenIcon="{null}" />
</s:Application>

和我的项目渲染器:

<?xml version="1.0" encoding="utf-8"?>
<s:MXTreeItemRenderer xmlns:fx="http://ns.adobe.com/mxml/2009"
                  xmlns:s="library://ns.adobe.com/flex/spark"
                  xmlns:mx="library://ns.adobe.com/flex/mx">

<s:states>
    <s:State name="normal" basedOn="{data.@state}"/>
    <s:State name="hovered" basedOn="{data.@state}"/>
    <s:State name="selected" basedOn="{data.@state}"/>
    <s:State name="root_item"/>            
    <s:State name="item" />
</s:states>

<fx:Script>
    <![CDATA[
        import com.flexer.Debug;
        import mx.controls.Alert;

     override public function set data(value:Object):void {
        super.data = value;
        if(treeListData.hasChildren)
        {

            setStyle("color", 0xff0000);
            setStyle("fontWeight", 'bold');
        }
        else
        {
            setStyle("color", 0x000000);
            setStyle("fontWeight", 'normal');
        }  
    }

 // Override the updateDisplayList() method 
    // to set the text for each tree node.      
    override protected function updateDisplayList(unscaledWidth:Number, 
        unscaledHeight:Number):void {

        super.updateDisplayList(unscaledWidth, unscaledHeight);
        if(super.data)
        {
            if(treeListData.hasChildren)
            {
                var tmp:XMLList = 
                    new XMLList(treeListData.item);
                var myStr:int = tmp[0].children().length();
                this.labelField.text= super.data.@label + " (" + myStr.toString() + ")";
            }
        }

    }


    ]]>
</fx:Script>

<s:HGroup left="0" right="0" top="0" bottom="0" verticalAlign="middle" includeIn="root_item">
    <s:Rect id="indentationSpacer" width="{treeListData.indent}" percentHeight="100" alpha="0">
        <s:fill>
            <s:SolidColor color="0xFFFFFF" />
        </s:fill>
    </s:Rect>
    <s:Group id="disclosureGroup">
        <s:BitmapImage source="{treeListData.disclosureIcon}" visible="{treeListData.hasChildren}" />
    </s:Group>
    <s:BitmapImage source="{treeListData.icon}" />
    <s:Label id="labelField" text="{treeListData.label}" paddingTop="2"/>
</s:HGroup> 

<s:HGroup includeIn="item">
    <s:Label text="{treeListData.label}"/>
 </s:HGroup>


</s:MXTreeItemRenderer>

Using Flex 4.1, i'm trying to create a Tree element with a custom ItemRenderer (MXTreeItemRenderer). my problem is that whenever I fold and unfold a root item, the order of the items change.. it's weird like maybe the XML is not formatted properly.

any ideas?

my Main.mxml file:

<?xml version="1.0" encoding="utf-8"?>
<s:Application xmlns:fx="http://ns.adobe.com/mxml/2009" 
           xmlns:s="library://ns.adobe.com/flex/spark" 
           xmlns:mx="library://ns.adobe.com/flex/mx" minWidth="955" minHeight="600">

<!-- Launch your application by right clicking within this class and select Debug As > FDT SWF Application -->

<fx:Declarations>
 <fx:XML id="moshe">
 <notifications>
     <root label="a" state="root_item">
      <node state="item" label="moshe"/>
      <node state="item" label="moshe"/>
     </root>
   <root label="b" state="root_item"/>
   <root label="c" state="root_item"/>
   <root label="d" state="root_item"/>
   <root label="e" state="root_item"/>
  </notifications>
    </fx:XML>
</fx:Declarations>  
<mx:Tree dataProvider="{moshe}"  width="500" itemRenderer="TheRenderer" labelField="@label" showRoot="false" folderClosedIcon="{null}" defaultLeafIcon="{null}"
     folderOpenIcon="{null}" />
</s:Application>

and my Item Renderer:

<?xml version="1.0" encoding="utf-8"?>
<s:MXTreeItemRenderer xmlns:fx="http://ns.adobe.com/mxml/2009"
                  xmlns:s="library://ns.adobe.com/flex/spark"
                  xmlns:mx="library://ns.adobe.com/flex/mx">

<s:states>
    <s:State name="normal" basedOn="{data.@state}"/>
    <s:State name="hovered" basedOn="{data.@state}"/>
    <s:State name="selected" basedOn="{data.@state}"/>
    <s:State name="root_item"/>            
    <s:State name="item" />
</s:states>

<fx:Script>
    <![CDATA[
        import com.flexer.Debug;
        import mx.controls.Alert;

     override public function set data(value:Object):void {
        super.data = value;
        if(treeListData.hasChildren)
        {

            setStyle("color", 0xff0000);
            setStyle("fontWeight", 'bold');
        }
        else
        {
            setStyle("color", 0x000000);
            setStyle("fontWeight", 'normal');
        }  
    }

 // Override the updateDisplayList() method 
    // to set the text for each tree node.      
    override protected function updateDisplayList(unscaledWidth:Number, 
        unscaledHeight:Number):void {

        super.updateDisplayList(unscaledWidth, unscaledHeight);
        if(super.data)
        {
            if(treeListData.hasChildren)
            {
                var tmp:XMLList = 
                    new XMLList(treeListData.item);
                var myStr:int = tmp[0].children().length();
                this.labelField.text= super.data.@label + " (" + myStr.toString() + ")";
            }
        }

    }


    ]]>
</fx:Script>

<s:HGroup left="0" right="0" top="0" bottom="0" verticalAlign="middle" includeIn="root_item">
    <s:Rect id="indentationSpacer" width="{treeListData.indent}" percentHeight="100" alpha="0">
        <s:fill>
            <s:SolidColor color="0xFFFFFF" />
        </s:fill>
    </s:Rect>
    <s:Group id="disclosureGroup">
        <s:BitmapImage source="{treeListData.disclosureIcon}" visible="{treeListData.hasChildren}" />
    </s:Group>
    <s:BitmapImage source="{treeListData.icon}" />
    <s:Label id="labelField" text="{treeListData.label}" paddingTop="2"/>
</s:HGroup> 

<s:HGroup includeIn="item">
    <s:Label text="{treeListData.label}"/>
 </s:HGroup>


</s:MXTreeItemRenderer>

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

謌踐踏愛綪 2024-10-26 14:17:50

感谢 David Goshadze 的评论,我能够解决这个问题。

这是我的新 XML:

<notifications>
 <root label="a">
  <item label="moshe"/>
  <item label="moshe2"/>
 </root>
 <root label="b" />
 <root label="c" />
 <root label="d" />
<root label="e" />
</notifications>

这是我的新渲染器:

<?xml version="1.0" encoding="utf-8"?>
<s:MXTreeItemRenderer xmlns:fx="http://ns.adobe.com/mxml/2009"
                  xmlns:s="library://ns.adobe.com/flex/spark"
                  xmlns:mx="library://ns.adobe.com/flex/mx">

<s:states>
    <s:State name="normal"/>
    <s:State name="hovered"/>
    <s:State name="selected"/>
</s:states>

<fx:Script>
    <![CDATA[
        import com.flexer.Debug;
        import mx.controls.Alert;

     override public function set data(value:Object):void {
        super.data = value;
        if (super.data) {
            if(treeListData.hasChildren)
            {

                setStyle("color", 0xff0000);
                setStyle("fontWeight", 'bold');
            }
            else
            {
                setStyle("color", 0x000000);
                setStyle("fontWeight", 'normal');
            }  

        } 
    }


override protected function createChildren():void

{

super.createChildren();



}       
// Override the updateDisplayList() method 
    // to set the text for each tree node.      
    override protected function updateDisplayList(unscaledWidth:Number, 
        unscaledHeight:Number):void {
        super.updateDisplayList(unscaledWidth, unscaledHeight);
        if(super.data)
        {
            var val:XML = super.data as XML;
             if (val.name() == 'root') {
                this.rootItemGroup.visible=true;
                this.itemGroup.visible=false;
                var tmp:XMLList = 
                    new XMLList(treeListData.item);
                var myStr:int = tmp[0].children().length();
                this.labelField.text= super.data.@label + " (" + myStr.toString() + ")";
            } else {
                this.rootItemGroup.visible=false;
                this.itemGroup.visible=true;
            }
        }

    }


    ]]>
</fx:Script>

<s:HGroup id="rootItemGroup" visible="false" left="0" right="0" top="0" bottom="0" verticalAlign="middle">
    <s:Rect id="indentationSpacer" width="{treeListData.indent}" percentHeight="100" alpha="0">
        <s:fill>
            <s:SolidColor color="0xFFFFFF" />
        </s:fill>
    </s:Rect>
    <s:Group id="disclosureGroup">
        <s:BitmapImage source="{treeListData.disclosureIcon}" visible="{treeListData.hasChildren}" />
    </s:Group>
    <s:BitmapImage source="{treeListData.icon}" />
    <s:Label id="labelField" text="{treeListData.label}" paddingTop="2"/>
</s:HGroup> 

<s:HGroup id="itemGroup" visible="false">
    <s:Label text="item ->"/>
    <s:Label text="{treeListData.label}"/>
 </s:HGroup>


</s:MXTreeItemRenderer>

如果我想检查某个项目是叶子还是节点,我无法检查 .hasChildren,因为我有带有节点的叶子。所以我检查 XML 对象的 name 属性来弄清楚这一点。
效果很好!感谢您的帮助。

thanks to David Goshadze's comment i was able to resolve the issue.

this is my new XML:

<notifications>
 <root label="a">
  <item label="moshe"/>
  <item label="moshe2"/>
 </root>
 <root label="b" />
 <root label="c" />
 <root label="d" />
<root label="e" />
</notifications>

and this is my new renderer:

<?xml version="1.0" encoding="utf-8"?>
<s:MXTreeItemRenderer xmlns:fx="http://ns.adobe.com/mxml/2009"
                  xmlns:s="library://ns.adobe.com/flex/spark"
                  xmlns:mx="library://ns.adobe.com/flex/mx">

<s:states>
    <s:State name="normal"/>
    <s:State name="hovered"/>
    <s:State name="selected"/>
</s:states>

<fx:Script>
    <![CDATA[
        import com.flexer.Debug;
        import mx.controls.Alert;

     override public function set data(value:Object):void {
        super.data = value;
        if (super.data) {
            if(treeListData.hasChildren)
            {

                setStyle("color", 0xff0000);
                setStyle("fontWeight", 'bold');
            }
            else
            {
                setStyle("color", 0x000000);
                setStyle("fontWeight", 'normal');
            }  

        } 
    }


override protected function createChildren():void

{

super.createChildren();



}       
// Override the updateDisplayList() method 
    // to set the text for each tree node.      
    override protected function updateDisplayList(unscaledWidth:Number, 
        unscaledHeight:Number):void {
        super.updateDisplayList(unscaledWidth, unscaledHeight);
        if(super.data)
        {
            var val:XML = super.data as XML;
             if (val.name() == 'root') {
                this.rootItemGroup.visible=true;
                this.itemGroup.visible=false;
                var tmp:XMLList = 
                    new XMLList(treeListData.item);
                var myStr:int = tmp[0].children().length();
                this.labelField.text= super.data.@label + " (" + myStr.toString() + ")";
            } else {
                this.rootItemGroup.visible=false;
                this.itemGroup.visible=true;
            }
        }

    }


    ]]>
</fx:Script>

<s:HGroup id="rootItemGroup" visible="false" left="0" right="0" top="0" bottom="0" verticalAlign="middle">
    <s:Rect id="indentationSpacer" width="{treeListData.indent}" percentHeight="100" alpha="0">
        <s:fill>
            <s:SolidColor color="0xFFFFFF" />
        </s:fill>
    </s:Rect>
    <s:Group id="disclosureGroup">
        <s:BitmapImage source="{treeListData.disclosureIcon}" visible="{treeListData.hasChildren}" />
    </s:Group>
    <s:BitmapImage source="{treeListData.icon}" />
    <s:Label id="labelField" text="{treeListData.label}" paddingTop="2"/>
</s:HGroup> 

<s:HGroup id="itemGroup" visible="false">
    <s:Label text="item ->"/>
    <s:Label text="{treeListData.label}"/>
 </s:HGroup>


</s:MXTreeItemRenderer>

If i want to check if an item is a leaf or a node I cannot check .hasChildren because i have leafs with nodes. so i check the name attribute of the XML object to figure that out.
works great! thanks for the assistance.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文