本文和大家重点讨论一下Flex Flash关系,主要包括Flex应用程序的生命周期,Flashpalyer和Framwork的区别等内容,相信通过本文的介绍你对两者的关系一定会有明确的认识。
Flex Flash关系分析
1、Flex应用程序的生命周期
Flex应用就其根本上讲就是Flash应用,只不过其是基于FlexFramework(由ActionScript写就)开发的。Flex应用程序的根对象的是SystemManager(不是我们在flex应用上看到的Application根元素),继承自flash.dispaly.MovieClip—flashplayerdisplaytype,MovieClip是一种支持timeline基本元素帧frame的对象,在FlexFramework中SystemManager是特殊的,含有两帧(其他component都是一帧的),分别是preloader和真正的Application,preloader帧可以迅速下载下来并用于显示应用下载进度,一旦Flex应用的SystemManager实例进入第二帧,将创建Flex主应用application实例并赋予本身的属性application(在进入第二帧之前是null),自此application(flex主应用)的内部生命周期、事件开始运作:
◆preinitialize:application已经实例化但尚未创建任何childcomponent
◆initialize:已经创建childcomponent但对其进行布局(layout)
◆creationComplete:application已经完成实例化并完成所有childcomponent的布局
SystemManager有一个topLevelSystemManager对象,指向一个SystemManager实例,是所有当前在flashplayer运行的任何东西的根(root),如果flex被作为主应用加载到flashplayer则上述属性将指向其本身(self-refrencing),但当flex应用是被另一flex应用载入的,其自身的SystmenManager的topLevelSystemManager属性则不是自引用了,而是指向其父应用的SystemManager实例。所有UIComponent的子类都有一个systemManager属性指向应用的SystemManager实例,在被SystemManger实例监听的component的事件发生冒泡时,其将拥有事件处理链上***的处理权。
2、Flashpalyer和Framwork的区别
Flashplayer是Flex应用和flash应用的运行环境,两应用对其拥有完全平等的操作权(通过Flashplayer提供的API),两应用形成的.swf文件在flashplayer中是同样的表现,不同的不是应用的内容而是其各自的创建方式。Flex的Framework在开发和运行之间为应用提供了一层抽象,Flex应用编译时会将必要的framworklibrary编译进.swf文件(同样影响应用文件的大小等),主要的flashplayerclass当然不会被编译到.swf中,因为他们已经存在于flashplayer中了,最终形成与flash应用同样的flashplayer可以理解的指令。
关于flashplayerclass和flexframework的区分很方便,前者的class以flash开头,如flash.net.URLLoader,而后者则以mx开头,如mx.controls.Button
3、动态载入另外的flex应用
<mx:SWFLoadersource=”src/*.swf”/>
Swfloader的content属性指向被载入的flex应用的SystemManager实例(其application属性指向被载入felx应用的Application实例),swfloader加载、初始化被载入flex应用时会dispatch出init事件,可与其中监听被载入flex应用的SystemManager实例的ApplicationComplete事件,事件发生时被载入content的Application对象方可以引用
与inithandler中event.target.content.addEventListener(FlexEvent.APPLICATION_COMPLETE,func);
与applicationCompleteHandler中event.target.application.method…
4、理解应用程序域(applicationdomain)
一个应用程序domain(类似于.net的appdoamin)中有flex应用的相关类定义、资源等,被载入的新flex应用可以存在于一个全新的、隔离的domain中(占额外的内存资源)、可以存在于当前domain的子doamin中(共享父domain的资源、类定义,须注意类定义被取代的情况)、也可以直接存在与当前doamin中(同样须注意类定义冲突),如runtimesharedlibrary。
代码中实现这三种方式的应用(主要应用到flash.system.LoaderContext、flash.display.Loader或flash.net.URLLoader、flash.system.ApplicationDomain)
- varcontext:LoaderContext=newLoaderContext();
- context.applicationDomain=newApplicationDomain(ApplicationDomain.currentDomain);//载入作为子domain
- context.applicationDomain=newApplicationDomain();//载入作为全新domain
- context.applicationDomain=ApplicationDomain.currentDomain;//载入当前domain
- varrequest:URLRequest=newURLRequest("RuntimeLoadingExample.swf");
- varloader:Loader=newLoader();
- loader.load(request,context);
5、关于preloader
Preloader是一个轻量级的类,在systemManager的***帧被实例化,preloader会dispatch出一系列的事件,由progressbar监听实现loading界面,一旦应用进入第二帧待application初始化后会借由systemmanager通知preloader初始化进度,preloader通知systemmanager其准备待删除
Preloader的事件dispatch:
- progress
- Indicatesdownloadprogress
- complete
- Indicatesthatthedownloadiscomplete
- rslError
- Indicatesthataruntimesharedlibrarycouldnotload
- rslProgress
- Indicatesthedownloadprogressforaruntimesharedlibrary
- rslComplete
- Indicatesthatthedownloadiscompleteforruntimesharedlibraries
- initProgress
- Indicatesthattheapplicationisinitializing
- initComplete
- Indicatesthattheapplicationhasinitialized
如此,preloader可以定制化了。
【编辑推荐】
- 解析Flexbuilder4十大新特性
- 从Flex Builder更名看Flash平台战略
- Flex及FlexBuilder2.0开发环境详解
- FlexBuilder3.0与Eclipse3.4的***结合
- 学习笔记 FlexBuilder2.0中如何使用基于Lists的控件