Eventi del componente Adobe Flex
-
08-06-2019 - |
Domanda
Ho scritto un componente che visualizza un nome file, una miniatura e ha un pulsante per caricare/riprodurre il file.Il componente è collegato a un ripetitore.Come posso fare in modo che l'evento del pulsante venga attivato sull'applicazione principale e le indichi quale file riprodurre?
Soluzione
Sul tuo componente personalizzato puoi ascoltare l'evento clic sul pulsante e quindi generare un evento personalizzato che contiene informazioni sul file che desideri riprodurre.Puoi quindi impostare la proprietà bubbles su true sull'evento e inviare l'evento personalizzato dal tuo componente personalizzato.La proprietà Bubbles farà fluttuare il tuo evento nell'elenco di visualizzazione e raggiungerà la tua applicazione principale.Ora sulla tua applicazione principale puoi ascoltare quell'evento e riprodurre il file corretto.Spero che questo ti aiuti.
Altri suggerimenti
L'ho capito (finalmente)
Componente personalizzato
<?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"/>
Il Ripetitore
<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>
Funzione di manipolazione
private function PlayFile(fileName:String):void{
Alert.show(fileName.toString());
}