« UpdateManager Updated :-) | Main | RIA Developer Camp »
AIR ContextWindow
| By Rich Tretola | October 18, 2007 | Print This Post
|
| 676 views |
Looking for an easy way to add window controls as a context menu to your AIR windows? Try my new ContextWindow class.

OK, so this is not rocket science by any means, it is just a class that extends mx.core.Window and creates a NativeMenu within the constructor and assigns it to the contextMenu property. To use it, simply download the class and create an instance of it just as you would with the regular Window class.
Here is a sample application file:
- <?xml version="1.0" encoding="utf-8"?>
- <mx:WindowedApplication xmlns:mx="http://www.adobe.com/2006/mxml"
- layout="absolute">
- <mx:Script>
- <![CDATA[
- import com.everythingflex.air.components.ContextWindow;
- private function createWindow():void{
- var w:ContextWindow = new ContextWindow();
- w.width=200;
- w.height=100;
- w.open();
- }
- ]]>
- </mx:Script>
- <mx:Button click="createWindow()" label="Create Wndow"
- horizontalCenter="0" verticalCenter="0"/>
- </mx:WindowedApplication>
Here is the ContextWindow.as class file:
- package com.everythingflex.air.components
- {
- import flash.display.NativeMenu;
- import flash.display.NativeMenuItem;
- import flash.events.Event;
- import mx.core.Window;
- public class ContextWindow extends Window
- {
- public function ContextWindow():void{
- super();
- createMenu();
- }
- private function createMenu():void{
- var mainMenu:NativeMenu = new NativeMenu();
- var minimizeMenu:NativeMenuItem = new NativeMenuItem("Minimize");
- var maximizeMenu:NativeMenuItem = new NativeMenuItem("Maximize");
- var restoreMenu:NativeMenuItem = new NativeMenuItem("Restore");
- var closeMenu:NativeMenuItem = new NativeMenuItem("Close");
- minimizeMenu.addEventListener(Event.SELECT, handleMenuClick);
- maximizeMenu.addEventListener(Event.SELECT, handleMenuClick);
- restoreMenu.addEventListener(Event.SELECT, handleMenuClick);
- closeMenu.addEventListener(Event.SELECT, handleMenuClick);
- mainMenu.addItem(minimizeMenu);
- mainMenu.addItem(maximizeMenu);
- mainMenu.addItem(restoreMenu);
- mainMenu.addItem(closeMenu);
- this.contextMenu=mainMenu;;
- }
- private function handleMenuClick(e:Event):void{
- var menuItem:NativeMenuItem = e.target as NativeMenuItem;
- if(menuItem.label == "Minimize") this.minimize();
- if(menuItem.label == "Maximize") this.maximize();
- if(menuItem.label == "Restore") this.restore();
- if(menuItem.label == "Close") this.close();
- }
- }
- }
Topics: Adobe AIR, Components |








October 19th, 2007 at 9:33 pm
public class ContextWindow extends Window
but why:
ContextWindow can’t find open();
October 22nd, 2007 at 12:32 pm
Not sure, this works fine for me:
var w:ContextWindow = new ContextWindow();
w.open();
December 12th, 2007 at 11:38 am
Thanks for all the different interesting articles. We like
to visit your website and the diverse postings.
June 27th, 2008 at 7:27 am
Is there a way to specify a context menu for the main application instead of one for a popup ? Thanks for this usefull article
June 27th, 2008 at 8:17 am
Yes, but not with this component. When you create a context menu, you can attach it to any object (Images, Panel, Boxes, etc).
August 11th, 2008 at 8:31 am
please any body can help me in achieving the functionality of minimising and maximising the menu in flex with the same button??
thanks in advance
October 30th, 2008 at 7:44 am
thanks.