TWaver - 專注UI技術

          http://twaver.servasoft.com/
          posts - 171, comments - 191, trackbacks - 0, articles - 2
            BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

          打造自己的Flex AIR標題欄

          Posted on 2012-02-29 14:51 TWaver 閱讀(2353) 評論(0)  編輯  收藏
          有人問如何用代碼禁用Flex AIR程序標題欄的最大化, 最小化按鈕, 雖然app.xml文件里面可以控制是否禁用和啟用最大化, 最小化按鈕, 但是無法動態切換, 因為WindowedApplication.maximizable和WindowedApplication.minimizable是read only的. 下面就介紹一下如何定制自己的AIR程序標題欄, 先看下效果(是不是和原生的很像? 完全可以以假亂真了):

          1. 先隱藏原生的標題欄: 編輯xxx-app.xml, 找到systemChrome行, 取消注釋, 并設置值為none:

          <!-- The type of system chrome to use (either "standard" or "none"). Optional. Default standard. -->
              <systemChrome>none</systemChrome>

          2. 構造標題欄: 先用漸變色填充背景, 然后分別添加關閉, 最小化, 最大化按鈕以及標題. 幸運的是Flex的WindowedApplication提供了exit, minimize, maximize和restore方法, 關閉, 最小化, 最大化以及還原窗口算是非常簡單了:

          <s:Group width="100%" height="20">
                          <s:Rect id="background" left="0" top="0" right="0" bottom="0">
                              <s:fill>
                                  <s:LinearGradient rotation="90">
                                      <s:entries>
                                          <s:GradientEntry color="0xCCCCCC" ratio="0" alpha="1"/>
                                          <s:GradientEntry color="0x999999" ratio=".66" alpha="1"/>
                                      </s:entries>
                                  </s:LinearGradient>
                              </s:fill>
                          </s:Rect>
                          <s:Image source="close.png" click="exit()" width="20" y="2"/>
                          <s:Image source="min.png" click="minimize()" width="20" x="20" y="2"/>
                          <s:Image source="max.png" click="handleMax()" width="20" x="40" y="2"/>
                          <s:Label id="_titlebar" text="TestAir" left="60" top="0" right="0" bottom="0" textAlign="center" verticalAlign="middle"/>
                      </s:Group>
          			3. 給標題添加事件, 以達到拖拽標題時, 移動窗口. 這里走了不少彎路(開始用監聽鼠標移動事件, 計算鼠標的移動距離, 以修改nativeWindow的x和y坐標, 發現鼠標移動過程中, 窗口一直在抖動), 最后發現WindowedApplication的nativeWindow有startMove方法, 只要在mouse down事件里面調用此方法, 就可以達到移動窗口的目的:
          this.addEventListener(Event.ADDED_TO_STAGE, function(e:*):void {
              _titlebar.addEventListener(MouseEvent.MOUSE_DOWN, function (e:MouseEvent):void {
                  nativeWindow.startMove();
              });
          });
          本文完整代碼見附件:AirTitleBar


          只有注冊用戶登錄后才能發表評論。


          網站導航:
           
          主站蜘蛛池模板: 瑞安市| 明星| 瑞丽市| 闸北区| 巴青县| 宜城市| 青州市| 潞城市| 芦山县| 绥芬河市| 庆阳市| 天水市| 屏东县| 鹿泉市| 海盐县| 桓台县| 恩平市| 明光市| 安吉县| 沭阳县| 洛宁县| 昌邑市| 友谊县| 曲周县| 饶平县| 东山县| 恭城| 孝昌县| 大名县| 黄梅县| 香港 | 乐清市| 咸宁市| 怀宁县| 贡嘎县| 浮梁县| 开封县| 博野县| 淮滨县| 罗甸县| 万山特区|