質問

私はダグMcCune氏<によって CoverFlowのライブラリで働いています/>。

付属の例では、彼はCoverFlowContainer内のいくつかのパネルを作成しました。そこ上記のリンクページのRSSフィードからカバーフローを取り込む彼の他の例があるが、彼は、これらのソースが含まれていません:(

私は最終的に私はこの単純な例で始めているがカバーフローに追加するWebサービスからデータを取得します

<?xml version="1.0" encoding="utf-8"?>
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="vertical" horizontalAlign="center" verticalAlign="middle"    xmlns:containers="com.dougmccune.containers.*" creationComplete="init()">
<mx:Script>
    <![CDATA[

        import mx.controls.TextArea;

        public var articlePanel:Panel = new Panel();
        public var articleTextArea:TextArea = new TextArea();

        private function init() : void
        {
            articlePanel.addChild(articleTextArea);
            articlePanel.title = "test tile"
            articleTextArea.text = "article1" + "\n" + "www.article.com" + "\n" + "hello this is article 1";
            coverflow2.addChild(articlePanel);  
        }       
    ]]>
</mx:Script>

<mx:VBox id="box" verticalGap="0" height="306" width="100%" maxWidth="600" maxHeight="300" >

           <containers:CoverFlowContainer id="coverflow2" width="100%" height="244" 
            horizontalGap="40" borderStyle="inset" backgroundColor="0x000000"
            segments="6" reflectionEnabled="true">

            <mx:Panel id="testpanel" width="200" height="200" title="Mxml title">
                <mx:DataGrid width="100%" height="100%">
                    <mx:columns>
                        <mx:DataGridColumn headerText="Column 1" dataField="col1"/>
                        <mx:DataGridColumn headerText="Column 2" dataField="col2"/>
                        <mx:DataGridColumn headerText="Column 3" dataField="col3"/>
                    </mx:columns>
                </mx:DataGrid>
            </mx:Panel>

            <mx:Panel id="buttonpanel" width="200" height="200" title="Mxml title">
                <mx:Button id="myButton" label="Change title" click="buttonpanel.title = ('hello') "/>
            </mx:Panel>
        </containers:CoverFlowContainer>                
    </mx:VBox>
     </mx:Application>

私はMXMLで、いくつかのパネルを定義したと私はActionScriptで作成した新しいパネルがCoverFlowのコンテナに追加されるようにcreationComplete=init()設定します。

私は、アプリケーションを起動すると、

これは、2枚の定義済みのパネルではなく、私はActionScriptで作成したものを表示します。

任意のアイデア?これを行うのは良い方法はありますか?

役に立ちましたか?

解決 2

最初にそれに何もカバーフローコンテナを定義することによって、これを修正します:

<containers:CoverFlowContainer id="coverflow" width="100%" height="244" 
                horizontalGap="40" borderStyle="inset" backgroundColor="0x000000"
                reflectionEnabled="true"/>

は、ActionScriptセクションでIは、Webサービスからの配列を取得し、配列内の各アイテムのために私はパネルを作成します。それ以外の場合は唯一のカバーフロー内の要素または全くの要素が表示されます各パネルに幅と高さを与えることが重要です。

articlePanel.width = 200;
articlePanel.height = 200;

他のヒント

あなたがMXを試すことができます:Repeaterコンポーネント

<mx:HTTPService id="srv" url="pics.xml"/>
<ns2:CarouselContainer id="cf" width="100%" height="303" horizontalGap="40"
                       segments="6" reflectionEnabled="true" angle="10" >

    <mx:Repeater id="r" dataProvider="{srv.lastResult.images.image}">
        <mx:Canvas width="200" height="200">
            <mx:Image source="{r.currentItem.src}"/>
        </mx:Canvas>
    </mx:Repeater>

</ns2:CarouselContainer>
scroll top