HaxeFlixel。颈背。 DistanceJoint调试。将精灵拖到区域

时间:2015-05-01 17:45:33

标签: debugging haxe haxeflixel nape

我有一个可以在屏幕上拖动的精灵。我希望能够将此精灵拖动到一个区域(框)中。现在我只能把精灵放到盒子里,但当我把它直接拖到工作室时,程序会崩溃。

我使用Adobe Flash调试器在FlashDevelop中进行了调试。当我将精灵放入框中时,调试器指向DistanceJoint.hx文件中的这行代码:

if(b1.space!=space||b2.space!=space)throw "Error: Constraints must have each body within the same space to which the constraint has been assigned";

我想我明白自己要做什么,但我很难找到一种方法在Drag课程中找到适当的例外。

我的想法是在使用mouseJoint中的Drag函数时中断collideLightBox类中的Playstate。但我不知道该怎么做,或者它是不是正确的想法。请帮忙。

相关代码:

class Drag extends FlxGroup {

    var mouseJoint:DistanceJoint;

    public inline function registerPhysSprite(spr:FlxNapeSprite)
    {
        MouseEventManager.add(spr, createMouseJoint);

    }

    function createMouseJoint(spr:FlxSprite)
    {

        var body:Body = cast(spr, FlxNapeSprite).body;

        mouseJoint = new DistanceJoint(FlxNapeState.space.world, body,
            new Vec2(FlxG.mouse.x, FlxG.mouse.y),
            body.worldPointToLocal(new Vec2(FlxG.mouse.x, FlxG.mouse.y)),
            0, 0);

        mouseJoint.space = FlxNapeState.space;
    }


    override public function update():Void
    {
        super.update();

        if (mouseJoint != null)
        {
            mouseJoint.anchor1 = new Vec2(FlxG.mouse.x, FlxG.mouse.y);

            if (FlxG.mouse.justReleased)
            {
                mouseJoint.space = null;
            }
        }
     }
}

class PlayState extends FlxNapeState {
    override public function create()
    {
    super.create();
    bgColor = FlxColor.BLACK;
    napeDebugEnabled = true;

    var light = new Light(10, 10);
    var box = new Box(100, 100);
    var drag:Drag;

    createWalls(1, 1, 1024, 768, 10, new Material(1, 1, 2, 1, 0.001));

    add(light);
    add(box);

    drag = new Drag();
    add(drag);                                                         
    drag.registerPhysSprite(light);

    light.body.velocity.y = 200;

    FlxNapeState.space.listeners.add(new InteractionListener(
        CbEvent.BEGIN, 
        InteractionType.COLLISION, 
        Light.CB_TYPE,
        Box.CB_TYPE,
        collideLightBox));
    }

    function collideLightBox(callback:InteractionCallback)
    {
        var light:Light = cast callback.int1.castBody.userData.sprite;
        light.kill();
    }
}

class Light extends FlxNapeSprite {
    public static var CB_TYPE(default, null) = new CbType();

    public function new(x:Float, y:Float)
    {
        super(x, y);
        makeGraphic(10, 10, FlxColor.TRANSPARENT);
        var radius = 5;
        drawCircle(5, 5, radius, FlxColor.WHITE);
        createCircularBody(radius);
        body.cbTypes.add(CB_TYPE);

        body.userData.sprite = this;
    }
}

class Box extends FlxNapeSprite {
    public static var CB_TYPE(default, null) = new CbType();

    public function new(x:Float, y:Float)
    {
        super(x, y);
        makeGraphic(100, 50, FlxColor.GREEN);
        createRectangularBody(width, height);
        body.cbTypes.add(CB_TYPE);
        body.type = BodyType.STATIC;
    }
}

1 个答案:

答案 0 :(得分:0)

给Drag一个类似" destroyConstraints()"的函数。并在该函数内设置mouseJoint.space = null。在collideLightBox,请致电drag.destroyConstraints()