博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
(转)Loader ,URLLoader ,URLStream的区别
阅读量:5065 次
发布时间:2019-06-12

本文共 5302 字,大约阅读时间需要 17 分钟。

AS3代码   

(1)  Loader        
      
Loader 类可用于加载 SWF 文件或图像(JPG、PNG 或 GIF)文件。 使用 load() 方法来启动加载。 被加载的显示对象将作为 Loader 对       
      
象的子级添加。        
      
(2) URLLoader        
      
URLLoader 类以文本、二进制数据或 URL 编码变量的形式从 URL 下载数据。 在下载文本文件、XML 或其它用于动态数据驱动应用程序的       
      
信息时,它很有用。        
      
URLLoader 对象会先从 URL 中下载所有数据,然后才将数据用于 ActionScript。 它会发出有关下载进度的通知,通过 bytesLoaded 和        
      
bytesTotal 属性以及已调度的事件,可以监视下载进度。       
      
在加载非常大的视频文件(如 FLV 的视频文件)时,可能会出现内存不足错误。        
      
(3) URLStream        
      
URLStream 类提供对下载 URL 的低级访问。 数据一下载,便可随即为应用程序使用,这和使用 URLLoader 时需要等到整个文件下载完不       
      
同。并且 URLStream 类还允许在完成下载前关闭流。 已下载文件的内容将作为原始二进制数据提供。        
      
在 URLStream 中的读取操作是非阻塞模式的。 这意味着您在读取数据之前必须使用 bytesAvailable 属性来确定是否能够获得足够的数据       
      
。 如果不能获得足够的数据,将引发 EOFError 异常。       
      
在默认情况下,所有二进制数据都是以 Big-endian 格式编码的,并且最高位字节于第一位。       
      
    
  
整合资料:   
  
(1)Loader   
 Loader 像2.0中MovieClip 的loadMovie 功能,用于加载外部的图片和SWF文件。   
  
 如果加载图片文件(jpg,gif,png等)时,Loader.content 得到数据类型是Bitmap 对象;   
 如果加载SWF文件(flash 9 版本)时,Loader.content 得到数据类型是MovieClip 对象;   
 如果加载SWF文件(flash 9 以前版本) 时, Loader.content 得到数据类型是AVM1Movie 对象;   
  
(2)URLLoader   
  
(3)URLStream   
  
下面我做了一个实例将被加载的配置文件以二进制数据读取 ,这可以解决很多问题,比如对不同格式配置文件进行的处理   
  
例如:   
  
AS3代码   

[c-sharp] 
 
  1. package          
  2. {         
  3.     import flash.display.Sprite;         
  4.     import flash.events.Event;         
  5.     import flash.net.URLRequest;         
  6.     import flash.net.URLStream;         
  7.              
  8.     import flash.net.URLLoader;         
  9.     import flash.utils.ByteArray;         
  10.     import flash.net.URLLoaderDataFormat;         
  11.     /**      
  12.      * …      
  13.      * @author yangzq 
  14.      */        
  15.     public class Test extends Sprite        
  16.     {         
  17.                  
  18.         public function Test()          
  19.         {         
  20.                      
  21.             //testURLLoader();         
  22.             testURLStream();         
  23.         }         
  24.                  
  25.         private function testURLLoader():void        
  26.         {         
  27.             var urlLoader:URLLoader = new URLLoader();         
  28.             urlLoader.dataFormat = URLLoaderDataFormat.BINARY;//原始二进制数据         
  29.             urlLoader.addEventListener(Event.COMPLETE, completeHandler);         
  30.                      
  31.             urlLoader.load(new URLRequest(“02.xml”));         
  32.         }         
  33.         private function completeHandler(event:Event):void        
  34.         {         
  35.                      
  36.             trace(“配置文件是ANSI  :” + event.target.data);// 如果配置文件是ANSI等,会出现中文字乱码         
  37.                      
  38.             //URLLoader如果遇到乱码,则可以转换(利用标准的xml格式Excle可以解决乱码问题就是基于这里):         
  39.             var _byteArray:ByteArray = new ByteArray;         
  40.             _byteArray.writeBytes(event.target.data);         
  41.             _byteArray.position = 0;            
  42.                      
  43.             //如果是xml文档         
  44.             var xml:XML = XML(_byteArray.readMultiByte(_byteArray.length, ”chinese”));//简体中文 (GB2312)         
  45.             trace(xml);         
  46.         }         
  47.                  
  48.                  
  49.         private function testURLStream():void        
  50.         {         
  51.             var stream:URLStream = new URLStream();         
  52.                      
  53.             stream.addEventListener(Event.COMPLETE, complete);         
  54.             stream.load(new URLRequest(“02.xml”));         
  55.         }         
  56.                  
  57.         private function complete (event:Event):void        
  58.         {         
  59.             var stream:URLStream = event.target as URLStream;         
  60.             var xml:XML = XML(stream.readMultiByte(stream.bytesAvailable, ”chinese”));//简体中文 (GB2312)         
  61.                      
  62.             trace(xml);         
  63.         }         
  64.                  
  65.                  
  66.     }         
  67.              
  68. }  

 

 

/

 

AS3已经中Loader与URLLoader是两个比较容易混淆的类,特此区分: 

区别:一个用来加载可显示数据,一个用来加载非显示数据
因为loader是继承与容器类的,所以首先它是个容器,而URLLoader 是继承与EventDispatcher,它不是容器

URLLoader 类以文本、二进制数据或 URL 编码变量的形式从 URL 下载数据,在加载非常大的视频文件(如 FLV 的视频文件)时,可能会出现内存不足错误,返回的数据在data属性里面

而loader多加载图片,swf等可视化对象,加载后作为唯一的子对象显示在列表上。

应用范围 

Loader: 多用于swf,图片(jpg,png,gif) 
URLLoader: 多用于文本文件(xml,php,jsp…)

使用方法 

Loader:

loader.contentLoaderInfo.addEventListener(Event.COMPLETE, loadComplete); private function loadComplete(event:Event) { trace("done");addChild(loader);}

URLLoader:

xmlLoader.dataFormat=URLLoaderDataFormat.TEXT; xmlLoader.addEventListener(Event.COMPLETE,xmlLoaded); private function xmlLoaded(event:Event) { try {myXML = XML(event.target.data);area.text=myXML;} catch (e:TypeError) {area.text="Load faild:/n"+e.message;} }

Loader
在使用Loader来加载数据时,添加侦听事件时,注意一定要给Loader的 contentLoaderInfo属性增加事件,而不是给Loader对象增加事件。

var loader:Loader = new Loader();

loader.contentLoaderInfo.addEventListener(Event.COMPLETE, completeHandler);
loader.contentLoaderInfo.addEventListener(SecurityErrorEvent.SECURITY_ERROR, securityErrorHandler);
loader.contentLoaderInfo.addEventListener(IOErrorEvent.IO_ERROR, ioErrorHandler);

大家知道Loader是用来代替原来 MovieClip的loadMovie功能,用于加载外部的图片文件,SWF文件。
如果加载图片文件(jpg,gif,png等)时,Loader.content得到数据类型是Bitmap对象;
如果加载SWF文件(flash 9 版本)时,Loader.content得到数据类型是MovieClip对象;
如果加载SWF文件(flash 9 以前版本) 时, Loader.content得到数据类型是AVM1Movie对象;

具体见  ()

当加载操作已开始或套接字已接收到数据时,将调度 ProgressEvent 对象。这些事件通常在将 SWF 文件、图像或数据加载到应用程序中时生成。有两种类型的进程事件:ProgressEvent.PROGRESS 和 ProgressEvent.SOCKET_DATA。
ProgressEvent.PROGRESS 64K触发一次事件。

 

[c-sharp] 
 
  1. actionscript中的urlloader使用       
  2. 2009-03-15 / Read(2)  Comments(0)  Category:其它技术       
  3. /*@post data to server*/       
  4. private function postData(src:String ,data:String ,callBack:Function):void       
  5. {       
  6.     var header1:URLRequestHeader = new URLRequestHeader("Content-Type" ,"application/json;charset=utf-8");       
  7.     var header2:URLRequestHeader = new URLRequestHeader("Accept" ,"application/json");       
  8.     var request:URLRequest = new URLRequest(src);       
  9.     request.data = data;       
  10.     request.method = URLRequestMethod.POST;       
  11.     request.requestHeaders = [header1 ,header2];       
  12.            
  13.     var loader:urlloader = new urlloader();       
  14.     loader.dataFormat = urlloaderDataFormat.TEXT;       
  15.     loader.addEventListener(Event.COMPLETE,       
  16.     function():void{       
  17.         callBack(loader.data);         
  18.     });       
  19.     loader.load(request);       
  20.            
  21. }       
  22. /*@get data from server*/       
  23. private function getData(src:String ,callBack:Function):void       
  24. {       
  25.     var header1:URLRequestHeader = new URLRequestHeader("Content-Type" ,"application/json;charset=utf-8");       
  26.     var header2:URLRequestHeader = new URLRequestHeader("Accept" ,"application/json");       
  27.     var request:URLRequest = new URLRequest(src);       
  28.     request.method = URLRequestMethod.GET;       
  29.     request.requestHeaders = [header1 ,header2];       
  30.            
  31.     var loader:urlloader = new urlloader();       
  32.     loader.dataFormat = urlloaderDataFormat.TEXT;       
  33.     loader.addEventListener(Event.COMPLETE,       
  34.     function():void{       
  35.         callBack(loader.data);         
  36.     });       
  37.     loader.load(request);       
  38.            
  39. }     

 

转载于:https://www.cnblogs.com/wonderKK/p/3539297.html

你可能感兴趣的文章
小程序底部导航栏
查看>>
ibatis学习笔记
查看>>
18-ES6(1)
查看>>
poj1611 简单并查集
查看>>
Ubuntu 14.04下安装CUDA8.0
查看>>
跨平台开发 -- C# 使用 C/C++ 生成的动态链接库
查看>>
C# BS消息推送 SignalR介绍(一)
查看>>
WPF星空效果
查看>>
WPF Layout 系统概述——Arrange
查看>>
PIGOSS
查看>>
几款Http小服务器
查看>>
iOS 数组排序
查看>>
第三节
查看>>
PHP结合MYSQL记录结果分页呈现(比较实用)
查看>>
Mysql支持的数据类型
查看>>
openSuse beginner
查看>>
Codeforces 620E(线段树+dfs序+状态压缩)
查看>>
Windows7中双击py文件运行程序
查看>>
Market entry case
查看>>
css3动画属性
查看>>