如何在Renderer中设置属性 Renderer中设置属性的方法实例
2013-06-24 11:38
429 查看
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;
}
相关文章推荐
- 如何在Renderer中设置属性
- python 7-6 如何使用描述符对实例属性做类型检查,分别实现set,方法,在set内使用isinstance做类型检查
- C#反射新建类实例和调用类方法及属性帮助类 以及获取或设置对象属性中字段值帮助类
- 2013-07-02 实例变量 、 属性 、便利构造器、设置器、 访问器、实例方法("-") 、类方法("+"静态方法)、单例
- android Tween Animation属性设置方法实例
- 通过反射(类类型)创建类的实例,调用类的方法,设置类的属性
- 如何设置 Internal 类,方法,属性对其他项目可见
- S4.1_Struts2_ActionAdvance 在action动作类里定义增删改方法,在struts.xml中的action method属性如何设置?
- Python中实例对象如何进行属性和方法调用原因分析
- python中类和实例如何绑定属性与方法示例详解
- jquery如何设置与去除disabled属性?五种方法
- video.js视频插件进行视频切换的设置方法及js中如何判断undefined的属性
- C#反射实例——获取及设置对象属性,运行对象方法
- 如何在低api中使用View的属性设置方法如setAlpha等
- 如何在低api中使用View的属性设置方法如setAlpha等
- 如何在PB数据窗口中设置数据窗口的更新属性
- HTML5里的placeholder属性使用实例和美化显示效果的方法
- Vue实例的属性和方法
- web.xml中如何设置配置文件的加载路径实例详解
- table设置colspan属性,列宽显示错位解决方法