青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

twzheng's cppblog

『站在風口浪尖緊握住鼠標旋轉!』 http://www.cnblogs.com/twzheng

  C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
  136 隨筆 :: 78 文章 :: 353 評論 :: 0 Trackbacks
Flash ActionScript 3.0 實現的樹形菜單

這是我初學ActionScript 3.0時實現的treeMenu類, 貼出來分享,或許對ActionScript 3.0的初學者有一定的幫助,但不建議在應用程序開發中使用。

各位博友可以就此發表自己的觀點,謝謝各位指教。

下面是treeMenu類的定義:
/**
 *    treeMenu類
 *     
 *    構造一個樹形菜單
 *    
 *    @author    twzheng (twzheng@msn.cn)
 *    @date    20070903
 *    @version    1.0.070903
 *    
 
*/


////////////////////////////////////////////////////////////////////////////////////////////
//
    在這里添加修改說明:
//
//
//
//////////////////////////////////////////////////////////////////////////////////////////

package com.components
{
    import flash.display.MovieClip;
    
    public class treeMenu extends MovieClip
    
{
        public 
var rootMenu:menuItem;
        
        
function treeMenu()
        
{
        }

        
        public 
function newTreeMenu()
        
{
            
if(rootMenu != null)
            
{
                trace(
" 錯誤:根菜單已存在,根菜單只能有一個!");
                
return;
            }

            rootMenu 
= new menuItem("rootMenu","rootMenu");
            
if(rootMenu == null)
            
{
                trace(
" 創建根菜單失??!");
                
return;
            }

            rootMenu.removeChild(rootMenu.menuLabel);
            rootMenu.childMenu.x 
= 0;
            rootMenu.childMenu.y 
= 0;
            
this.addChild(rootMenu);
        }

        
        public 
function addChildMenu(bMenu:menuItem, mName:String, mLabel:String)
        
{
            
var mItem = new menuItem(mName,mLabel);
            
if(mItem == nullreturn;
            
var index:int = bMenu.childItem.length;
            
            mItem.y 
= menuItemLocalizer(bMenu.childItem);
            
            bMenu.childItem[index] 
= mItem;
            
            bMenu.childMenu.addChild(mItem);
        }

        
        private 
function menuItemLocalizer(bMenu:Array):int
        
{
            
var num:int = 0;
            
for each (var item in bMenu)
                num 
= num + item.getHeight();
            
return num;
        }

    }

}


/**
 * 菜單項節點類
 * 
 * @author    twzheng (http://www.ugocn.com)
 * @date    20070903
 * @version    1.0.070903
 
*/
    

import flash.display.DisplayObjectContainer;
import flash.display.MovieClip;
import flash.text.TextField;
import flash.events.MouseEvent;
import flash.events.Event;
import flash.ui.Mouse;

internal class menuItem extends MovieClip
{
    public 
var menuName:String;            // 菜單項名稱
    public var menuLabel:TextField;        // 菜單項標簽(即顯示給用戶的菜單標簽)
    public var childMenu:DisplayObjectContainer; // 子菜單項容器
    public var childItem:Array;            // 子菜單項數組
    
    private 
var h:Number;        // 菜單項高度屬性,記錄的是實際高度(包含隱藏菜單高度)
    
    
function menuItem(mName:String, mLabel:String)
    
{
        
if(mName == "" || mName == null || mLabel == null)
        
{
            trace(
" 菜單名或者菜單標簽為空,添加菜單項失敗!");
            
return;
        }

        menuName 
= mName;
        
        menuLabel 
= new TextField();
        menuLabel.text 
= mLabel;
        menuLabel.height 
= 22;
        menuLabel.textColor 
= 0x000000;
        menuLabel.background 
= false;
        menuLabel.addEventListener(MouseEvent.MOUSE_MOVE,itemMouseMove);
        menuLabel.addEventListener(MouseEvent.MOUSE_OUT,itemMouseOut);
        
this.addChild(menuLabel);
        
        childMenu 
= new MovieClip();
        childMenu.addEventListener(Event.ADDED,mcAddedEvent);
        childMenu.addEventListener(Event.REMOVED,mcRemovedEvent);
        
this.childMenu.x = this.menuLabel.x + 8;
        
this.childMenu.y = this.menuLabel.y + this.menuLabel.height;
        
this.addChild(childMenu);
        
        childItem 
= new Array();
        
        
this.h = menuLabel.height;
        
// 菜單項單擊事件應留給外部使用者實現
        //this.menuLabel.addEventListener(MouseEvent.CLICK,itemClick);
    }

    
    
// 返回菜單項顯示的真實高度,即菜單項的實際高度減去隱藏菜單項的高度
    public function getHeight():Number
    
{
        
return h - getHideMenu(this);
    }

    
    
/**
    * 獲取item的childMenu中所有隱藏子菜單項的高度和
    *
    * @item                主菜單項,此函數即計算它的子菜單中隱藏菜單的高度
    * @return            返回item的childMenu中visible屬性為false的子菜單高度和
    * 
    * 注:如果item.childMenu的visible屬性為false即返回childMenu的高度,如果item.childMenu為空則返回0。
    
*/

    private 
function getHideMenu(item:menuItem):Number
    
{
        
var sumHeight = 0;
        
if(item.childMenu.visible)
        
{
            
if(item.childItem == null)
                
return 0;
            
for(var i = 0; i < item.childItem.length; i++)
            
{
                
// 對每個子菜單項遞歸
                sumHeight = sumHeight + getHideMenu(item.childItem[i]);
            }

            
return sumHeight;
        }

        
else
            
return item.childMenu.height;
    }

    
    
/**
    * 獲取名字為mName菜單項的對象
    *
    * @mName            菜單項名字字符串
    * @return            返回調用此函數的菜單項的子菜單中名字為mName的子菜單項對象
    
*/

    public 
function getMenu(mName:String):menuItem
    
{
        
for each(var item in childItem)
        
{
            
if(item.menuName == mName)
                
return item;
        }

        trace(
" 錯誤:不存在名為 " + mName + " 的子菜單項!");
        
return null;
    }

    
    
/**
    * 接收TextField的單擊事件,更改TextField對應item的子菜單顯示狀態
    *
    * @item            接收到單擊事件的menuLabel對應的菜單項(menuItem)
    
*/

    public 
function chgChildItemVisible(item:menuItem)
    
{
        
var chgHeight = 0;
        
if(item.childMenu.visible)
        
{
            chgHeight 
= item.getHeight() - item.menuLabel.height;
            item.childMenu.visible 
= false;
            updateMenu(item,
0 - chgHeight);
        }

        
else
        
{
            item.childMenu.visible 
= true;
            chgHeight 
= item.childMenu.height - getHideMenu(item);
            updateMenu(item,chgHeight);
        }

    }

    
    
/**
    * 更新各菜單項位置
    * 注:由于參數item的子菜單容器childMenu高度發生變化而需要改變其同級別的菜單項以及所有的父菜單項的y坐標
    *
    * @item            引發調用此函數的菜單項(即由于item的childMenu高度改變而需要調用此函數)
    * @chgHeight    需要改變的y坐標高度,正值即增加y坐標值,負值減小y坐標值
    
*/

    private 
function updateMenu(item:menuItem, chgHeight:Number)
    
{
        
if(item == nullreturn;
        
// item.parent為父菜單的子菜單容器,item.parent.paren才是對應的父菜單項
        var parentItem = item.parent.parent;

        
var i,index:int = 0;
        
        
if(parentItem == null || ! (parentItem is menuItem))
            
return;
        
        
// 搜索item在父菜單的子菜單數組childItem中的索引
        index = parentItem.childItem.indexOf(item);
        
        
// 改變item同級別的并且位于其后的菜單項的顯示位置
        for(i = index + 1; i < parentItem.childItem.length; i++)
        
{
            parentItem.childItem[i].y 
= parentItem.childItem[i].y + chgHeight;
        }

        
        
// 對父菜單項遞歸
        updateMenu(parentItem,chgHeight);
    }

    
//    private function itemClick(e:MouseEvent)
//
    {
//
        var item = e.currentTarget;
//
        chgChildItemVisible(item.parent);
//
    }
    
    private 
function itemMouseMove(e:MouseEvent)
    
{
        
var item = e.currentTarget;
        item.background 
= true;
        item.backgroundColor 
= 0x66ccFF;
        item.textColor 
= 0x0000FF;
    }

    
    private 
function itemMouseOut(e:MouseEvent)
    
{
        
var item = e.currentTarget;
        item.background 
= false;
        item.backgroundColor 
= 0xFFFFFF;
        item.textColor 
= 0x000000;
    }

    
    
// 向子菜單容器加入子菜單項事件,增加當前菜單的高度
    private function mcAddedEvent(e:Event)
    
{// 此事件響應函數還需要更改。。。
        var mc = e.currentTarget;
        h 
= h + 22;//mc.height;///2
    }

    
    
// 從子菜單容器移除子菜單項事件,減小當前菜單的高度
    private function mcRemovedEvent(e:Event)
    
{// 此事件響應函數還需要更改。。。
        var mc = e.currentTarget;
        h 
= h - 22;//mc.height/2;
    }

}



treeMenu類簡單應用
package 
{
    import flash.display.MovieClip;    
    import flash.events.
*;

    import com.library.treeMenu;
    
    public class menu extends MovieClip
    
{
        
function menu()
        
{
            
var tm = new treeMenu();
            tm.newTreeMenu();            
// 創建根菜單
            
            tm.addChildMenu(tm.rootMenu,
"基菜單-01","基菜單-01");
            tm.rootMenu.getMenu(
"基菜單-01").menuLabel.addEventListener(MouseEvent.CLICK,eventClick);
            
            tm.addChildMenu(tm.rootMenu.getMenu(
"基菜單-01"),"一級菜單-011","一級菜單-011");
            
            tm.addChildMenu(tm.rootMenu,
"基菜單-02","基菜單-02");
            tm.rootMenu.getMenu(
"基菜單-02").menuLabel.addEventListener(MouseEvent.CLICK,eventClick);
            
            tm.addChildMenu(tm.rootMenu.getMenu(
"基菜單-02"),"一級菜單-021","一級菜單-021");
            tm.rootMenu.getMenu(
"基菜單-02").getMenu("一級菜單-021").menuLabel.addEventListener(MouseEvent.CLICK,eventClick);
            
            tm.addChildMenu(tm.rootMenu.getMenu(
"基菜單-02").getMenu("一級菜單-021"),"二級菜單-0211","二級菜單-0211");
            tm.rootMenu.getMenu(
"基菜單-02").getMenu("一級菜單-021").getMenu("二級菜單-0211").menuLabel.addEventListener(MouseEvent.CLICK,eventClick);
            
            tm.addChildMenu(tm.rootMenu.getMenu(
"基菜單-02").getMenu("一級菜單-021").getMenu("二級菜單-0211"),"三級菜單-02111","三級菜單-02111");
            tm.addChildMenu(tm.rootMenu,
"基菜單-03","基菜單-03");
            
            
// 菜單坐標 默認坐標(0,0)
            //tm.x = 50;
            //tm.y = 50;
            this.addChild(tm);
        }

        
        private 
function eventClick(e:MouseEvent)
        
{
            
var item = e.currentTarget;
            item.parent.chgChildItemVisible(item.parent);    
// 隱藏或顯示子菜單項
        }

    }

}


posted on 2007-10-19 00:51 譚文政 閱讀(3182) 評論(9)  編輯 收藏 引用 所屬分類: Flash AS 3.0

評論

# re: ActionScript 3.0 實現樹形菜單(TreeMenu) 2007-10-19 07:43 Minidx全文檢索
非C++,屬于其它技術哦  回復  更多評論
  

# re: ActionScript 3.0 實現樹形菜單(TreeMenu) 2007-10-19 07:43 Minidx全文檢索
非C++,屬于其它技術哦  回復  更多評論
  

# re: ActionScript 3.0 實現樹形菜單(TreeMenu) 2007-10-19 12:53 苦味酸
對,這是用Flash ActionScript 3.0 實現的。

由于項目的需要,前段時間改學Flash ActionScript 3.0了,覺得自己越學越雜,但計算機語言都是相通的,大同小異,重要的是設計思想,軟件的架構。我現在比較熟悉的語言是C++/C#和ActionScript 3.0。  回復  更多評論
  

# re: ActionScript 3.0 實現樹形菜單(TreeMenu)[未登錄] 2008-02-26 21:15 小小菜鳥
wangyan.work@qq.com

發個源文件吧,謝謝  回復  更多評論
  

# re: ActionScript 3.0 實現樹形菜單(TreeMenu)[未登錄] 2008-02-26 21:34 小小菜鳥
能拖動節點換位置,給節點改名,添件刪除節點,就美了,呵呵
  回復  更多評論
  

# re: ActionScript 3.0 實現樹形菜單(TreeMenu) 2008-10-17 17:08 hfydm
編譯不能通過,相關信息:1046: Type was not found or was not a compile-time constant: menuItem.  回復  更多評論
  

# re: ActionScript 3.0 實現樹形菜單(TreeMenu) 2009-02-18 09:09 needi
這個怎么用啊。。有沒有實例?。?????  回復  更多評論
  

# re: ActionScript 3.0 實現樹形菜單(TreeMenu) 2009-11-19 18:46 路過的人
拜讀了,謝謝  回復  更多評論
  

# re: ActionScript 3.0 實現樹形菜單(TreeMenu) 2012-04-05 09:10 fds
灰常感謝  回復  更多評論
  


只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            免费观看日韩| 久久精品三级| 欧美深夜影院| 亚洲一区二区三区中文字幕| 欧美亚洲视频| 黄网站色欧美视频| 欧美福利小视频| 一本色道久久88精品综合| 午夜精品福利一区二区蜜股av| 国产女主播一区| 久久视频在线视频| 亚洲美女毛片| 久久久91精品国产| 亚洲风情亚aⅴ在线发布| 欧美精品一二三| 午夜精品免费视频| 欧美国产精品专区| 亚洲一区二区三区午夜| 国产日韩一区欧美| 欧美大学生性色视频| 亚洲天堂男人| 欧美波霸影院| 亚洲欧美一区二区原创| 尤物九九久久国产精品的特点 | 欧美激情影院| 亚洲人成网站777色婷婷| 中文国产一区| 狠狠色丁香久久婷婷综合_中| 美女精品视频一区| 亚洲小说欧美另类社区| 欧美成人xxx| 性伦欧美刺激片在线观看| 亚洲国产精品一区在线观看不卡 | 欧美日韩的一区二区| 香蕉久久久久久久av网站| 亚洲第一偷拍| 久久久av水蜜桃| 亚洲深夜福利| 亚洲丰满在线| 黄色av一区| 国产精品国产三级欧美二区| 老司机午夜精品| 西西人体一区二区| 亚洲美女av在线播放| 蜜臀久久99精品久久久久久9| 亚洲欧美日韩精品久久亚洲区| 亚洲激情在线播放| 黑丝一区二区三区| 国产精品尤物福利片在线观看| 欧美承认网站| 久久这里有精品视频| 欧美一区二区精品在线| 夜夜爽av福利精品导航| 亚洲国产日韩欧美综合久久| 另类国产ts人妖高潮视频| 欧美伊人久久久久久久久影院| 99视频精品全部免费在线| 亚洲国产成人午夜在线一区| 国内精品久久久久久久果冻传媒 | 99精品欧美一区二区蜜桃免费| 欧美成年人网| 蜜桃久久精品乱码一区二区| 久久国产直播| 久久精品国产欧美亚洲人人爽| 亚洲国产婷婷香蕉久久久久久99| 韩国一区电影| 国内自拍一区| 好吊日精品视频| 国内外成人免费视频| 国产欧美在线视频| 国产亚洲一区二区在线观看| 国产欧美三级| 国产亚洲欧美一区在线观看| 国产欧美大片| 国产一区二区欧美| 国内伊人久久久久久网站视频 | 免费观看成人网| 欧美成人精品在线| 欧美激情欧美激情在线五月| 欧美激情在线观看| 亚洲第一搞黄网站| 亚洲日本乱码在线观看| 99成人精品| 午夜亚洲性色视频| 久久久久九九视频| 欧美超级免费视 在线| 欧美久久成人| 国产精品v亚洲精品v日韩精品| 国产精品毛片a∨一区二区三区|国 | 亚洲一区二区视频在线观看| 亚洲性视频h| 午夜久久美女| 久久亚洲国产成人| 女人色偷偷aa久久天堂| 亚洲国产精品成人久久综合一区| 亚洲人成欧美中文字幕| 一级日韩一区在线观看| 亚洲伊人一本大道中文字幕| 午夜日韩在线| 欧美成人精品一区| 国产精品久久久久久久久久尿| 国产情人节一区| 亚洲激情在线视频| 亚洲自拍电影| 免费欧美在线| 9i看片成人免费高清| 午夜精品久久久久久久久久久| 久久一区二区三区国产精品| 欧美精品一区二区三区久久久竹菊| 欧美三级视频在线观看| 国产亚洲激情视频在线| 日韩视频免费| 久久精品国产精品亚洲精品| 亚洲国产精品久久久久久女王| 亚洲一区二区三区高清| 男女激情久久| 国产精品永久免费视频| 亚洲精品欧美极品| 久久爱www久久做| 亚洲国语精品自产拍在线观看| 亚洲永久免费精品| 欧美激情小视频| 国产一区二区三区四区hd| 一区二区三区黄色| 欧美不卡三区| 亚洲资源av| 欧美片第一页| 亚洲电影中文字幕| 性高湖久久久久久久久| 亚洲激情亚洲| 欧美在线看片| 国产精品白丝黑袜喷水久久久 | 日韩视频二区| 蜜臀久久99精品久久久久久9 | 亚洲午夜精品国产| 欧美福利小视频| 性色av一区二区三区红粉影视| 欧美日韩视频免费播放| 亚洲国产成人久久| 久久乐国产精品| 亚洲一区亚洲| 欧美午夜电影在线| 99re66热这里只有精品3直播 | 欧美日韩小视频| 亚洲日本成人网| 蜜月aⅴ免费一区二区三区 | 国产精品一区二区三区四区| 日韩视频免费观看高清在线视频| 久久久激情视频| 亚洲一区影音先锋| 国产精品黄色| 亚洲小说欧美另类社区| 亚洲日本欧美| 欧美激情欧美狂野欧美精品| 亚洲成人在线视频播放| 久久性天堂网| 久久激情综合网| 激情亚洲网站| 欧美大片一区二区三区| 久久精品国产免费| 影音先锋久久久| 蜜臀久久99精品久久久久久9| 久久国产精品久久w女人spa| 国产三级欧美三级日产三级99| 香蕉国产精品偷在线观看不卡| 最新高清无码专区| 欧美日韩精品欧美日韩精品| 一区二区三区四区五区精品视频| 91久久精品www人人做人人爽 | 136国产福利精品导航网址| 久久久久久久久一区二区| 欧美一区二区三区男人的天堂| 国产日韩欧美中文在线播放| 久久久欧美一区二区| 久久精品欧美日韩精品| 影音欧美亚洲| 亚洲国产裸拍裸体视频在线观看乱了| 欧美激情a∨在线视频播放| 亚洲美女黄网| 亚洲视频精选在线| 国产精品亚洲综合天堂夜夜| 久久精品成人一区二区三区| 久久久久久亚洲精品杨幂换脸 | 99精品视频免费观看视频| 国产精品久线观看视频| 久久久7777| 欧美黄在线观看| 午夜国产一区| 久久久综合精品| 正在播放日韩| 午夜在线电影亚洲一区| 亚洲国产精品成人综合| 亚洲欧洲日本在线| 国产精品高潮久久| 久久久无码精品亚洲日韩按摩| 麻豆免费精品视频| 亚洲一区在线免费观看| 久久精精品视频| 亚洲午夜精品| 久久男女视频|