1

我有一个可以在屏幕上拖动的精灵。我希望能够将这个精灵拖到一个区域(框)中。就目前而言,我只能将精灵放入框中,但是当我直接将它拖动到 inn 时,程序会崩溃。

我已经使用 Adob​​e 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我的想法是在使用函数 in时打破Drag类中的in 。但我不知道该怎么做,或者这是否是正确的想法。请帮忙。collideLightBoxPlaystate

相关代码:

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;
    }
}
4

1 回答 1

0

给 Drag 一个类似“destroyConstraints()”的函数并设置mouseJoint.space = null在该函数中。在collideLightBox,呼叫drag.destroyConstraints()

于 2015-05-07T18:11:08.497 回答