Javascript - 标准化矢量仅在180度范围内旋转

时间:2013-09-29 01:08:54

标签: javascript html5-canvas vector-graphics rotational-matrices

我正在尝试用Javascript创建一个小型小行星游戏,我已经把它弄到了船在屏幕上绘制并可以飞来飞去的地方。但是,每当我尝试将其旋转一定量时,它只能在+/- PI / 2之间旋转。我需要它覆盖的不仅仅是180度的范围,否则船只永远不能转身。我正在尝试使用自定义的2D Vector类从头开始这样做,而且我有几个人看着它而没有运气,该怎么做。

这是我的矢量代码,或者至少是构造函数和旋转函数。

function Vec2D(x, y) {
    var self = this;
    var sqrt = Math.sqrt;
    this.x = x !== null ? Number(x) : 0;
    this.y = y !== null ? Number(y) : 0;
}
Vec2D.prototype.rotate = function (deg) {
    var theta = deg * (Math.PI / 180),
        xTemp = this.x;
    this.x = this.x * Math.cos(theta) - this.y * Math.sin(theta); 
    this.y = xTemp * Math.sin(theta) + this.y * Math.cos(theta);
    return this;
}

这是我的船试图旋转的代码。

function Ship(x_, y_, size_) {
    this.position = new Vec2D(x_, y_);
    this.velocity = new Vec2D(0, 0);
    this.forward = new Vec2D(0, 0);
    //some other things
    this.turningRight = false;
    this.turningLeft = false;
    this.turnAmt = 5;
    //some more things
}
Ship.prototype.update = function () {
   //other update code
   if (this.turningRight) {
        this.forward.rotate(this.turnAmt);
        console.log("right");
   }
   if (this.turningLeft) {
        this.forward.rotate(-1.0 * this.turnAmt);
        console.log("left");
   }
   //end of rotation code in update
}

如果需要,我可以重现更多代码,但据我所知,这是所有相关代码。我已经尝试过控制台打印,我已经尝试搞乱旋转矩阵了,我甚至尝试过只使用弧度而不是每次都从度数转换它(说实话,我真的应该这样做)。

关于我的新手JavaScript的任何想法?

0 个答案:

没有答案