Для обработки щелчка мыши на пункте меню добавьте к объекту NativeMenuItem прослушиватель для события
select
:
var menuCommandX:NativeMenuItem = new NativeMenuItem("Command X");
menuCommandX.addEventListener(Event.SELECT, doCommandX)
Так как события
select
передаются вверх по иерархии, можно также прослушивать события select в родительском меню. При прослушивании на уровне меню для определения того, какая команда была выбрана, можно использовать свойство
target
объекта события. В примере ниже показано, как отслеживать выбранную команду с помощью метки:
var colorMenuItem:NativeMenuItem = new NativeMenuItem("Choose a color");
var colorMenu:NativeMenu = new NativeMenu();
colorMenuItem.submenu = colorMenu;
var red:NativeMenuItem = new NativeMenuItem("Red");
var green:NativeMenuItem = new NativeMenuItem("Green");
var blue:NativeMenuItem = new NativeMenuItem("Blue");
colorMenu.addItem(red);
colorMenu.addItem(green);
colorMenu.addItem(blue);
if(NativeApplication.supportsMenu){
NativeApplication.nativeApplication.menu.addItem(colorMenuItem);
NativeApplication.nativeApplication.menu.addEventListener(Event.SELECT, colorChoice);
} else if (NativeWindow.supportsMenu){
var windowMenu:NativeMenu = new NativeMenu();
this.stage.nativeWindow.menu = windowMenu;
windowMenu.addItem(colorMenuItem);
windowMenu.addEventListener(Event.SELECT, colorChoice);
}
function colorChoice(event:Event):void {
var menuItem:NativeMenuItem = event.target as NativeMenuItem;
trace(menuItem.label + " has been selected");
}
Если используется класс ContextMenuItem, можно прослушивать либо событие
select
, либо событие
menuItemSelect
. Событие
menuItemSelect
дает дополнительную информацию об объекте, которому принадлежит контекстное меню, но не передается вверх по иерархии.