我编写了一个组件,它显示文件名,缩略图并具有一个用于加载/播放文件的按钮。该组件是绑定到中继器的数据。我怎样才能让按钮事件触发主应用程序并告诉它要播放哪个文件?Adobe Flex组件事件
5
A
回答
1
在您的自定义组件上,您可以收听按钮单击事件,然后生成一个自定义事件,其中包含有关要播放的文件的信息。然后,您可以将事件的bubbles属性设置为true,并从您的自定义组件中分派自定义事件。气泡属性将使您的事件浮出显示列表并到达主应用程序。现在在您的主应用程序中,您可以收听该事件并播放正确的文件。希望这可以帮助。
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());
}
相关问题
- 1. Adobe Flex极端组件
- 2. Adobe导游组件Flex
- 3. Adobe Flex计时器事件
- 4. Adobe Flex/Actionscript事件处理命令
- 5. Adobe Flex的切换组件全屏
- 6. Adobe Flex DeepLinking
- 7. Adobe Flex RichTextEditor
- 8. Adobe Flex arraycollection
- 9. Adobe Edge onload事件
- 10. Adobe Flex key capture
- 11. Adobe Flex日期
- 12. Adobe flex layout redraw
- 13. Adobe Flex的unicodeRange
- 14. Adobe Flex Charting SDK
- 15. Adobe Flex Datagrid:addEventListener MouseEvent.CLICK
- 16. Adobe Flex的.swf文件缓存
- 17. Adobe Flex空气文件预览
- 18. Adobe Flex的文件上传
- 19. Adobe Flex - 生成XML文件
- 20. Adobe Flex在电子邮件中?
- 21. Adobe Flex:从组件MXML中的主应用程序访问结果事件
- 22. Adobe Illustrator - 文件分组
- 23. Adobe CQ5全球组件
- 24. Adobe AIR HTML组件 - socket.io
- 25. Adobe Flex - 标签值上的MouseDown事件
- 26. Adobe Flex:启用= false的spark组件的工具提示
- 27. Adobe Flex 4.5 Spark:绑定ItemRenderer组件到父
- 28. Adobe Flex的设置样式为组件的状态
- 29. Adobe Flex - 如何在图像的“窗口”中嵌入组件?
- 30. Adobe Flex中的HitTest