コンテキストメニューを使う事は、私自身あまり無いので気づかなかったのですが
ブラウザで表示する場合と、AdobeAIRでの表示ではちょっと扱いが違うようだ
ブラウザで表示する場合、特定のオブジェクトに対してコンテキストメニューを追加しなくても
this.contextMenu = _ContextMenu;
のように [ this ] に対して設定する事が出来るが、AdobeAIRの場合は特定のオブジェクトに対して設定しないとコンテキストメニューが表示されないようだ
例:[ムービークリップオブジェクト].contextMenu = _ContextMenu;
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 | package{ import flash.display.*; import flash.events.*; import flash.net.*; import flash.system.*; import flash.ui.*; public class ContextMenuClass extends Sprite{ private var _ContextMenu:ContextMenu; private var _SubMenu:NativeMenu; public function ContextMenuClass(){ trace("ContextMenuClass"); stage.showDefaultContextMenu = true; var myMC:MovieClip = new MovieClip(); var bmd:BitmapData = new BitmapData(200, 200, false, 0xCCCCCC); var bmp:Bitmap = new Bitmap(bmd); myMC.addChild(bmp); addChild(myMC); _ContextMenu = new ContextMenu(); _ContextMenu.hideBuiltInItems(); _SubMenu = new NativeMenu(); //コンテキストメニューアイテムにプロパティを設定する var captionArray:Array = new Array(); for(var count:int=0; count<10; count++){ var itemName:String = "項目" + count.toString(); captionArray.push(itemName); } for(var i:int=0; i<captionArray.length; i++){ var item:ContextMenuItem = new ContextMenuItem(""); if(i<5){ item.caption = captionArray[i]; // キャプション名 item.enabled = true; // 有効か item.separatorBefore = false; // 1つ上にセパレータを付ける item.visible = true; // 可視表示するか item.addEventListener(ContextMenuEvent.MENU_ITEM_SELECT,selectHandler); // 項目選択時の処理 _ContextMenu.customItems.push(item); }else{ item.caption = captionArray[i]; // キャプション名 item.enabled = true; // 有効か item.separatorBefore = false; // 1つ上にセパレータを付ける item.visible = true; // 可視表示するか item.addEventListener(ContextMenuEvent.MENU_ITEM_SELECT,selectHandler); // 項目選択時の処理 _SubMenu.addItem(item); } } // item.visible = true or false で項目毎の表示がハンドリング可 myMC.contextMenu = _ContextMenu; } private function selectHandler(event:Event):void{ trace(event.currentTarget.caption); } } } |