Adobe Flex 4.5 Spark: привязка компонента ItemRenderer к родительскому элементу - PullRequest
2 голосов
/ 13 июля 2011

В Flex 3 раньше можно было связать свойство компонента внутри itemRenderer через outerDocument. Так, например, если бы внутри itemRenderer было изображение, которое отображалось только при заданном условии родителя, что-то вроде этого отлично бы работало:

<mx:itemRenderer>
 <mx:Component>
   <mx:Label text="{data}"/>
   <mx:Image id="img" visible="{outerDocument.ShowImage}" includeInLayout="{outerDocument.ShowImage}"/>
</mx:Component>
</mx:itemRenderer>

где внешний документ (не список, а mxml, в котором находится список) содержал что-то вроде

[Bindable]
public function get ShowImage():void
{
return showImage;
}
public function set ShowImage(val:Boolean):void
{
showImage = val;
}

Я пытался сделать то же самое в Flex 4.5, используя средства визуализации элементов Spark, используя parentDocument, но, похоже, он не знает о привязке. Когда я делаю это во Flex 4.5, itemRenderer, кажется, не знает, когда изменяется parentDocument ShowImage.

Кто-нибудь видел эту проблему и может предложить решение?

РЕДАКТИРОВАТЬ: Добавить источник искры Как и было запрошено, мой источник искры:

MyItemRenderer.mxml

<s:ItemRenderer 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:Label id="myLabel" text="{data}/>
<s:Image src="something.png" visible="{parentDocument.ShowImage}" includeInLayout="{parentDocument.ShowImage}"/>
</s:ItemRenderer>

RendererContainer.mxml

<s:Panel xmlns:fx="http://ns.adobe.com/mxml/2009" 
         xmlns:s="library://ns.adobe.com/flex/spark" 
         xmlns:mx="library://ns.adobe.com/flex/mx">
<fx:Script>
<![CDATA[

private var showImage:Boolean = false;

[Bindable]
public function set ShowImage(val:Boolean):void
{
     showImage = val;
}
public function get ShowImage():Boolean
{
     return showImage;
}
]]>
    </fx:Script>
    <!-- Content Group -->
    <s:List id="lstCell" width="100%" height="100%" itemRenderer="MyItemRenderer">      
    </s:List>
</s:Panel>

Хорошо, поэтому в оболочке за пределами RendererContainer.mxml есть флажок, который отправляет пользовательское событие, которое обрабатывается путем изменения Bindable Boolean. Изменение в этой переменной затем изменяет свойство ShowImage в моем компоненте RendererContainer. Я ожидал бы, что привязка будет тогда подхвачена MyItemRenderer, но, похоже, она не работает.

Так что моя внешняя оболочка будет обращаться к ShowImage, как это

<comp:RendererContainer id="myId" ShowImage="{myCheckbox.selected}"/>

Ответы [ 4 ]

1 голос
/ 18 июля 2011

отлично работает:

<?xml version="1.0" encoding="utf-8"?>
<s:WindowedApplication 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:layout>
        <s:VerticalLayout/>
    </s:layout>
    <fx:Script>
        <![CDATA[
            import mx.collections.ArrayCollection;
        ]]>
    </fx:Script>
    <fx:Declarations>
        <!-- Place non-visual elements (e.g., services, value objects) here -->
    </fx:Declarations>
    <s:Panel 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:layout>
            <s:VerticalLayout/>
        </s:layout>
        <fx:Script>
            <![CDATA[

                private var showImage:Boolean = false;

                [Bindable]
                public function set ShowImage(val:Boolean):void
                {
                    showImage = val;
                }
                public function get ShowImage():Boolean
                {
                    return showImage;
                }
            ]]>
        </fx:Script>
        <s:CheckBox label="Select" change="{ShowImage = !ShowImage}"/>
        <!-- Content Group -->
        <s:List id="lstCell" width="100%" height="100%" dataProvider="{new ArrayCollection(['A','B'])}">
            <s:itemRenderer>
                <fx:Component>
                    <s:ItemRenderer xmlns:fx="http://ns.adobe.com/mxml/2009" 
                                    xmlns:s="library://ns.adobe.com/flex/spark" 
                                    xmlns:mx="library://ns.adobe.com/flex/mx" 
                                    autoDrawBackground="true">
                        <s:layout>
                            <s:HorizontalLayout/>
                        </s:layout>
                        <s:Label id="myLabel" text="{data}"/>
                        <s:Button label="something.png" visible="{outerDocument.ShowImage}" includeInLayout="{outerDocument.ShowImage}"/>
                    </s:ItemRenderer>
                </fx:Component>
            </s:itemRenderer>
        </s:List>
    </s:Panel>

</s:WindowedApplication>
1 голос
/ 14 июля 2011

Я думаю, что это должно помочь вам, YourTypeHere будет классом содержания объект, убедитесь, что свойство ShowImage общедоступно и доступно для привязки.

<mx:itemRenderer>
     <mx:Component> 
     <mx:Script>
        <![CDATA[ 
            import YourTypeHere;
        ]]>
    </mx:Script>
       <mx:Label text="{data}"/>
       <mx:Image id="img" 
        visible="{YourTypeHere(this.parent.ShowImage)}" 
        includeInLayout="{YourTypeHere(this.parent.ShowImage)}"/>
    </mx:Component>
</mx:itemRenderer>

P.s. пожалуйста, не называйте свойства начальной буквой в верхнем регистре, включая получатели, рассмотрите возможность присвоения ей имени showImage и вашей личной переменной, например _showImage: D

1 голос
/ 18 июля 2011

Это поможет.

<s:Image src="something.png" visible="{RendererContainer(ListSkin(parentDocument).parentDocument).ShowImage}" includeInLayout="{RendererContainer(ListSkin(parentDocument).parentDocument).ShowImage}"/>
1 голос
/ 13 июля 2011

Кажется, ваш получатель имеет тип возврата void.Измените это на Boolean

[Bindable]
public function get ShowImage():Boolean
{
return showImage;
}
public function set ShowImage(val:Boolean):void
{
showImage = val;
}
...