Libgdx三角函数错误的角度

时间:2015-06-20 00:14:33

标签: libgdx trigonometry

我正在构建一个像Counter Strike 2D这样的自上而下的射击游戏,存在问题:

public class Player extends Entity {

private float moveSpeed;
private float turnSpeed;
private float maxSpeed;
private float moveFriction;
private float turnFriction;

private Texture tex;
private Sprite sprite;

private ArrayList<Bullet> bullets;

public Player() {
    moveSpeed = 15 / Game.PPM;
    turnSpeed = 400 / Game.PPM;
    maxSpeed = 300 / Game.PPM;
    moveFriction = 5 / Game.PPM;
    turnFriction = 10 / Game.PPM;

    tex = new Texture(Gdx.files.internal("ingame/TempPlayer.png"));
    sprite = new Sprite(tex);

    bodyDef = new BodyDef();
    bodyDef.position.set(Game.cam.position.x / Game.PPM, Game.cam.position.y / Game.PPM);
    bodyDef.type = BodyType.DynamicBody;
    body = Game.world.createBody(bodyDef);

    shape = new PolygonShape();
    shape.setAsBox(sprite.getWidth() / 2 / Game.PPM, sprite.getHeight() / 4 / Game.PPM);

    fixDef = new FixtureDef();
    fixDef.shape = shape;
    body.createFixture(fixDef);

    shape.setAsBox(sprite.getWidth() / 10 / Game.PPM, sprite.getHeight() / 5 / Game.PPM, new Vector2(sprite.getWidth() / 2 / Game.PPM, sprite.getHeight() / 3 / Game.PPM), 0 / Game.PPM);

    fixDef.shape = shape;
    body.createFixture(fixDef);

    bullets = new ArrayList<Bullet>();
}

public void update(float dt) {
    sprite.setCenter(body.getPosition().x * Game.PPM, body.getPosition().y * Game.PPM);
    sprite.setRotation(body.getAngle() * MathUtils.radiansToDegrees);

    // FRICTON
    if (body.getLinearVelocity().x > 0) {
        body.setLinearVelocity(body.getLinearVelocity().x - moveFriction, body.getLinearVelocity().y);
    } else if (body.getLinearVelocity().x < 0) {
        body.setLinearVelocity(body.getLinearVelocity().x + moveFriction, body.getLinearVelocity().y);
    }
    if (body.getLinearVelocity().y > 0) {
        body.setLinearVelocity(body.getLinearVelocity().x, body.getLinearVelocity().y - moveFriction);
    } else if (body.getLinearVelocity().y < 0) {
        body.setLinearVelocity(body.getLinearVelocity().x, body.getLinearVelocity().y + moveFriction);
    }
    if (body.getAngularVelocity() > 0) {
        body.setAngularVelocity(body.getAngularVelocity() - turnFriction);
    } else if (body.getAngularVelocity() < 0) {
        body.setAngularVelocity(body.getAngularVelocity() + turnFriction);
    }

    // MAX SPEED
    if (body.getLinearVelocity().x > maxSpeed) {
        body.setLinearVelocity(maxSpeed, body.getLinearVelocity().y);
    } else if (body.getLinearVelocity().x < -maxSpeed) {
        body.setLinearVelocity(-maxSpeed, body.getLinearVelocity().y);
    }
    if (body.getLinearVelocity().y > maxSpeed) {
        body.setLinearVelocity(body.getLinearVelocity().x, maxSpeed);
    } else if (body.getLinearVelocity().y < -maxSpeed) {
        body.setLinearVelocity(body.getLinearVelocity().x, -maxSpeed);
    }

    // PLAYER MOVEMENT
    if (body.getAngle() >= 360) {
        body.setTransform(body.getPosition().x, body.getPosition().y, 0);
    }

    float xVel = -(MathUtils.sin(body.getAngle()) * moveSpeed);
    float yVel = MathUtils.cos(body.getAngle()) * moveSpeed;

    if (Gdx.input.isKeyPressed(Keys.LEFT)) {
        body.setAngularVelocity(turnSpeed);
    } else if (Gdx.input.isKeyPressed(Keys.RIGHT)) {
        body.setAngularVelocity(-turnSpeed);
    } else {
        body.setAngularVelocity(0);
    }
    if (Gdx.input.isKeyPressed(Keys.UP)) {
        body.setLinearVelocity(body.getLinearVelocity().x + xVel, body.getLinearVelocity().y + yVel);
    } else if (Gdx.input.isKeyPressed(Keys.DOWN)) {
        body.setLinearVelocity(body.getLinearVelocity().x - xVel, body.getLinearVelocity().y - yVel);
    }
    if (Gdx.input.isKeyJustPressed(Keys.SPACE)) {
        bullets.add(new Bullet(body.getPosition().x, body.getPosition().y, body.getAngle()));
    }

    // CAMERA MOVEMENT
    Game.b2dCam.position.set(body.getPosition().x, body.getPosition().y, 0);
    Game.cam.position.set(body.getPosition().x * Game.PPM, body.getPosition().y * Game.PPM, 0);

    for (int i = 0; i < bullets.size(); i++) {
        bullets.get(i).update(dt);
    }
}

public void render(SpriteBatch sb) {
    sb.setProjectionMatrix(Game.cam.combined);
    sprite.draw(sb);
    for (int i = 0; i < bullets.size(); i++) {
        bullets.get(i).render(sb);
    }
}

public void dispose() {
    tex.dispose();
    shape.dispose();
}

在这部分代码中,我试图去找我想去的地方,它应该像这样工作

float xVel = MathUtils.cos(body.getAngle()) * moveSpeed;
    float yVel = MathUtils.sin(body.getAngle()) * moveSpeed;

    if (Gdx.input.isKeyPressed(Keys.LEFT)) {
        body.setAngularVelocity(turnSpeed);
    } else if (Gdx.input.isKeyPressed(Keys.RIGHT)) {
        body.setAngularVelocity(-turnSpeed);
    } else {
        body.setAngularVelocity(0);
    }
    if (Gdx.input.isKeyPressed(Keys.UP)) {
        body.setLinearVelocity(body.getLinearVelocity().x + xVel, body.getLinearVelocity().y + yVel);
    } else if (Gdx.input.isKeyPressed(Keys.DOWN)) {
        body.setLinearVelocity(body.getLinearVelocity().x - xVel, body.getLinearVelocity().y - yVel);
    }

但当我这样做时,当我试图前进时,角色会横向移动

如果我改变了cos和sin的地方,那就好了但不应该

float xVel = -(MathUtils.sin(body.getAngle()) * moveSpeed);
    float yVel = MathUtils.sin(body.getAngle()) * moveSpeed;

1 个答案:

答案 0 :(得分:0)

可能的原因仅仅是因为你的Player纹理(png / jpg本身)可能没有指向右边,这被认为是0度角。

如果是这种情况,最简单的解决方案是编辑纹理,以便玩家指向右侧。

你的所有代码似乎都很好,除了这个:

// PLAYER MOVEMENT
if (body.getAngle() >= 360) {
    body.setTransform(body.getPosition().x, body.getPosition().y, 0);
}

将弧度与度数进行比较。无论如何,if-clause不应该是必需的,Box2D已经将角度值夹在0和2 * PI之间。