7

ファイル名とサムネイルを表示し、ファイルをロード/再生するためのボタンを持つコンポーネントを作成しました。コンポーネントはリピーターにデータバインドされています。ボタン イベントがメイン アプリケーションに対して発生し、どのファイルを再生するかを伝えるようにするにはどうすればよいですか?

4

2 に答える 2

1

思いついた(やっと)

カスタム コンポーネント

<?xml version="1.0" encoding="utf-8"?>
<mx:Canvas xmlns:mx="http://www.adobe.com/2006/mxml" x="0" y="0" width="215" height="102" styleName="leftListItemPanel" backgroundColor="#ECECEC" horizontalScrollPolicy="off" verticalScrollPolicy="off">
<mx:Script>
    <![CDATA[
        [Bindable] public var Title:String = "";
        [Bindable] public var Description:String = "";
        [Bindable] public var Icon:String = ""; 
        [Bindable] public var FileID:String = "";
        private function viewClickHandler():void{
            dispatchEvent(new Event("viewClick", true));// bubble to parent
        }
    ]]>
</mx:Script>
<mx:Metadata>
    [Event(name="viewClick", type="flash.events.Event")]
</mx:Metadata>
<mx:Label x="11" y="9" text="{String(Title)}" styleName="listItemLabel"/>
<mx:TextArea x="11" y="25" height="36" width="170" backgroundAlpha="0.0" alpha="0.0" styleName="listItemDesc" wordWrap="true" editable="false" text="{String(Description)}"/>
<mx:Button x="20" y="65" label="View" click="viewClickHandler();" styleName="listItemButton" height="22" width="60"/>
<mx:LinkButton x="106" y="68" label="Details..." styleName="listItemLink" height="18"/>
<mx:HRule x="0" y="101" width="215"/>

リピーター

<mx:Canvas id="pnlSpotlight" label="SPOTLIGHT" height="100%" width="100%" horizontalScrollPolicy="off">
    <mx:VBox width="100%" height="80%" paddingTop="2" paddingBottom="1"  verticalGap="1">
        <mx:Repeater id="rptrSpotlight" dataProvider="{aSpotlight}">            
            <sm:SmallCourseListItem 
                viewClick="PlayFile(event.currentTarget.getRepeaterItem().fileName);"
                Description="{rptrSpotlight.currentItem.fileDescription}"
                FileID = "{rptrRecentlyViewed.currentItem.fileName}"    
                Title="{rptrSpotlight.currentItem.fileTitle}" />
        </mx:Repeater>
    </mx:VBox>
</mx:Canvas>

ハンドリング機能

private function PlayFile(fileName:String):void{
    Alert.show(fileName.toString());
}
于 2008-08-06T19:23:41.287 に答える
1

カスタム コンポーネントでは、ボタン クリック イベントをリッスンし、再生するファイルに関する情報を保持するカスタム イベントを生成できます。その後、イベントで bubbles プロパティを true に設定し、カスタム コンポーネントからカスタム イベントをディスパッチできます。バブル プロパティは、イベントを表示リストに浮かび上がらせ、メイン アプリケーションに到達させます。これで、メイン アプリケーションでそのイベントをリッスンし、正しいファイルを再生できます。お役に立てれば。

于 2008-08-06T19:25:37.400 に答える