Flex/AS3/flash player支持屏蔽右键菜单,自定义菜单,并设置相应的菜单事件(示例,图解)

简介:

Flex/AS3/flash player支持屏蔽右键菜单,自定义菜单,并设置相应的菜单事件(示例,图解)

播放器 版本 11.2以后支持右键菜单屏蔽及自定义菜单 1.更新播放器 ,11.2 以上版本

http://download.macromedia.com/get/flashplayer/updaters/11/playerglobal11_3.swc
http://download.macromedia.com/get/flashplayer/updaters/11/playerglobal11_4.swc
http://download.macromedia.com/get/flashplayer/updaters/11/playerglobal11_2.swc
http://download.macromedia.com/get/flashplayer/updaters/11/playerglobal11_5.swc

2.编译器参数设置-swf-version=15(见图)

  1. 自定义 菜单,并设置相应的菜单事件 (Flex代码)
<?xml version="1.0" encoding="utf-8"?>
<s:Application xmlns:fx="http://ns.adobe.com/mxml/2009"
 xmlns:s="library://ns.adobe.com/flex/spark"
 xmlns:mx="library://ns.adobe.com/flex/mx"
 xmlns:twaver="http://www.servasoftware.com/2009/twaver/flex"
 applicationComplete="init()">
 <fx:Script>
 <![CDATA[

 import mx.controls.Button;
 import mx.controls.Menu;
 import mx.events.MenuEvent;
 import mx.controls.Alert;

 private var menu:Menu = null;
 private var bt:Button = new Button();

 private function init():void {
 bt.label = "走你~";
 network.addElement(bt);
 network.addEventListener(MouseEvent.RIGHT_CLICK,handleRighClick);//监听右键
 }
 private function handleRighClick(e:MouseEvent):void {

 if(menu != null){
 menu.hide();
 }
 menu = Menu.createMenu(network, myMenuData, false);//myMenuData菜单数据源
 menu.labelField = "@label";//右键菜单的文字

 var point:Point = network.globalToLocal(new Point(e.stageX, e.stageY));
 menu.show(point.x, point.y);
 menu.addEventListener(MenuEvent.ITEM_CLICK,menuItemClickHandler); //菜单事件
 }

 private function menuItemClickHandler(evt:MenuEvent):void{
 Alert.show(evt.item.@eventName) //将事件名显示出来
 }
 ]]>
 </fx:Script>
 <fx:Declarations>
 <fx:XML id="myMenuData">
 <root label="MenuItem 1" >
 <menuitem label="new" eventName="new" />
 <menuitem label="refreash" eventName="refreash" />
 <menuitem label="remove" eventName="remove" />
 </root>

 </fx:XML>
 </fx:Declarations>
 <s:Group id="network" width="100%" height="100%" />
</s:Application>
目录
相关文章
|
1月前
|
容器
在 Flex 布局中,如何设置元素在侧轴上的初始对齐方式?
【10月更文挑战第22天】同时,还可以进一步探索其他 Flex 布局相关的属性和技巧,以更好地掌握 Flex 布局的强大功能,创造出更具创意和适应性的页面布局。
38 2
|
5月前
|
小程序
【微信小程序】英文字母不换行问题 flex布局字符超出宽度折行问题:设置了word-break: break-all;和flex: 1;冲突flex不生效问题
【微信小程序】英文字母不换行问题 flex布局字符超出宽度折行问题:设置了word-break: break-all;和flex: 1;冲突flex不生效问题
161 1
CSS3 【display: flex;】与【align-self: 可覆盖父元素设置的algin-items;】的使用
CSS3 【display: flex;】与【align-self: 可覆盖父元素设置的algin-items;】的使用
60 0
CSS3 【display: flex;】与【align-self: 可覆盖父元素设置algin-items;】的使用
CSS3 【display: flex;】与【align-self: 可覆盖父元素设置algin-items;】的使用
80 0
|
前端开发
css3属性flex弹性布局设置三列(四列)分布样式
参考:阮一峰的网络日志 doctype html> Document body{ padding: 0; margin: 0; } .
1465 0
Flex中如何通过设置GridLines对象的horizontalAlternateFill样式交错显示LineSeries图表背景颜色的例子
原文 http://blog.minidx.com/2008/11/27/1652.html 接下来的例子演示了Flex中如何通过设置GridLines对象的horizontalAlternateFill样式,交错显示LineSeries图表背景颜色。
953 0