本博推荐文章快速导航: Sql Server2005 Transact-SQL 新兵器学习 MCAD学习 代码阅读总结 ASP.NET状态管理 DB(数据库) WAP WinForm Flex,Fms

Flex组件的项目渲染器(ItemRenderer)使用总结

系列文章导航
  1. Flex,Fms3相关文章索引
  2. Air版免费视频成人聊天室,免费网络远程视频会议系统((Flex,Fms3联合打造))

 

Flex中提供了大量用于数据呈现的组件,这其中,以List系列组件最为常见,使用也最频繁,比如ComBoBox、List、Tree、TileList、DataGrid等等。这些组件有一个共同的特性,那就是支持自定义itemRenderer,这个功能非常强大,能够帮助我们实现很多实用的功能.

项目渲染器(ItemRenderer)是ListBase类列表控件的重要属性,我们在平常工作中会经常自定义项目渲染器以实现该类控件的特殊显示效果。

默认的项目渲染器取决于组件类。TileList 和 HorizontalList 类使用 TileListItemRenderer;List 类使用 ListItemRenderer。DataGrid 类使用 DataGridColumn 中的 DataGridItemRenderer。

什么是itemRenderer?
itemRenderer,可以理解为数据的表现方式,具体地说,是指显示每一条数据时采用的形式。在使用数据处理类组件时,我们只需要把数据按照一定的格式组织好,然后赋予给组件,剩下的事就不用费心了。
每一个组件都有默认的itemRenderer,比如List组件:
List组件默认的itemRenderer类似Label组件,只简单显示一行文本。如右图所示,红色方框选中的是一个itemRenderer。
本质上,itemRenderer和其它容器类组件没有区别,里面可以包括任意的可视化元素,包括文本、图片、视频等,只要是Flex支持的视觉元素,都可以。

自定义itemRenderer
组件默认的itemRenderer都过于简单,如果想加强表现力,就必须创建个性化的itemRenderer。
自定义itemRenderer有两种方式:一种是嵌入式,直接写在组件的标签中,所有的代码都集中在一个MXML文件中;另一种是把itemRenderer独立出来,形成一个MXML组件或ActionScript类。

 

看下面图片,我用TileList控件的自定义ItemRenderer实现的效果:

image

 

代码下载:

http://files.cnblogs.com/aierong/Air_TestWin.rar

 

 

代码说明:

先自定义一个名称为:itemh的MXML

<?xml version="1.0" encoding="utf-8"?>
<mx:HBox xmlns:mx="http://www.adobe.com/2006/mxml" width="145" height="41"
         horizontalScrollPolicy="off" verticalScrollPolicy="off">

    <mx:VBox width="40" height="100%" horizontalScrollPolicy="off" verticalScrollPolicy="off">
        <mx:Image click="this.parentDocument.imgclick(event)"
                  data="{data.label}" source="assets\tx.JPG" width="40"/>
    </mx:VBox>
    <mx:VBox width="95" height="100%" horizontalScrollPolicy="off" verticalScrollPolicy="off">
        <mx:Label text="{data.label}" toolTip="{data.label}" />
        <mx:Image toolTip="点我查看视频"  buttonMode="true"
                  source="assets\camera.JPG" width="16" height="20"  />
    </mx:VBox>

</mx:HBox>

 

主调用应用中:

<mx:ArrayCollection id="arrColl_keySetup">
    <mx:source>
        <mx:Array id="arr_keysetup">
            <mx:Object data="00" sel="false" label="aaa"/>
            <mx:Object data="11" sel="false" label="bbb"/>
            <mx:Object data="22" sel="true" label="ccc"/>
        </mx:Array>
    </mx:source>
</mx:ArrayCollection>

<mx:TileList id="tlist" maxColumns="1"
    dataProvider="{arrColl_keySetup}" 
    itemRenderer="itemh"
    x="34" y="10" width="148">
</mx:TileList>

 

给TileList的itemRenderer属性赋值itemh,并绑定数组集合类就可以了。

 

动态指定itemRenderer

利用ClassFactory类可以动态指定itemRenderer

代码如下:

private function initTileList():void
{
    this.tlist.dataProvider=this.arrColl_keySetup;
    this.tlist.itemRenderer = new  ClassFactory(itemh);
}

<mx:TileList id="tlist" maxColumns="1" x="34" y="10" width="148"
    creationComplete="initTileList()">
</mx:TileList>

 

 

至于怎样在项目渲染器访问主调用应用中的成员,可用parentDocument来引用;
反过来,主调用应用要访问项目渲染器中的成员,一般都是通过在项目渲染器先派发事件,然后在主调用应用中注册事件侦听器来实现。

例如:在项目渲染器中点击图片事件,然后通知主调用应用

<mx:Image click="this.parentDocument.imgclick(event)"
                  data="{data.label}" source="assets\tx.JPG" width="40"/>

在主调用应用中定义:

public function imgclick(evt:MouseEvent):void
{
    var img:Image=evt.currentTarget as Image;
    Alert.show(img.data.toString());
}

记住得是public的,不同类之间是无法访问私有方法的

图片点击后效果图片:

image

其实上面的功能也可以用dispatchEvent来实现

先定义一个事件类

package
{
    import flash.events.Event;
    public class myEvent extends Event
    {
        public var data:String;
        public function myEvent(type:String, bubbles:Boolean=false, cancelable:Boolean=false,data:String="")
        {
            super(type, bubbles, cancelable);
            this.data=data;
        }
    }
}

然后在itemh中将事件调度到事件流中

<mx:Image click="clickHandler(event)"
          data="{data.label}" source="assets\tx.JPG" width="40"/>

private function clickHandler(evt:MouseEvent):void
{
    var img:Image=evt.currentTarget as Image;
    dispatchEvent(new  myEvent("img_click",true,true,img.data.toString()));
}

最后在主调应用中监听事件

private function initTileList():void
{
    this.tlist.addEventListener("img_click",onItemimg_click);
}

private function onItemimg_click(evt:myEvent):void
{
    Alert.show(evt.data);
}

<mx:TileList id="tlist" maxColumns="1" x="34" y="10" width="148"
    dataProvider="{arrColl_keySetup}" itemRenderer="itemh"
    creationComplete="initTileList()">
</mx:TileList>

 

 

 

其实也可以用<mx:itemRenderer>和<mx:Component>标签来声明itemRenderer

例如以上代码可以改为:

<mx:Script>
    <![CDATA[
        import mx.controls.Image;
        import mx.controls.Alert;

        public function imgclick(evt:MouseEvent):void
        {
            var img:Image=evt.currentTarget as Image;

            Alert.show(img.data.toString());
        }
    ]]>
</mx:Script>

<mx:ArrayCollection id="arrColl_keySetup">
    <mx:source>
        <mx:Array id="arr_keysetup">
            <mx:Object data="00" sel="false" label="aaa"/>
            <mx:Object data="11" sel="false" label="bbb"/>
            <mx:Object data="22" sel="true" label="ccc"/>
        </mx:Array>
    </mx:source>
</mx:ArrayCollection>

<mx:TileList id="tlist" maxColumns="1"
             dataProvider="{arrColl_keySetup}" 
             x="34" y="10" width="148">
    <mx:itemRenderer>
        <mx:Component>
            <mx:HBox width="145" height="41" horizontalScrollPolicy="off" verticalScrollPolicy="off">
                <mx:VBox width="40" height="100%" horizontalScrollPolicy="off" verticalScrollPolicy="off">
                    <mx:Image click="this.parentDocument.imgclick(event)"
                        data="{data.label}" buttonMode="true" source="assets\tx.JPG" width="40"/>
                </mx:VBox>
                <mx:VBox width="95" height="100%" horizontalScrollPolicy="off" verticalScrollPolicy="off">
                    <mx:Label text="{data.label}" toolTip="{data.label}"/>
                    <mx:Image toolTip="点我查看视频" buttonMode="true"
                        source="assets\camera.JPG" width="16" height="20"/>
                </mx:VBox>
            </mx:HBox>
        </mx:Component>
    </mx:itemRenderer>
</mx:TileList>

 

再提供2个比较好的例题

http://blog.minidx.com/2008/10/03/1457.html

http://blog.minidx.com/2008/03/09/559.html

 

 

收藏与分享

收藏到QQ书签 添加到百度搜藏 添加到百度搜藏 添加到雅虎收藏 分享到饭否 收藏到就喜欢网络收藏夹

RSS订阅我 什么是RSS?

feedsky    http://wap.feedsky.com/aierongrss    E-mail
订阅到雅蛙       使用RSS邮天下订阅    订阅到有道阅读
订阅到抓虾    鲜果阅读器订阅图标    Add to Google
訂閱 Bloglines    哪吒提醒    Subscribe in NewsGator Online

东莞.net俱乐部

东莞.net俱乐部 欢迎您的加入

我的系列文章
A.Sql Server2005 Transact-SQL 新兵器学习
B.MCAD学习
C.代码阅读总结
D.ASP.NET状态管理
E.DB(数据库)
F.WAP
G.WinForm
H.Flex

我的好文推荐
FlexAir开源版-全球免费多人视频聊天室,免费网络远程多人视频会议系统((Flex,Fms3联合开发))<视频聊天,会议开发实例8>
Sql Server2005 Transact-SQL 新兵器学习总结之-总结
MS SQL数据库备份和恢复存储过程(加强版本)
sql server中分布式查询随笔(链接服务器(sp_addlinkedserver)和远程登录映射(sp_addlinkedsrvlogin)使用小总结)
ASP.NET2.0国际化/本地化应用程序的实现总结(多语言,多文化页面的实现)
WAP开发资料站(最新更新)
自定义格式字符串随笔 (IFormattable,IFormatProvider,ICustomFormatter三接口的实现)
Mcad学习笔记之异步编程(AsyncCallback 委托,IAsyncResult接口,BeginInvoke方法,EndInvoke方法的使用小总结)
Mcad学习笔记之通过反射调用類的方法,屬性,字段,索引器(2種方法)
Mcad学习笔记之序列化(2进制和Soap序列 化)
Mcad学习笔记之委托再理解(delegate的构造器,BeginInvoke,EndInvoke,Invoke4个方法的探讨)
ASP.NET状态管理之一(概括篇)
Flex,Fms学习笔记

希望上面提到的知识对您有所提示,同时欢迎交流和指正
作者:aierong
出处:http://www.cnblogs.com/aierong
贴子以"现状"提供且没有任何担保,同时也没有授予任何权利!
本文版权归作者所有,欢迎转载!
原创技术文章和心得,转载注明出处!这也是对原创者的尊重!

posted @ 2009-02-11 16:49 aierong 阅读(7918) 评论(2) 编辑 收藏

 回复 引用   
#1楼 2009-02-19 10:21 waychu[未注册用户]
请教:使用动态指定itemRenderer:

<mx:Panel title="Catalog" width="100%" height="100%">
<mx:TileList id="tlist" creationComplete="initTileList()" width="100%" height="100%"/>
</mx:Panel>

initTileList()方法没有被触发,借助Button的click="initTileList()" 才行,
是啥回事?

 回复 引用 查看   
#2楼[楼主] 2009-02-19 10:24 aierong      
--引用--------------------------------------------------
waychu: 请教:使用动态指定itemRenderer:

&lt;mx:Panel title=&quot;Catalog&quot; width=&quot;100%&quot; height=&quot;100%&quot;&gt;
&lt;mx:TileList id=&quot;tlist&quot; creationComplete=&quot;initTileList()&quot; width=&quot;100%&quot; height=&quot;100%&quot;/&gt;
&lt;/mx:Panel&gt;

initTileList()方法没有被触发,借助Button的click=&quot;initTileList()&quot; 才行,
是啥回事?
--------------------------------------------------------


你用fb3的调试功能一步步运行,看看为什么没触发creationComplete="initTileList()"

<mx:TileList id="tlist" creationComplete="initTileList()" width="100%" height="100%"/>
这段代码是没问题的