Asignar una clase ActionScript 3 a un itemRenderer en Flex
Viernes, Julio 10th, 2009En este Tip voy a explicar un sistema para poder controlar la funcionalidad de un componente usado como itemRenderer en cualquier componente de tipo lista desde una clase de ActionScript 3.
Supongamos que en nuestra aplicación Flex tenemos un compomente TileList al que le hemos asignado otro componente como itemRenderer:
<mx:TileList id=“myTileList”>Â Â
  <mx:itemRenderer>
    <mx:Component>    Â
      <mx:myItemRenderer/>
    </mx:Component>
  </mx:itemRenderer>
</mx:TileList>
Este itemRenderer será otro archivo MXML al que queremos asignarle una clase AS3 para poder manejarlo, para ello le añadiremos un tag
<mx:Script> Â Â <![CDATA[ Â Â Â Â import com.proyecto.MyItemRendererClass; Â Â Â Â private var _this:MyItemRendererClass = new MyItemRendererClass(this); Â Â ]]> </mx:Script>
El único detalle a tener en cuenta es que la clase reciba correctamente el contenido del objeto “data” del dataProvider. Eso se lo tenemos que pasar una vez el itemRenderer esté creado, de manera que en el evento creationComplete del componente haremos un setter a la clase:
<mx:Canvas xmlns:mx=“http://www.adobe.com/2006/mxml”creationComplete=“_this.data = data”>
Con lo que la clase para controlar el itemRenderer comenzarÃa siendo asÃ:
package com.proyecto {   public class MyItemRendererClass   {     private var _main:Object;     private var _data:Object;     //————————————————————————     public function MyItemRendererClass(m:Object)     {       _main = m;     }      public function set data(d:Object):void     {       _data = d;       init();     }      //————————————————————————     public function init():void     {       /* etc.. */     }      //————————————————————————   } }
Comparte:
- Acceder a los itemRenderer de un componente lista en Flex
- Clase de ActionScript 3 para añadir sombras a MovieClips
- Clase de Actionscript 3 para arrays multidimensionales







