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 閱讀(2347) 評論(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


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


          網站導航:
           
          主站蜘蛛池模板: 大连市| 青冈县| 密云县| 咸阳市| 肃宁县| 丹寨县| 巴彦县| 玛曲县| 甘南县| 连州市| 雅江县| 阿合奇县| 桐庐县| 罗江县| 潼关县| 娱乐| SHOW| 平乡县| 万全县| 隆林| 托里县| 洱源县| 武汉市| 静乐县| 庄浪县| 怀化市| 鸡泽县| 阿克苏市| 宝丰县| 汉中市| 远安县| 潞西市| 无为县| 白河县| 交口县| 盘锦市| 望城县| 炉霍县| 合水县| 香格里拉县| 衡山县|