2010-12-21 4 views
0

내 고객 중 한 명에게 액션 스크립트 기반 사이트를 리버스 엔지니어링합니다. 그래서, 나는 내가 배열이 이전 질문을이 일에 저를 주도하고있다 응답 ...하위 메뉴가 표시되지 않습니다 ... 어떤 아이디어?

있어 ...이 문제를 가지고 :에 내장됩니다

 
subnavData = new Array(
       {"title":"OVERVIEW", "func":this.changeSlide, "param":this.showServices, "hasChild":true}, 
        {"title":"CREATIVE DIRECTION", "func":this.changeSlide, "param":this.showBranding, "childOf":0}, 
        {"title":"SOCIAL INTERACTIVE", "func":this.changeSlide, "param":this.showOnline, "childOf":0}, 
        {"title":"LIVE EVENTS", "func":this.changeSlide, "param":this.showLiveEvents, "childOf":0}, 
        {"title":"CONTENT STRATEGY", "func":this.changeSlide, "param":this.showPerformance, "childOf":0}, 
       {"title":"PROCESS", "func":this.changeSlide, "param":this.showProcess}, 
       {"title":"CASE STUDIES", "func":this.changeSlide, "param":this.showCaseStudies}, 
       {"title":"CLIENTS", "func":this.changeSlide, "param":this.showClients} 
      ); 

이 기능별 메뉴 :

 

private function makeNewSubNav($data:Array):void { 
      group = new Array(); 
      for(var i:Number = 0; i < $data.length; i++){ 
       var obj:Object = new Object(); 
       obj.active = false; 
       obj.mc = new MovieClip(); 
       if($data[i].childOf != undefined) { 
        obj.childOf = $data[i].childOf; 
        obj.mcB = new SubMenuTopButton(); 
        obj.mcB.arrow.x = -obj.mcB.arrow.width; 
        obj.mcB.txtmask.x += 10; 
        obj.mcB.y = group[obj.childOf].subMasked.height; 
        var childbg:Sprite = new Sprite(); 
        childbg.graphics.beginFill(0xfdddf0, 1); 
        childbg.graphics.lineStyle(); 
        childbg.graphics.drawRect(0,0,167, 21); 
        childbg.graphics.endFill(); 
        obj.mcB.addChildAt(childbg, 0); 
        group[obj.childOf].subMasked.addChild(obj.mc); 
       } else { 
        obj.childOf = false; 
        obj.mcB = new SubMenuTopButton(); 
        navContainer.addChild(obj.mc); 
       } 
       obj.mc.addChild(obj.mcB); 
       obj.mcB.txtmask.tf_name.text = $data[i].title; 
       obj.mcB.buttonMode = true; 
       obj.mcB.mouseChildren = false; 
       obj.mcB.num = i; 
       obj.callback = $data[i].func; 
       obj.param = $data[i].param; 
       obj.mcB.addEventListener(MouseEvent.CLICK, navPress); 
       obj.mcB.addEventListener(MouseEvent.MOUSE_OVER, navOver); 
       obj.mcB.addEventListener(MouseEvent.MOUSE_OUT, navOut); 

       if($data[i].hasChild != undefined){ 
        obj.hasChild = true; 
        obj.subContainer = new MovieClip(); 
        obj.subMasked = new MovieClip(); 
        obj.subMask = new MovieClip(); 
        obj.subMask.graphics.beginFill(0x0000FF,1); 
        obj.subMask.graphics.lineStyle(); 
        obj.subMask.graphics.drawRect(0,0,width,1); 
        obj.subMask.graphics.endFill(); 
        obj.subMask.height = 0; 
        obj.subContainer.addChild(obj.subMasked); 
        obj.subContainer.addChild(obj.subMask); 
        obj.subMasked.mask = obj.subMask; 
        obj.subContainer.y = obj.mc.height; 
        obj.mc.addChild(obj.subContainer); 
       } 
       group.push(obj); 
      } 

      adjustHeight(); 

     } 

하지만 'childOf'는 렌더링되지 않습니다. 무슨 일인지 알아? 어떤 도움이라도 대단히 감사하겠습니다. 감사!

답변

1

코드를 로컬에서 수정하고 테스트했습니다. 단추는 올바르게 작성되었지만 숨겨진 채로 남아 있습니다. 새 하위 단추를 만든 후에는 하위 마스크의 크기를 조정해야합니다. 그렇지 않으면 높이가 항상 0으로 유지되고 단추가 전혀 표시되지 않습니다. 또한, y- 포지셔닝은 꺼져있는 것처럼 보입니다.

관련 문제