Actionscript 3 addchild внутри ребенка и очистить первого ребенка - PullRequest
1 голос
/ 25 мая 2010

Хорошо, вот настройка:

В основной временной шкале у меня есть меню, которое представляет собой MovieClip. Это меню состоит из около 17 «кнопок», каждая из которых указывает на отдельный раздел сайта. При нажатии «кнопки» (2 примера: menu_bag_button, menu_trashbag_button) меню анимируется, перемещается влево, и 2 элемента библиотеки (bag_container и close_btn) должны отображаться справа, оба в пределах «framecontainer».

Затем, пока меню находится слева, эта конкретная кнопка не должна повторять анимацию меню, поэтому я сделал оператор if, чтобы найти, в каком кадре он находится, а если он слева, он просто очищает контейнер контейнера и загружает содержание снова.

Проблема в том, что при нажатии на другую ссылку необходимо выполнить одно из двух действий: если меню находится в центре без загруженного контента, необходимо анимировать меню справа и загрузить контент / close_btn в "фрейм-контейнер"; или, если меню находится слева, необходимо очистить «framecontainer» и загрузить соответствующий контент. Я много чего перепробовал, но так как все эти кнопки находятся внутри "menu_mc", скрипт действий должен указывать на корень, ТО на "framecontainer", и все становится запутанным.

Если есть быстрый и лучший способ сделать это без того, чтобы я занимался часами кодирования, это было бы здорово ... в противном случае я должен сейчас придерживаться этого запутанного способа.

Вот мой текущий код. Он работает нормально, за исключением того факта, что он не очищает контент, поэтому он продолжает загружать фреймы, чтобы один из них был закрыт, за ним по-прежнему остался другой контент:

import flash.display.*;
import fl.transitions.*;
import flash.events.MouseEvent;

//Stopping on this frame (805) so the menu will be in place to interact with
stop();

//framecontainer location/size for the content to be loaded.
//Not sure if the parameters below it are absolutely necessary.
var framecontainer:MovieClip = new MovieClip();
framecontainer.width = 450;
framecontainer.height = 450;
framecontainer.x = 450;
framecontainer.y = 0;

//adding the framecontainer so that the content can be loaded into it.
//again, not sure if this is necessary yet
MovieClip(root).addChild(framecontainer);




//FIRST MENU ITEM, "BAG"
//If we can get the framecontainer to work, I don't think I'll have to create
//a custom closeBtn for each and every link. I'll be able to just use a generic
//closeBtn and have it clear the framecontainer and continue the animation.

var closebagBtn:close_btn = new close_btn();
closebagBtn.x = 0;
closebagBtn.y = 0;

var bagFrame:MovieClip = new bag_frame_mc();
bagFrame.x = 900;
bagFrame.y = 0;


menu_bag_button.addEventListener(MouseEvent.MOUSE_UP, bagClick);
function bagClick(event:MouseEvent):void{
    if(MovieClip(root).currentFrame == 850) {
// the next line does nothing, but it's supposed to clear
MovieClip(root).framecontainer.clear();
}
//Below, I need to add bagFrame and closebagBtn into framecontainer,
//but I don't know how. Tried adding ".framecontainer" in front of addchild
//but got error saying that bagClick (function above) is undefined.
else {
MovieClip(root).addChild (bagFrame);
MovieClip(root).addChild (closebagBtn);
MovieClip(root).gotoAndPlay(806);
}
}
closebagBtn.addEventListener(MouseEvent.MOUSE_UP, bagClose);
function bagClose (event:MouseEvent):void{
MovieClip(root).removeChild(bagFrame);
MovieClip(root).removeChild(closebagBtn);
MovieClip(root).gotoAndPlay(850);
}





//SECOND MENU ITEM, "TRASHBAG"

var closetrashbagBtn:close_btn = new close_btn();
closetrashbagBtn.x = 0;
closetrashbagBtn.y = 0;

var trashbagFrame:MovieClip = new trashbag_frame_mc();
trashbagFrame.x = 900;
trashbagFrame.y = 0;

menu_trashbag_button.addEventListener(MouseEvent.MOUSE_UP, trashbagClick);
function trashbagClick(event:MouseEvent):void{
    if(MovieClip(root).currentFrame == 850) {
// the next line does nothing, but it's supposed to clear
MovieClip(root).framecontainer.clear();
}
//Below, I need to add trashbagFrame and closebagBtn into framecontainer,
//but I don't know how. Tried adding ".framecontainer" in front of addchild
//but got error saying that bagClick (function above) is undefined.
else {
}
else {
MovieClip(root).addChild (trashbagFrame);
MovieClip(root).addChild (closetrashbagBtn);
MovieClip(root).gotoAndPlay(806);
}
}
closetrashbagBtn.addEventListener(MouseEvent.MOUSE_UP, trashbagClose);
function trashbagClose (event:MouseEvent):void{
MovieClip(root).removeChild(trashbagFrame);
MovieClip(root).removeChild(closetrashbagBtn);
MovieClip(root).gotoAndPlay(850);
}

/////////////////////////////////////////////// /////////////// Новый, функциональный код (требуется уточнение):

import flash.display.*;
import fl.transitions.*;
import flash.events.MouseEvent;

stop();

var menuList:Array = [menu_bag, menu_chips, menu_coke, menu_cup, menu_deodorant, menu_fork, menu_knife, menu_lighter, menu_milk, menu_pill, menu_rings, menu_shampoo, menu_spoon, menu_straw, menu_toothbrush, menu_trashbag, menu_water];



var closeBtn:close_btn = new close_btn();
closeBtn.x = 0;
closeBtn.y = 0;

closeBtn.addEventListener(MouseEvent.MOUSE_UP, contentClose);
function contentClose (event:MouseEvent):void{
    while(MovieClip(root).numChildren > 1)
    {
        MovieClip(root).removeChild(MovieClip(root).getChildAt(MovieClip(root).numChildren - 1));
    }
MovieClip(root).gotoAndPlay(850);
}




var bagFrame:MovieClip = new bag_frame_mc();
bagFrame.x = 900;
bagFrame.y = 0;

menu_bag.addEventListener(MouseEvent.MOUSE_UP, bagClick);
function bagClick(event:MouseEvent):void{
    if(MovieClip(root).currentFrame == 850) {
    while(MovieClip(root).numChildren > 1)
    {
        MovieClip(root).removeChild(MovieClip(root).getChildAt(MovieClip(root).numChildren - 1));
    }
MovieClip(root).addChild (bagFrame);
MovieClip(root).addChild (closeBtn);
}
else {
MovieClip(root).addChild (bagFrame);
MovieClip(root).addChild (closeBtn);
MovieClip(root).gotoAndPlay(806);
}
}

var trashbagFrame:MovieClip = new trashbag_frame_mc();
trashbagFrame.x = 900;
trashbagFrame.y = 0;

menu_trashbag.addEventListener(MouseEvent.MOUSE_UP, trashbagClick);
function trashbagClick(event:MouseEvent):void{
    if(MovieClip(root).currentFrame == 850) {
    while(MovieClip(root).numChildren > 1)
    {
        MovieClip(root).removeChild(MovieClip(root).getChildAt(MovieClip(root).numChildren - 1));
    }
MovieClip(root).addChild (trashbagFrame);
MovieClip(root).addChild (closeBtn);
}
else {
MovieClip(root).addChild (trashbagFrame);
MovieClip(root).addChild (closeBtn);
MovieClip(root).gotoAndPlay(806);
}
}

1 Ответ

2 голосов
/ 25 мая 2010

Прежде всего, я очень надеюсь, что это не код временной шкалы! Я надеюсь, что этот код внутри класса.

Во-вторых, мне действительно не нравится идея использования "root". И если вы собираетесь использовать его более одного раза, вы можете просто создать новую переменную для is, напечатанную как мувиклип, и ссылаться на нее вместо того, чтобы всегда приводить ее к мувиклипу. например,

var target:MovieClip = root as MovieClip;
target.addChild(container);

Если этот код находится на основной временной шкале, вам даже не нужно ссылаться на root (но это не так).

Чтобы ответить на актуальный вопрос ...

Проблема с этими строками:

MovieClip(root).addchild (container);
MovieClip(root).container.addChild (bagLink);
MovieClip(root).addChild (closeBtn);
MovieClip(root).gotoAndPlay(806);

проблема в том, что когда вы говорите MovieClip (root) .addchild (container); , вы добавляете «содержимое» переменной контейнера как дочерний элемент root. Содержимое контейнера var не имеет ни малейшего понятия, вы назвали его «контейнер», поэтому вы не можете сказать MovieClip (root) .container .

Однако вы можете просто сказать:

container.addChild(bagLink);

Поскольку контейнер var указывает на контейнер MovieClip.

...