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

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 譚文政 閱讀(3161) 評論(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
灰常感謝  回復  更多評論
  

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久精品一本久久99精品| 午夜精品久久| 欧美偷拍另类| 欧美日韩精品是欧美日韩精品| 欧美国产欧美亚洲国产日韩mv天天看完整| 久久久久久久999| 免费成人黄色片| 国产一区二区中文字幕免费看| 亚洲综合国产| 久久精品国产一区二区三| 久久精品国产视频| 裸体一区二区三区| 欧美色另类天堂2015| 国产精品毛片高清在线完整版| 亚洲免费影院| 一区二区免费在线视频| 精品二区视频| 一区二区免费在线播放| 久久另类ts人妖一区二区| 亚洲成人在线免费| 国产精品99久久久久久久vr | 欧美成人激情视频免费观看| 欧美激情2020午夜免费观看| 一区二区免费在线视频| 久久不射网站| 久久精品亚洲精品国产欧美kt∨| 在线观看不卡| 午夜激情一区| 亚洲激情一区二区| 久久久精品国产免大香伊| 欧美天天影院| 亚洲乱码国产乱码精品精| 欧美有码在线观看视频| 亚洲激情综合| 久久天天躁狠狠躁夜夜爽蜜月 | 欧美日韩激情小视频| 激情伊人五月天久久综合| 亚洲午夜一区| 亚洲国产精品久久久久婷婷884| 亚洲欧美变态国产另类| 日韩午夜电影| 欧美成人一区二区三区| 精品白丝av| 久久久精品动漫| 亚洲在线日韩| 久久精品1区| 国产在线播精品第三| 一本色道久久综合亚洲精品高清| 亚洲在线视频观看| 久久―日本道色综合久久| 蘑菇福利视频一区播放| 亚洲伦理在线观看| 欧美精品激情在线| 亚洲区中文字幕| 欧美高清在线播放| 久久全国免费视频| 一区二区视频欧美| 欧美 亚欧 日韩视频在线| 久久九九久精品国产免费直播 | 国产农村妇女毛片精品久久莱园子 | 亚洲国产欧美日韩| 玖玖玖免费嫩草在线影院一区| 欧美一区二区久久久| 国产亚洲欧美激情| 新67194成人永久网站| 欧美va亚洲va日韩∨a综合色| 在线观看91精品国产麻豆| 欧美国产成人精品| 欧美精品 日韩| 亚洲性av在线| 西西裸体人体做爰大胆久久久| 国产一区二区三区视频在线观看| 久久亚洲欧美国产精品乐播| 久久蜜臀精品av| 亚洲三级电影全部在线观看高清| 亚洲日本成人| 国产精品二区二区三区| 欧美影院在线| 毛片av中文字幕一区二区| 9l视频自拍蝌蚪9l视频成人| 亚洲天堂视频在线观看| 狠狠色狠狠色综合人人| 亚洲乱码国产乱码精品精天堂 | 欧美亚洲网站| 亚洲激情社区| 久久久精品一区二区三区| 久久免费精品日本久久中文字幕| 亚洲国产三级在线| 亚洲自拍偷拍一区| 亚洲第一色在线| 99精品国产在热久久婷婷| 国产欧美一区二区白浆黑人| 欧美风情在线观看| 国产精品男gay被猛男狂揉视频| 麻豆9191精品国产| 国产精品久久久久久av下载红粉| 久久在线视频在线| 国产精品盗摄一区二区三区| 久久一综合视频| 欧美特黄视频| 狠狠v欧美v日韩v亚洲ⅴ| 亚洲精品视频免费| 亚洲欧美综合精品久久成人| 欧美另类专区| 久久久久久网址| 欧美精品一区二区在线观看| 久久精品九九| 国产精品九色蝌蚪自拍| 亚洲第一区色| 国产午夜精品久久久久久免费视 | 欧美插天视频在线播放| 欧美日韩久久精品| 欧美福利专区| 国产一区二区三区在线播放免费观看| 欧美福利视频在线| 国产综合香蕉五月婷在线| 日韩视频不卡| 亚洲三级国产| 久久深夜福利免费观看| 欧美在线视频免费| 欧美性事免费在线观看| 亚洲精品在线二区| 99国产精品久久久| 欧美激情国产高清| 亚洲大片av| 韩国v欧美v日本v亚洲v| 亚洲欧美日本另类| 欧美一级欧美一级在线播放| 欧美日韩精品三区| 99精品国产99久久久久久福利| 亚洲日本成人网| 久久久久久久久久久久久女国产乱| 麻豆精品在线观看| 欧美黄色日本| 最新亚洲视频| 欧美不卡视频一区发布| 欧美激情小视频| 亚洲日本免费电影| 一本色道久久综合精品竹菊| 亚洲在线第一页| 欧美一区二区三区免费观看视频| 欧美日韩精品久久| 一区二区三区精品久久久| 亚洲一区亚洲二区| 国产日产精品一区二区三区四区的观看方式 | 欧美国产日韩a欧美在线观看| 国产一级揄自揄精品视频| 午夜日韩福利| 免费欧美电影| 亚洲精品免费看| 欧美色中文字幕| 亚洲欧美色一区| 毛片精品免费在线观看| 亚洲黄色在线看| 欧美美女日韩| 亚洲在线免费观看| 免费视频一区二区三区在线观看| 美女久久一区| 亚洲日本无吗高清不卡| 一区二区国产精品| 国产伦精品一区二区三区高清版| 亚洲精品一二三| 亚洲人成网站精品片在线观看 | 美女免费视频一区| 久久久久国产精品一区三寸| 欧美成人情趣视频| 亚洲美女av网站| 久久精品免费播放| 欧美激情在线免费观看| 欧美人与禽性xxxxx杂性| 欧美日韩一本到| 中文av字幕一区| 久久日韩精品| 国产精品va在线播放| 亚洲第一级黄色片| 亚洲天堂黄色| 黄色精品免费| 国产精品扒开腿爽爽爽视频| 久久精品夜色噜噜亚洲a∨| 一级日韩一区在线观看| 米奇777在线欧美播放| 国产欧美精品在线| 男女激情久久| 欧美亚洲视频在线观看| 91久久亚洲| 久久久久久亚洲精品杨幂换脸| 一本久道久久综合婷婷鲸鱼| 国产主播精品在线| 国产精品久久久一区麻豆最新章节| 久久久99爱| 欧美激情区在线播放| 欧美在线你懂的| 亚洲午夜电影网| 亚洲清纯自拍| 欧美国产激情二区三区| 久久久亚洲午夜电影| 亚洲在线视频免费观看| 亚洲免费av电影| 亚洲人成网站999久久久综合| 国产主播喷水一区二区|