如何在Renderer中設置屬性 Renderer中設置屬性的方法實例
更新時間:2013年06月24日 11:38:46 作者:
如何在Renderer中設置屬性 Renderer中設置屬性的方法實例,需要的朋友可以參考一下
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 chrome瀏覽器調試出現(xiàn)空白的解決方法
flex瀏覽器調試出現(xiàn)空白,原因是谷歌有個默認的flash播放器,只要將默認的播放器禁用,留下新安裝的插件,就OK了2014-02-02
如何在Renderer中設置屬性 Renderer中設置屬性的方法實例
如何在Renderer中設置屬性 Renderer中設置屬性的方法實例,需要的朋友可以參考一下2013-06-06
Flex4 使用itemRenderer 為Tree加線具體實現(xiàn)
本文為大家詳細介紹下Flex4如何使用itemRenderer 為Tree加線,感興趣的朋友可以參考下2013-12-12

