0

アイテムレンダラーでコンポーネントのテキストサイズを動的に変更するにはどうすればよいですか?

ここに私の CustomItemRenderer.mxml があります:

<?xml version="1.0" encoding="utf-8"?>
<s:ItemRenderer xmlns:fx="http://ns.adobe.com/mxml/2009" 
                xmlns:s="library://ns.adobe.com/flex/spark">
    <fx:Declarations>
        <!-- Place non-visual elements (e.g., services, value objects) here -->
    </fx:Declarations>

    <fx:Script>
        <![CDATA[
            override public function set data(value:Object):void
            {
                super.data = value;

                invalidateDisplayList();
            }

            private function list_itemRendererFunc(item:Object):void {
                textArea2.setStyle("fontSize",
                                textArea2.getStyle("fontSize") + 2);    
        ]]>
    </fx:Script>
    <s:Label left="10" right="10" top="10" height="25" fontSize="14" maxDisplayedLines="1"
             text="{data.title}" textAlign="center"/>

    <s:TextArea id="textArea2" left="10" right="10" top="35" bottom="10" editable="false"
                fontSize="12" skinClass="spark.skins.mobile.TextAreaSkin"
                text="{data.description }"/>
</s:ItemRenderer>

ボタンが押されたときに textArea2 にアクセスしてフォントサイズを変更したい。手伝って頂けますか?

4

1 に答える 1

0

バインド可能な public var を itemrenderer 内に配置し、次のように fontSize にバインドします。

<s:TextArea id="textArea2" fontSize="{mypublicvar}" ...

次に、ボタンが押されると、リスト (またはデータグリッド?) の itemrenderers をループし、そのレンダラーの mypublicvar を次のように新しい値に変更します。

for(var i:int = 0; i < list.dataGroup.numElements; i++)
{
   var itemRendererItem:CustomItemRenderer = list.dataGroup.getElementAt(i) as CustomItemRenderer;
   itemRendererItem.mypublicvar += 2;

   //you can also try
   itemRendererItem.textArea2.setStyle("fontSize",...
}

ところで、あなたの list_itemRendererFunc は間違った場所にあると思います。より定式化された質問を作成する必要があります。

于 2012-01-18T01:45:42.890 に答える