Flex动态设置Button中的icon指向外网图片源

本文介绍了一个名为 Icon Utility 的自定义类,用于快速加载和显示图标资源。通过集成 Loader、BitmapData 和 UIComponent 等组件,实现动态调整图标大小、自动加载远程图片并优化内存使用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  package { import flash.display.BitmapData; import flash.display.Loader; import flash.display.LoaderInfo; import flash.events.Event; import flash.geom.Matrix; import flash.net.URLRequest; import flash.system.LoaderContext; import flash.utils.Dictionary; import mx.containers.accordionClasses.AccordionHeader; import mx.controls.tabBarClasses.Tab; import mx.core.BitmapAsset; import mx.core.UIComponent; public class IconUtility extends BitmapAsset { private static var dictionary:Dictionary; public static function getClass( target:UIComponent, source:String, width:Number = NaN, height:Number = NaN ):Class { if(!dictionary) { dictionary = new Dictionary(false); } //if(source is String) //{ var loader:Loader = new Loader(); loader.load(new URLRequest(source as String), new LoaderContext(true)); //source = loader; //} dictionary[target] = { source:loader, width:width, height:height }; return IconUtility; } public function IconUtility():void { addEventListener(Event.ADDED, addedHandler, false, 0, true) } private function addedHandler(event:Event):void { if(parent) { if(parent is AccordionHeader) { var header:AccordionHeader = parent as AccordionHeader; getData(header.data); } else if(parent is Tab) { var tab:Tab = parent as Tab; getData(tab.data); } else { getData(parent); } } } private function getData(object:Object):void { var data:Object = dictionary[object]; if(data) { var source:Object = data.source; if(data.width > 0 && data.height > 0) { bitmapData = new BitmapData(data.width, data.height, true, 0x00FFFFFF); } if(source is Loader) { var loader:Loader = source as Loader; if(!loader.content) { loader.contentLoaderInfo.addEventListener(Event.CO MPLETE, completeHandler, false, 0, true); } else { displayLoader(loader); } } } } private function displayLoader( loader:Loader ):void { if(!bitmapData) { bitmapData = new BitmapData(loader.content.width, loader.content.height, true, 0x00FFFFFF); } bitmapData.draw(loader, new Matrix(bitmapData.width/loader.width, 0, 0, bitmapData.height/loader.height, 0, 0)); if(parent is UIComponent) { var component:UIComponent = parent as UIComponent; component.invalidateSize(); } } private function completeHandler(event:Event):void { if(event && event.target && event.target is LoaderInfo) { displayLoader(event.target.loader as Loader); } } } }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值