2009-11-09 7 views
0

XML 파일 (아래)에서 반환 된 "항목"을 나열하는 데이터 격자가있는 페이지 (아래)가 있습니다.로드 할 때 각 항목의 뷰 스택에 페이지가 생성되었습니다 발견 (작동) 그것은 또한 각 패널 안에 페이지 (아래) 렌더링하지만 데이터를 전달하는 데 문제가 있습니다. 각 페이지는 렌더링되고로드되지만 XML 데이터의 첫 번째 결과는 각 페이지가 자체 데이터를 가지지 않고 모두 첫 페이지와 동일합니다.패널 내의 Flex 렌더러 데이터

HomePage.mxml

<?xml version="1.0" encoding="utf-8"?> 
<mx:Canvas xmlns:mx="http://www.adobe.com/2006/mxml" 
width="100%" height="100%" 
creationComplete="init()" 
xmlns:software="com.xd.components.pages.software.*" 
xmlns:pages="com.xd.components.pages.*" 
xmlns:renderers="com.xd.components.renderers.*"> 
<mx:Script> 
<![CDATA[ 
import mx.core.Application; 
import com.xd.components.renderers.PageListRenderer; 
import mx.containers.Panel; 
import mx.core.Container; 
import com.xd.components.renderers.SoftwareListRenderer; 
import mx.utils.ObjectProxy; 
import mx.controls.Alert; 
import mx.rpc.events.ResultEvent; 
import mx.containers.VBox; 
[Bindable] public var httpData:Object; 
[Bindable] public var selectedItem:String; 

     private function init():void { 
      //get data 
      httpService.send();  
     } 

     //private const MAX_CHILDREN:uint = 5; 

     private function viewstack_addChild(name:String):void { 
      var p:Panel = new Panel(); 
      p.id = name; 
      p.name = name; 
      p.title = name; 
      p.percentWidth = 100; 
      p.percentHeight = 100; 
      var randColor:uint = Math.random() * 0xFFFFFF; 
      p.setStyle("backgroundColor", randColor); 
      var pR:PageListRenderer = new PageListRenderer(); 
      //var data:Object; 
      //Do something to get the data to be displayed; 
      //data = httpService.lastResult.item; 
      pR.data = httpData; 
      p.addChild(pR); 
      myViewStack.addChild(p); 
     } 
     private function httpResult_handler(evt:ResultEvent):void { 
      if (evt.result.software.item) { 

      httpData = XML(evt.result).descendants("item"); 
      var item:Object = httpData; 
      for each(item in httpData) { 
       viewstack_addChild(item.name); 
      } 
      } 
     } 
    public function switchView(viewId:String):void 
    { 
     var container:Container = Container(myViewStack.getChildByName(viewId)); 
     selectedItem = viewId; 
     if (container != null) 
     { 
      myViewStack.selectedChild = container; 
     } 
    } 
    ]]> 
</mx:Script> 

<mx:HTTPService id="httpService" url="data/Software.xml" resultFormat="e4x" result="httpResult_handler(event)" fault="Alert.show('XML Data Error')" /> 

<mx:VBox width="100%" height="100%" horizontalAlign="center" verticalAlign="middle"> 
<mx:HBox width="100%" height="100%"> 
<mx:VBox width="30%" height="100%"> 
<mx:Panel borderThicknessLeft="0" borderThicknessRight="0" borderThicknessBottom="0" width="100%" height="100%" title="Software List:"> 
    <mx:DataGrid id="myDG" 
       dataProvider="{httpData}" 
       headerHeight="0" 
       editable="false" 
       width="100%" height="100%" 
       rowHeight="50" 
       itemClick="switchView(myDG.selectedItem.name);"> 

     <mx:columns> 
      <mx:DataGridColumn itemRenderer="com.xd.components.renderers.SoftwareListRenderer" /> 
     </mx:columns> 

    </mx:DataGrid> 
</mx:Panel> 
</mx:VBox> 
<mx:VBox width="70%" height="100%"> 
<mx:ViewStack id="myViewStack" width="100%" height="100%" hideEffect="WipUp" showEffect="WipeDown" creationPolicy="all"> 
    <pages:NewsPage id="NewsPage" height="100%" width="100%" horizontalScrollPolicy="off" verticalScrollPolicy="off" /> 
    <software:ShowTracker id="ShowTracker" height="100%" width="100%" horizontalScrollPolicy="off" verticalScrollPolicy="off" /> 
</mx:ViewStack> 
</mx:VBox> 
</mx:HBox> 
</mx:VBox> 
</mx:Canvas> 

PageListRenderer.mxml

<?xml version="1.0" encoding="utf-8"?> 
<mx:HBox 
height="100%" 
width="100%" 
xmlns:mx="http://www.adobe.com/2006/mxml"> 

<mx:Script> 
<![CDATA[ 
    import mx.core.Application; 
]]> 
</mx:Script> 
<mx:VBox width="100%" height="100%"> 
<mx:VBox height="70%" width="100%" horizontalAlign="center" verticalAlign="middle"> 
    <mx:Image source="{data.image}" width="90%" height="90%"/> 
</mx:VBox> 
<mx:VBox height="30%" width="100%" horizontalAlign="left" verticalAlign="top"> 
    <mx:Label width="100%" text="Name/Version:" color="#FFFFFF"/> 
    <mx:Label width="100%" text="{data.name}" color="#FFAE00"/> 
    <mx:Label width="100%" text="{data.version}" color="#FFAE00"/> 
    <mx:Label width="100%" text="{data.longdesc}" color="#FFFFFF"/> 
<mx:Button click="installApp()" label="Install Application" horizontalCenter="0" verticalCenter="0" width="160" height="52" id="install" visible="false"/> 
    <mx:Button click="launchApp()" label="Launch Application" horizontalCenter="0" verticalCenter="0" width="160" height="52" id="launch" visible="false"/> 
</mx:VBox> 
</mx:VBox> 
</mx:HBox> 

Software.xml

<software> 

<item> 
<name>ShowTracker</name> 
<version>1.0</version> 
<shortdesc>TV Show Tracker.</shortdesc> 
<image></image> 
<longdesc>ShowTracker allows you to manage all the TV Shows you watch. I helps you keep track of what episode you are upto for each series you are currently watching</longdesc> 
<appid>com.showtracker</appid> 
<pubid>EB6DA1B683461BF1C71FEC13E276982941DF167B.1</pubid> 
<appurl>http://www.nitcom.com.au/showtracker/downloads/ShowTracker-v1.air</appurl> 
<runversion>1.5</runversion> 
</item> 
<item> 
<name>Test2</name> 
<version>1</version> 
<shortdesc>test desC#2</shortdesc> 
<image>test1.jpg</image> 
<longdesc>test1.jpg</longdesc> 
<appid>com.showtracker</appid> 
<pubid>EB6DA1B683461BF1C71FEC13E276982941DF167B.1</pubid> 
<appurl>http://www.nitcom.com.au/showtracker/downloads/ShowTracker-v1.air</appurl> 
<runversion>1.5</runversion> 
</item> 
<item> 
<name>Test #3</name> 
<version>1</version> 
<shortdesc>test desC#3</shortdesc> 
<image>test1.jpg</image> 
<longdesc>test1.jpg</longdesc> 
<appid>com.showtracker</appid> 
<pubid>EB6DA1B683461BF1C71FEC13E276982941DF167B.1</pubid> 
<appurl>http://www.nitcom.com.au/showtracker/downloads/ShowTracker-v1.air</appurl> 
<runversion>1.5</runversion> 
</item> 
</software> 

답변

0

이 문제를 일으키는 지 잘 모릅니다하지만 다음과 같습니다

private function httpResult_handler(evt:ResultEvent):void { 
    if (evt.result.software.item) { 

     httpData = XML(evt.result).descendants("item"); 
     var item:Object = httpData; 
     for each(item in httpData) { 
      viewstack_addChild(item.name); 
     } 
    } 
} 

요구 사항이있을 수 있습니다 :

private function httpResult_handler(evt:ResultEvent) :void { 
    if(evt.result.software.item){ 
    var httpData:XMLList = XML(evt.result).descendants("item"); 
    for each(var item:Object in httpData){ 
     viewstack_addChild(item.name); 
    } 
    } 
} 

을 정말 당신은보기가 전체 항목을 스택에 합격하고 그것을 개별 속성을 보내는 대신 필요한 것을 보자한다.

+0

안녕하세요 Greg, "private function viewstack_addChild (name : String) : void"에서 응답하지 않았습니다. pR.data = httpData? 또는 그 부분이 잘못 되었습니까? 당신이 참조하고있는 함수는 유일한 이름으로 각 페이지를 생성 할 수 있도록 이름을 보내고 있습니다. – medoix

+0

붙여 넣은 버전에는 원래 httpData에 대해 가지고 있던 변수가 바인드 가능 객체 였기 때문에 var httpData : XMLList를 httpData로 변경하고 맨 위의 변수를 XMLList로 변경하면 전체적으로 많이 손상됩니다 전에 작업했던 방식으로 돌아 가면 데이터 그리드는 괜찮지 만 페이지의 내용은 모두 동일합니다. – medoix

+0

일부 작업을 마친 후에 item.name을 전달하는 대신 올바른 항목을 전달하고 viewstack_addChild (name : String) 함수를 viewstack_addChild (item : Object)로 변경하여 이제 모든 데이터를 올바르게 사용할 수있게되었습니다. . 그렉 고마워. – medoix

관련 문제