`

【转】Air 右键菜单和系统托盘

    博客分类:
  • Flex
阅读更多

<?xml version="1.0" encoding="utf-8"?>
<mx:WindowedApplication xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute" alwaysInFront="true" width="314"
    height="420" titleBarColors="[0x000000,0x888888]" applicationComplete="initApplication();">
    <mx:Script>
        <![CDATA[
        import mx.events.CloseEvent;
        import mx.controls.Alert;
        private var dockImage:BitmapData;
        public function initApplication():void{  
                var loader:Loader=new Loader();  
                loader.contentLoaderInfo.addEventListener(Event.COMPLETE,prepareForSystray);// 这里就是完成第一步的任务须,这个prepareForSystray就是对托盘的生在和菜单的控制  
                loader.load(new URLRequest("images/regt.png"));//这里先要加载托盘图标的小图片  
                this.addEventListener(Event.CLOSING,closingApplication);//设置关闭体的事件  
            }  

        //关闭窗体的事件  

            public function closingApplication(event:Event):void{  

                event.preventDefault();//阻止默认的事件  
                Alert.yesLabel="Close";  
                Alert.noLabel="Mini";  
                Alert.show("Close or Minimize?", "Close?", 3, this, alertCloseHandler);//弹出自定义的选择框, 关于Alert的详细用法,参考官方文档或我前面的相关文章.  
            }  

        //根据用户的选择来判断做什么,这里选择是就是关闭,选择否(Mini)就是最小化到托盘.  

        private function alertCloseHandler(event:CloseEvent):void{  

            if(event.detail==Alert.YES){  
                closeApp(event);  
            }else{  
                dock();//最小化到托盘  
            }  
        }  

    //生成托盘  

        public function prepareForSystray(event:Event):void{  
            dockImage=event.target.content.bitmapData;  
            if(NativeApplication.supportsSystemTrayIcon){  
               setSystemTrayProperties();//设置托盘菜单的事件  
                SystemTrayIcon(NativeApplication.nativeApplication.icon).menu=createSystrayRootMenu();//生成托盘菜单  
            }     
        }  

        public function createSystrayRootMenu():NativeMenu{  
            var menu:NativeMenu = new NativeMenu();  
            var openNativeMenuItem:NativeMenuItem = new NativeMenuItem("Open");//生成OPEN菜单项  
            var exitNativeMenuItem:NativeMenuItem = new NativeMenuItem("Exit");//同理  
            openNativeMenuItem.addEventListener(Event.SELECT, undock);  
            exitNativeMenuItem.addEventListener(Event.SELECT, closeApp);//添加EXIT菜单项事件  
            menu.addItem(openNativeMenuItem);  
            menu.addItem(new NativeMenuItem("",true));//separator   
            menu.addItem(exitNativeMenuItem);//将菜单项加入菜单  
            return menu;  
        }  

        //设置托盘图标的事件  

        private function setSystemTrayProperties():void{  
            SystemTrayIcon(NativeApplication.nativeApplication .icon).tooltip = "TurboSquid squidword";  
            SystemTrayIcon(NativeApplication.nativeApplication .icon).addEventListener(MouseEvent.CLICK, undock);  
            stage.nativeWindow.addEventListener(NativeWindowDisplayStateEvent.DISPLAY_STATE_CHANGING, nwMinimized);   
        }  

//最小化窗体  

        private function nwMinimized(displayStateEvent:NativeWindowDisplayStateEvent):void {  
            if(displayStateEvent.afterDisplayState == NativeWindowDisplayState.MINIMIZED) {  
                displayStateEvent.preventDefault();//阻止系统默认的关闭窗体事件  
                dock();//将程序放入托盘  
            }  
        }  

        //将本地应用程序放到托盘  

        public function dock():void {  
            stage.nativeWindow.visible = false; //设置本地程序窗体不可见  
            NativeApplication.nativeApplication.icon.bitmaps = [dockImage];//设置托盘的图标  
        }  

        //激活程序窗体  

        public function undock(evt:Event):void {  
           stage.nativeWindow.visible = true;//设置本地程序窗体可见  
           stage.nativeWindow.orderToFront();//设置本地程序窗体到最前端  
           NativeApplication.nativeApplication .icon.bitmaps = [];//将托盘图标清空  
        }  

        //关闭程序窗体  

        private function closeApp(evt:Event):void {  
            stage.nativeWindow.close();  
        }      
        ]]>
    </mx:Script>   
</mx:WindowedApplication>

分享到:
评论

相关推荐

    AIR教程-AIR教程

    AIR教程 1 Adobe AIR右键菜单和系统托盘(Tray)功能以及实现方法 2 如何将应用程序最小化到托盘,然后给托盘图标加右键菜单以及添加相应的事件,来激活应用程序窗体

    Flex3Air最小化到系统托盘

    Flex3Air最小化到系统托盘 跨来下载吧,你会很高兴的哦。。。。。呵呵呵呵呵俄

    新浪AIR微博 v2.4.1

    微博AIR是基于Adobe AIR平台的新浪微博桌面客户端 【使用方法】第一步:安装 Adobe AIR 运行环境(已安装的用户请跳...如果出现登录框不显示的问题,请用如下方法解决:右键点托盘里的图标,选择"注销",重新登录即可。

    思科AP AIR-CAP1602I-C-K9瘦转胖

    思科AP AIR-CAP1602I-C-K9瘦...思科AP AIR-CAP1602I-C-K9瘦转胖需要进行一系列的配置和安装步骤,包括搭建FTP站点、配置AP、安装新的IOS镜像等。同时,需要了解相关技术概念和设备,以便更好地理解和实施瘦转胖的配置。

    flex3.0 (AIR) 模拟资源管理器

    使用FileSystemDataGrid 以及 FileSystemTree 模拟资源管理器,包括右键弹出菜单、菜单触发监听器、以及对FileSystemDataGrid 和 FileSystemTree 组件的属性的演示。另外,其中的“dateGridDemo.mxml”详细演示了另...

    MacBookAir安装双系统

    MacBookAir安装双系统,在MacBookAir上安装windows7.0系统,使MacBookAir可以选择系统启动,进入不同的使用系统环境。

    macbook air 如何安装xp系统

    macbook air 如何安装xp系统

    在windows下激活Airprint无线打印 AirPrint+Activator

    AirPrint无线打印技术当前仅面向Mac开放,并且只能在几款惠普打印机上实现。没有这些AirPrint兼容打印机的可以借助一款名为Printopia的Mac程序激活AirPrint功能,那么Windows... 确保系统防火q1an9放行airprint.exe。

    2013最新APPLE Macbook Air 安装单WINDOWS7 系统

    如何在最新2013款APPLE Macbook air上实现单windows7系统安装

    flex air 博客管理系统

    flex air 博客管理系统 学习用的例子

    用Flex AIR 做一个类似QQ消息提示在系统托盘闪烁图标

    NULL 博文链接:https://dzlg.iteye.com/blog/734992

    airprinter 1.6.6.1 无限制版

    如果你有台iPhone手机, 或者苹果iPad平板电脑,那么你可以很方便得利用苹果iOS系统内置AirPrint功能WiFi无线打印照片,Word,PDF等各种文件到你的Air Printer打印机,但有个前提是你的打印机必须支持苹果Air Print...

    Air Printer 1.6.6.1破解补丁

    如果你有台iPhone手机, 或者苹果iPad平板电脑,那么你可以很方便得利用苹果iOS系统内置AirPrint功能WiFi无线打印照片,Word,PDF等各种文件到你的Air Printer打印机,但有个前提是你的打印机必须支持苹果Air Print...

    新浪微博air v1.14.1.zip

    微博AIR是基于Adobe AIR平台的新浪微博桌面客户端   【使用方法】 第一步:安装 Adobe AIR 运行环境(已安装的用户请跳过)http://down.chinaz.com/soft/29198.htm...右键点托盘里的图标,选择"注销",重新登录即可。

    FLEX提高篇--------AIR应用程序的托盘及托盘菜单的制作

    只是源码的一部分不能运行 博文链接:https://hacker47.iteye.com/blog/208020

    小米笔记本AIR12.5安装黑苹果系统EFI.zip

    小米笔记本电脑AIR12.5 型号7代7Y54CPU,615显卡,256G固态以及4G内存配置相同就可以用必须要下载MAC10.15的系统版本才可以完美使用。

    STM32+EC20和STM32+Air724UG开发板原理图和PCB.zip

    STM32+EC20和STM32+Air724UG开发板原理图和PCB

    flex 4.6 树形多选+动态菜单

    包含2个demo 一个是树形多选框,可选中多个选项,并同时显示选中项的内容;一个是动态可伸缩的菜单,点击后弹出菜单,菜单失去焦点后收缩。

Global site tag (gtag.js) - Google Analytics