棋盘界面。无法删除孩子。有什么建议吗?

发布于 2024-11-13 21:23:35 字数 3734 浏览 5 评论 0原文

你好 我正在创建一个棋盘,您可以在其中移动棋子。目前我正在研究车,代码如下。我知道它并不优雅,而且可能是效率最低的代码,但这是我使用 ActionScript 3.0 的第二天,我还是一个初学者。无论如何,事实是,当您单击该片段时,下面的代码会计算出可能的方法。然后绿色方块就会出现在这些地方。然后你可以按那些绿色方块,然后车就会移动到那里。

好的,现在解决问题。方块不会消失。我希望当我点击其中一个时将它们全部删除,并且车将移动到那里。

我尝试过removeChild(),但由于这种情况发生在不同的函数中,所以它不起作用。因此,如果您愿意查看代码并提出解决方案,我们将非常感谢您的帮助。

亲切的问候 埃米尔

https://picasaweb.google.com/109156245246626370734/ 2011 年 6 月 4 日? authkey=Gv1sRgCMy4v_b01aikzAE&feat=directlink

import flash.display.Sprite
import flash.events.MouseEvent
import flash.text.TextField;
import flash.geom.Point;
import caurina.transitions.*

myPoint.addEventListener(MouseEvent.MOUSE_DOWN, startMove);

function startMove(evt:MouseEvent) {

    var boxNum:int = Math.floor(myPoint.y/100)+1;
    for (var i:int = 1; i <boxNum; i++) {
        var box:Ball = new Ball();
        box.x = myPoint.x;
        box.y = myPoint.y - i * box.height;
        addChild(box);
        Tweener.addTween(box, {alpha:0.5});
                box.buttonMode = true;
                box.addEventListener(MouseEvent.ROLL_OVER, onOver,
                                     false, 0, true);
                box.addEventListener(MouseEvent.ROLL_OUT, onOut,
                                     false, 0, true);
                box.addEventListener(MouseEvent.MOUSE_DOWN, onclick);
        }
    var boxNum1:int = Math.floor((800-myPoint.y)/100)+1;
    for (var i:int = 1; i <boxNum1; i++) {
        var box1:Ball = new Ball();
        box1.x = myPoint.x;
        box1.y = myPoint.y + i * box.height;
        addChild(box1);
        Tweener.addTween(box1, {alpha:0.5});
                box1.buttonMode = true;

                box1.addEventListener(MouseEvent.ROLL_OVER, onOver,
                                     false, 0, true);
                box1.addEventListener(MouseEvent.ROLL_OUT, onOut,
                                     false, 0, true);
                box1.addEventListener(MouseEvent.CLICK, onclick);
    }
    var boxNum2:int = Math.floor(myPoint.x/100)+1;
    for (var i:int = 1; i <boxNum2; i++) {
        var box2:Ball = new Ball();
        box2.x = myPoint.x - i * box.height;
        box2.y = myPoint.y;

        addChild(box2);
        Tweener.addTween(box2, {alpha:0.5});
                box2.buttonMode = true;
                box2.addEventListener(MouseEvent.ROLL_OVER, onOver,
                                     false, 0, true);
                box2.addEventListener(MouseEvent.ROLL_OUT, onOut,
                                     false, 0, true);
                box2.addEventListener(MouseEvent.CLICK, onclick);
    }
    var boxNum3:int = Math.floor((800-myPoint.x)/100)+1;
    for (var i:int = 1; i <boxNum3; i++) {
        var box3:Ball = new Ball();
        box3.x = myPoint.x + i * box.height;
        box3.y = myPoint.y;
        addChild(box3);
        Tweener.addTween(box3, {alpha:0.5});
        box3.buttonMode = true;
        box3.addEventListener(MouseEvent.ROLL_OVER, onOver, false, 0, true);
        box3.addEventListener(MouseEvent.ROLL_OUT, onOut, false, 0, true);
        box3.addEventListener(MouseEvent.CLICK, onclick);
    }
}

function onOver(evt:Event):void {
    var box:MovieClip = MovieClip(evt.target);
    addChild(box)
    box.scaleX = box.scaleY = 1.1;
}

function onOut(evt:Event):void {
    evt.target.scaleX = evt.target.scaleY = 1;
}

function onclick(Event:MouseEvent):void {
    var xcod:int = Math.ceil(mouseX/100)*100-50;
    var ycod:int = Math.ceil(mouseY/100)*100-50;
    Tweener.addTween(myPoint, {x:xcod, y:ycod, time:1, transition:"linear"});
}

Hello
I am in the process of creating a chess board where you can move the pieces. Currently i am working on the rook and the coding is below. I know it is not elegant and probably the most inefficient code out there, but this is day 2 of my actionscript 3.0 life and i am kinda a beginner. Anyway, so the thing is, when you click the piece the code below figures out the possible ways to go. Then green squares appear at those places. You can then press those green squares and then the rook will move there.

Ok, now to the problem. The squares will not go away. I want them all to be deleted when i have clicked on one of them and the rook will move there.

I have tried removeChild(), but since that happens in a different function it does not work. So if you are so kind to look through the code and suggest a solution, your help is much appreciated.

Kind Regards Emile

https://picasaweb.google.com/109156245246626370734/Jun42011?authkey=Gv1sRgCMy4v_b01aikzAE&feat=directlink

import flash.display.Sprite
import flash.events.MouseEvent
import flash.text.TextField;
import flash.geom.Point;
import caurina.transitions.*

myPoint.addEventListener(MouseEvent.MOUSE_DOWN, startMove);

function startMove(evt:MouseEvent) {

    var boxNum:int = Math.floor(myPoint.y/100)+1;
    for (var i:int = 1; i <boxNum; i++) {
        var box:Ball = new Ball();
        box.x = myPoint.x;
        box.y = myPoint.y - i * box.height;
        addChild(box);
        Tweener.addTween(box, {alpha:0.5});
                box.buttonMode = true;
                box.addEventListener(MouseEvent.ROLL_OVER, onOver,
                                     false, 0, true);
                box.addEventListener(MouseEvent.ROLL_OUT, onOut,
                                     false, 0, true);
                box.addEventListener(MouseEvent.MOUSE_DOWN, onclick);
        }
    var boxNum1:int = Math.floor((800-myPoint.y)/100)+1;
    for (var i:int = 1; i <boxNum1; i++) {
        var box1:Ball = new Ball();
        box1.x = myPoint.x;
        box1.y = myPoint.y + i * box.height;
        addChild(box1);
        Tweener.addTween(box1, {alpha:0.5});
                box1.buttonMode = true;

                box1.addEventListener(MouseEvent.ROLL_OVER, onOver,
                                     false, 0, true);
                box1.addEventListener(MouseEvent.ROLL_OUT, onOut,
                                     false, 0, true);
                box1.addEventListener(MouseEvent.CLICK, onclick);
    }
    var boxNum2:int = Math.floor(myPoint.x/100)+1;
    for (var i:int = 1; i <boxNum2; i++) {
        var box2:Ball = new Ball();
        box2.x = myPoint.x - i * box.height;
        box2.y = myPoint.y;

        addChild(box2);
        Tweener.addTween(box2, {alpha:0.5});
                box2.buttonMode = true;
                box2.addEventListener(MouseEvent.ROLL_OVER, onOver,
                                     false, 0, true);
                box2.addEventListener(MouseEvent.ROLL_OUT, onOut,
                                     false, 0, true);
                box2.addEventListener(MouseEvent.CLICK, onclick);
    }
    var boxNum3:int = Math.floor((800-myPoint.x)/100)+1;
    for (var i:int = 1; i <boxNum3; i++) {
        var box3:Ball = new Ball();
        box3.x = myPoint.x + i * box.height;
        box3.y = myPoint.y;
        addChild(box3);
        Tweener.addTween(box3, {alpha:0.5});
        box3.buttonMode = true;
        box3.addEventListener(MouseEvent.ROLL_OVER, onOver, false, 0, true);
        box3.addEventListener(MouseEvent.ROLL_OUT, onOut, false, 0, true);
        box3.addEventListener(MouseEvent.CLICK, onclick);
    }
}

function onOver(evt:Event):void {
    var box:MovieClip = MovieClip(evt.target);
    addChild(box)
    box.scaleX = box.scaleY = 1.1;
}

function onOut(evt:Event):void {
    evt.target.scaleX = evt.target.scaleY = 1;
}

function onclick(Event:MouseEvent):void {
    var xcod:int = Math.ceil(mouseX/100)*100-50;
    var ycod:int = Math.ceil(mouseY/100)*100-50;
    Tweener.addTween(myPoint, {x:xcod, y:ycod, time:1, transition:"linear"});
}

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

不美如何 2024-11-20 21:23:35

alxx的答案是正确的,你不需要为他们保留一个特殊的列表。另一种方法是使用数组来保存引用,如下所示:

var boxes:Array = new Array();

function startMove(evt:MouseEvent):void {
   ...
   var box:Ball = new Ball();
   addChild(box);
   boxes.push(box);
   ...
   var box1:Ball = new Ball();
   addChild(box1);
   boxes.push(box1);
   ...
}

function onClick(evt:MouseEvent):void {
   for each (var box:Ball in boxes) {
      removeChild(box);
   }
   boxes = new Array();
}

alxx's answer is correct, you wouldn't need to keep a special list for them. The other way you could do it, using an Array to save references, would look like this:

var boxes:Array = new Array();

function startMove(evt:MouseEvent):void {
   ...
   var box:Ball = new Ball();
   addChild(box);
   boxes.push(box);
   ...
   var box1:Ball = new Ball();
   addChild(box1);
   boxes.push(box1);
   ...
}

function onClick(evt:MouseEvent):void {
   for each (var box:Ball in boxes) {
      removeChild(box);
   }
   boxes = new Array();
}
坐在坟头思考人生 2024-11-20 21:23:35

您可以将临时高亮显示在单独的 Sprite 中。然后你的主板将如下所示:
舞台儿童:底板、亮点、碎片,按顺序排列。
当您需要删除高亮显示时,您可以使用 numChildrengetChildAt 迭代高亮显示的子级,并在每个上调用 removeChild,您甚至不需要为他们准备的特别清单。

You can put temporary highlights in separate Sprite. Then your board will looks as follows:
Stage children: base board, highlights, pieces, in that order.
When you need to remove highlights, you can iterate highlights' children with numChildren and getChildAt and call removeChild on each, you don't even need a special list for them.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文