您现在的位置:计算机技术学习网 > 技术中心 > WEB编程 > ASP >

定制Flex菜单图标

来源:网络 责任编辑:栏目编辑 发表时间:2013-07-01 14:37 点击:

默认Menu上的Icon必须通过iconField和iconFunction去指定,但是这两种方式都必须用嵌入资源Class名字去指定Icon,如果想用动态的图片(比如URL)作为Menu的Icon,就必须定制一把MenuItemRenderer。

 

首先写个类CustomMenuItemRenderer继承MenuItemRenderer,里面增加一个如下变量作为自定义Icon的组件:

view sourceprint?1 private var image:UIComponent = new UIComponent();

然后里面重写measure方法(计算MenuItem的宽高):

view sourceprint?01 override protected function measure():void { 

02     super.measure(); 

03   

04     if (separatorIcon || listData == null) { 

05         return; 

06     } 

07   

08     var imageAsset:IImageAsset = Utils.getImageAsset(data.@iconName); 

09     if(imageAsset == null){ 

10         return; 

11     } 

12     measuredWidth += imageAsset.width; 

13     if(imageAsset.height > measuredHeight){ 

14         measuredHeight = imageAsset.height; 

15     } 

16 }

重写commitProperties方法(重画并增加Icon,指定Icon宽高):

view sourceprint?01 override protected function commitProperties():void { 

02     super.commitProperties(); 

03   

04     if (separatorIcon || listData == null) { 

05         return; 

06     } 

07   

08     var imageAsset:IImageAsset = Utils.getImageAsset(data.@iconName); 

09     if(imageAsset == null){ 

10         return; 

11     } 

12     image.width = imageAsset.width; 

13     image.height = imageAsset.height; 

14     image.graphics.beginBitmapFill(imageAsset.getBitmapData()); 

15     image.graphics.drawRect(0, 0, image.width, image.height); 

16     image.graphics.endFill(); 

17     if(!this.contains(image)){ 

18         this.addChild(image); 

19     } 

20 }

重写updateDisplayList方法(指定Icon的位置,由于Icon在左边,所以super一把后,再移动Labe等的位置):

view sourceprint?01 override protected function updateDisplayList(unscaledWidth:Number, unscaledHeight:Number):void{ 

02     super.updateDisplayList(unscaledWidth, unscaledHeight); 

03   

04     if (separatorIcon || listData == null) { 

05         return; 

06     } 

07   

08     var imageAsset:IImageAsset = Utils.getImageAsset(data.@iconName); 

09     if(imageAsset == null){ 

10         return; 

11     } 

12     if(typeIcon){ 

13         typeIcon.x += imageAsset.width; 

14     } 

15     if(label){ 

16         label.x += imageAsset.width; 

17     } 

    相关新闻>>

      发表评论
      请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
      用户名: 验证码:点击我更换图片
      最新评论 更多>>

      推荐热点

      • WAP常见问题问答大全(四)
      • ASP开发必备:WEB打印代码大全
      • ASP调用系统ping命令
      • asp缓存技术
      • ASP教程:第三篇 ASP基础
      • 用ASP+XML打造留言本(4)
      • 关于ASP Recordset 分页出现负数解决方法及建议
      • 用asp怎样编写文档搜索页面(5)
      • ASP处理多关键词查询实例代码
      网站首页 - 友情链接 - 网站地图 - TAG标签 - RSS订阅 - 内容搜索
      Copyright © 2008-2015 计算机技术学习交流网. 版权所有

      豫ICP备11007008号-1