Flex4之將Sprite控件添加到FLEX UI中


 
    在Flex的幫助文檔里,有很多例子都是擴展Sprite類的。如果想把這些實例添加到你的s:Application中,如:addChild(DisplayObject ),肯定會出錯。錯誤的大致意思是:flash.display::Sprite沒有實現mx.core.IUIComponent接口。
    Sprite->DisplayObjectContainer ->InteractiveObject ->DisplayObject ->EventDispatcher ->Object
從Sprite的繼承關系來看,它雖然是DIsplayObject但是它沒有實現IUIComponent,不能直接添加到Flex組件里是當然的了。
    Flex文檔上指出所有的可視化控件都繼承自UIComponent 而它自己是實現了IUIComponent 接口的。UIComponent 允許添加Sprite和MovieClip。
經常使用到的做法是:
   var comp: UIComponent = new UIComponent ();
   comp.
addChild
(sprite);
   cavas1.
addChild(comp);
這樣flash控件就能正常在flex組件里顯示了。
舉個例子我在as文件中這么寫

 

Java代碼 復制代碼  收藏代碼
  1. <SPAN style="FONT-SIZE: medium">package components   
  2. {   
  3.     import flash.display.*;   
  4.     import flash.net.URLRequest;   
  5.     public class Main extends Sprite {   
  6.         public function Main(  ) {   
  7.             var loader:Loader = new Loader(  );   
  8.             addChild( loader );   
  9.             loader.load( new URLRequest( "img/aa.jpg" ) );   
  10.         }   
  11.     }   
  12.   
  13. }</SPAN>  
 

 

 然后具體顯示就想上面說的那樣
  
Xml代碼 復制代碼  收藏代碼
  1. <SPAN style="FONT-SIZE: medium"><?xml version="1.0" encoding="utf-8"?>  
  2. <s:Application xmlns:fx="http://ns.adobe.com/mxml/2009"    
  3.                xmlns:s="library://ns.adobe.com/flex/spark"    
  4.                xmlns:mx="library://ns.adobe.com/flex/mx" minWidth="955" minHeight="600" creationComplete="init()">  
  5.     <fx:Declarations>  
  6.         <!-- 將非可視元素(例如服務、值對象)放在此處 -->  
  7.     </fx:Declarations>  
  8.    <fx:Script>  
  9.        <![CDATA[  
  10.            import components.Main;  
  11.              
  12.            import mx.core.UIComponent;  
  13.            function init():void{  
  14.               var comp: UIComponent = new UIComponent();  
  15.               var main:Main=new Main();  
  16.               comp.addChild(main);  
  17.               this.addElement(comp);  
  18.            }  
  19.        ]]>  
  20.    </fx:Script>  
  21. </s:Application>  
  22. </SPAN>  


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM