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 ButtonBackGroudImage 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 ButtonBackGroudImage;
}
public function ButtonBackGroudImage():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.COMPLETE, 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);
}
}
}
}
<?xml version="1.0" encoding="utf-8"?><mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute"> <mx:Script> <![CDATA[ import com.IconUtility; public function open():void { navigateToURL(new URLRequest("http://hi.baidu.com/woaidelphi/"), "_blank"); } ]]> </mx:Script> <mx:Button id="button" label="Button" icon="{IconUtility.getClass(button, 'http://hiphotos.baidu.com/woaidelphi/abpic/item/ace9cd3836b88206b9998fe9.jpg')}" x="488" y="233" width="278" height="107" click="open()"/></mx:Application>
分享到:
相关推荐
NULL 博文链接:https://emavaj.iteye.com/blog/676072
flexBulider页面加载动态图片的显示
flex 动态载入外部图片 学习使用基础资料
Flex Android项目 设置Button的背景色 为button添加背景色属性
FLEX 动态树 动态图表 FLEX 动态树 动态图表
很好用的动态创建DataGrid并加入图片的方式。 只需要继承和实现一个接口就可以了。
flex 修改 tree的icon,根据数据源root 中不同的参数修改不同的图片。
FLEX 背景图片设置的方法,很实用的技巧
Flex相册 Flex图片
重载flex的Button, 使文本能够自动换行
Flex MenuBar从数据库中动态加载图片.我找了好久才实现。
用flex编写的一个计算器,0-9数字按钮通过as 动态实现 直接讲文件导入flash builder就可以使用
flex 设置背景音乐flex 设置背景音乐flex 设置背景音乐flex 设置背景音乐flex 设置背景音乐flex 设置背景音乐flex 设置背景音乐
flex中文帮助flex中文帮助flex中文帮助flex中文帮助
在Flex中如何使用按钮Button组件进行开发
flex button的label字体垂直显示,这个是一个完整的事例,网上有部分代码,但是都不全
Flex动态爱墙(源代码) 利用flex3。0开发的一个动态的电子墙
精通FLEX源代码,精通FLEX源代码精通FLEX源代码
FLEX教程码源集合FLEX教程码源集合
Flex获取设置html cookie;Flex获取设置html cookie