As3 Loader复制加载的图片实例程序
先来了解一下Loader: 在 ActionScript 3.0 中使用的不是 ActionScript 2.0 MovieClipLoader 和 LoadVars 类,而是 Loader和 URLLoader 类。
Loader 类的属性允许您设置要加载的内容并在运行时监视它的加载进度。
使用 ActionScript 设置 Loader 类的属性将会覆盖在"属性"检查器或"组件"检查器中设置的同名参数。
每个组件类都有一个 version 属性,该属性是一个类属性。类属性只能用于该类本身。version 属性会返回一个字符串,该字符串指示组件的版本。要访问此属性,请使用以下代码:
trace(mx.controls.Loader.version);
Loader 类的方法摘要
下表列出了 Loader 类的方法。
Loader.load()
加载由 contentPath 属性指定的内容。
注意
代码 trace(myLoaderInstance.version); 返回 undefined。
使用Loader考虑 Flash Player 和 Adobe AIR 的安全模型:
例
代码如下 | 复制代码 |
package net.smilecn.studyLoader{ |
您可以加载来自任何可访问源的内容。
如果执行调用的 SWF 文件位于网络沙箱中并且要加载的文件是本地的,则不允许加载。
System.allowInsecureDomain() 方法来允许跨脚本排列,否则另一个安全沙箱中的 SWF 文件不能对它执行跨脚本操作。
如果被加载的内容为 AVM1 SWF 文件(用 ActionScript 1.0 或 2.0 编写),则 AVM2 SWF 文件(用 ActionScript 3.0 编写)不能对它执行跨脚本操作。但是,可以通过使用 LocalConnection 类在两个 SWF 文件之间实现通信。
如果被加载的内容为图像,则除非该 SWF 文件的域包含在该图像原始域的跨域策略文件中,否则安全沙箱之外的 SWF 文件无法访问其数据。
在只能与本地文件系统的内容交互的沙箱中的影片剪辑不能对只能与远程内容交互的沙箱中的影片剪辑使用脚本,反之亦然。
但在 Apollo 运行时中,application 安全沙箱中的内容(使用 Apollo 应用程序安装的内容)不受这些安全限制的约束。
例
代码如下 | 复制代码 |
package /** public function Main():void urlLoader.load(urlRequest); } private function doShow(_evt:Event):void private function swfLoadComplete(e:Event):void private function swfLoadComplete2(e:Event):void } |
补充:flash教程,As3.0