如何在Renderer中设置属性 Renderer中设置属性的方法实例

所属分类: 网络编程 / Flex 阅读数: 1471
收藏 0 赞 0 分享

ClassFactory的properties妙用

1)UITextField与label,使用label显不出来

复制代码 代码如下:

package com.citigroup.presentation.csa
{
    import flash.events.MouseEvent;

    import mx.controls.Label;
    import mx.controls.advancedDataGridClasses.AdvancedDataGridHeaderRenderer;
    import mx.core.UITextField;
    import mx.events.FlexEvent;

    public class GroupHeaderRenderer extends AdvancedDataGridHeaderRenderer
    {
        public var children:Array=[];
        public var expand:Boolean=true;
        private var l:UITextField;
        public function GroupHeaderRenderer()
        {
            super();
            l=new UITextField();
            l.text="[-]";
            l.addEventListener(MouseEvent.CLICK,toggle);
                    addChild(l);
            this.addEventListener(FlexEvent.CREATION_COMPLETE,init);

        }
        private function init(event:FlexEvent):void{
            if(expand){
                l.text="[-]";
            }else{
                l.text="[+]";
                toggleChildren(false);
            }
            this.removeEventListener(FlexEvent.CREATION_COMPLETE,init);
        }
        override public function set data(value:Object):void{
            super.data = value;
            this.setStyle("color","0xF9F088");
            this.setStyle("fontWeight","bold");
            this.setStyle("textAlign","left");
        }
        override protected function updateDisplayList(unscaledWidth:Number, unscaledHeight:Number):void{
                    super.updateDisplayList(unscaledWidth,unscaledHeight);
            label.x=0;
            l.x=label.x+label.width;
                    l.y=label.y;
        }

        private function toggle(event:MouseEvent):void{
            if(l.text=="[+]"){
                l.text="[-]";
                toggleChildren(true);
            }else{
                l.text="[+]";
                toggleChildren(false);
            }
        }
        private function toggleChildren(visible:Boolean):void{
            if(children.length<=1) return;
            for(var i:int=1;i<children.length;i++){
                children[i].visible=visible;
            }
        }
    }


public function genAdgColumn(headerText:String,dataField:String,width:Number=100):AdvancedDataGridColumn{
                var col:AdvancedDataGridColumn=new AdvancedDataGridColumn();
                col.headerText=headerText;
                col.dataField=dataField;
                col.width=width;
                return col;
            }
            public function genAdgColumnGroup(headerText:String,dataField:String,children:Array,expand:Boolean=true):AdvancedDataGridColumnGroup{
                var group:AdvancedDataGridColumnGroup=new AdvancedDataGridColumnGroup();
                group.headerText=headerText;
                group.dataField=dataField;
                <span style="color:#ff0000;">var cf:ClassFactory=new ClassFactory(GroupHeaderRenderer);
                cf.properties ={'children':children,'expand':expand};
                group.headerRenderer=cf;                 
                group.children=children;
                return group;
            }

更多精彩内容其他人还在看

使用flex中的httpservice方法与java进行交互

这篇文章主要介绍了使用flex中的httpservice方法与java进行交互,需要的朋友可以参考下
收藏 0 赞 0 分享

flex自定义按钮皮肤示例附图

这篇文章主要介绍了flex如何自定义按钮皮肤,需要的朋友可以参考下
收藏 0 赞 0 分享

flex利用webservice上传照片实现代码

这篇文章主要介绍了flex利用webservice上传照片实现代码,需要的朋友可以参考下
收藏 0 赞 0 分享

Flex实现的上传摄像头拍照并将UI保存为图片

这篇文章主要介绍了Flex如何实现上传摄像头拍照并将UI保存为图片,需要的朋友可以参考下
收藏 0 赞 0 分享

flex内嵌html网页示例代码

这篇文章主要介绍了flex如何内嵌html网页,需要的朋友可以参考下
收藏 0 赞 0 分享

flex通过java后台获取ip和pcname示例代码

这篇文章主要介绍了flex通过java后台获取ip和pcname的具体实现,需要的朋友可以参考下
收藏 0 赞 0 分享

Flex弹出窗口请求Action函数示例

这篇文章主要介绍了Flex弹出窗口请求Action函数,需要的朋友可以参考下
收藏 0 赞 0 分享

Flex中TabNavigator设置Tabs样式思路及源码

这篇文章主要介绍了Flex中TabNavigator如何设置Tabs样式有哪些思路,感兴趣的朋友可以看看下面的源码
收藏 0 赞 0 分享

Flex文件读取报错示例

这篇文章以示例的方式介绍了Flex文件读取报错的情况,需要的朋友可以参考下
收藏 0 赞 0 分享

Flex父子窗口相互调用实现思路及源码

这篇文章主要介绍了Flex父子窗口相互调用实现思路及源码,需要的朋友可以参考下
收藏 0 赞 0 分享
查看更多