如何根据方向矢量计算旋转矩阵?

时间:2015-10-09 17:54:40

标签: java c++ matrix 3d rotation

在我的3D世界实现中,我使用Direction-Vectors(单位矢量)来决定3D对象的方向。

每个3D对象都有自己的Direction-Vector,默认情况下方向为V3(1,0,0),Origin为V3(0,0,0)。

这就是我如何应用方向旋转矩阵" D" (矩阵" A"用于围绕它们的Direction-Vector旋转3D对象作为轴,这似乎工作正常)

Model3D model = actor.model;
// Loops through all the edges in the model
for (int i = 0; i < model.edges.length; i++) {
    M3 D = directionMatrix(actor);
    M3 R = rotationMatrix(actor);
    // Draws a line based on each edge in the model.
    // Each line consists of two points a and b.
    // The matrix R rotates the points around a given axis.
    // The D matrix rotates the points towards a given axis - not around it.
    S.drawLine(g,
        D.mul(R.mul(model.points[model.edges[i].a])).scale(actor.scale),
        D.mul(R.mul(model.points[model.edges[i].b])).scale(actor.scale)
    );
}

这是我计算当前方向旋转矩阵&#34; D&#34;:

的方法
public M3 directionalRotationMatrix(c_Actor3D actor) {
    double x =  Math.atan2(actor.direction.z, actor.direction.y);
    double y =  Math.atan2(actor.direction.x, actor.direction.z);
    double z =  Math.atan2(actor.direction.y, actor.direction.x);
    double sin_x = Math.sin(x), sin_y = Math.sin(y), sin_z = Math.sin(z);
    double cos_x = Math.cos(x), cos_y = Math.cos(y), cos_z = Math.cos(z);
    return new M3(
            cos_x * cos_y, (cos_x * sin_y * sin_z) - (sin_x * cos_z),
            (cos_x * sin_y * cos_z) + (sin_x * sin_z), sin_x * cos_y, (sin_x * sin_y * sin_z) + (cos_x * cos_z),
            (sin_x * sin_y * cos_z) - (cos_x * sin_z), -sin_y, cos_y * sin_z, cos_y * cos_z);
}

我的问题是创建正确的方向旋转矩阵,它可以在各自的Direction-Vectors方向上旋转3D对象。

我根本不确定我做错了什么......我的想法是先将立方体朝一个方向旋转,然后围绕方向轴旋转立方体。毕竟是位置转换等等。

感谢您的帮助!

1 个答案:

答案 0 :(得分:0)

听起来你正试图将3D物体向前朝向的方向移动。要做到这一点,你需要对象的位置(x,y,z)和3个向量(向前,向上和向右)。您可以使用俯仰偏航和基于滚动的矢量数学旋转3个矢量(请参见下面的链接)。对于向前移动,您可以添加对象的位置加上速度乘以前向矢量,即:position + = speed * forward

使用此处发布的以下完整示例代码来确定如何实现您自己的版本。 http://cs.lmu.edu/~ray/notes/flightsimulator/