空间(vector3)位置求旋转算法前提不借助外部库,已知空间内任意一点 求其以原点位置旋转的度数.rotX,rotY,rotZ
来源:学生作业帮助网 编辑:作业帮 时间:2024/06/29 01:27:27
![空间(vector3)位置求旋转算法前提不借助外部库,已知空间内任意一点 求其以原点位置旋转的度数.rotX,rotY,rotZ](/uploads/image/z/15173633-65-3.jpg?t=%E7%A9%BA%E9%97%B4%28vector3%29%E4%BD%8D%E7%BD%AE%E6%B1%82%E6%97%8B%E8%BD%AC%E7%AE%97%E6%B3%95%E5%89%8D%E6%8F%90%E4%B8%8D%E5%80%9F%E5%8A%A9%E5%A4%96%E9%83%A8%E5%BA%93%2C%E5%B7%B2%E7%9F%A5%E7%A9%BA%E9%97%B4%E5%86%85%E4%BB%BB%E6%84%8F%E4%B8%80%E7%82%B9+%E6%B1%82%E5%85%B6%E4%BB%A5%E5%8E%9F%E7%82%B9%E4%BD%8D%E7%BD%AE%E6%97%8B%E8%BD%AC%E7%9A%84%E5%BA%A6%E6%95%B0.rotX%2CrotY%2CrotZ)
空间(vector3)位置求旋转算法前提不借助外部库,已知空间内任意一点 求其以原点位置旋转的度数.rotX,rotY,rotZ
空间(vector3)位置求旋转算法
前提不借助外部库,已知空间内任意一点 求其以原点位置旋转的度数.
rotX,rotY,rotZ
空间(vector3)位置求旋转算法前提不借助外部库,已知空间内任意一点 求其以原点位置旋转的度数.rotX,rotY,rotZ
//
void rotAxis3D_Tech_Matrix(float theta, float nx, float ny, float nz, float (&ptIn)[3], float (&ptOut)[3])
{
float len = sqrtf(nx * nx + ny * ny + nz * nz); //normalize vector
nx /= len; ny /= len; nz /= len;
ptOut[0] = ptIn[0] * (cosf(theta) + nx * nx * (1 - cosf(theta))) + //transform by matrix
ptIn[1] * (nx * ny * (1 - cosf(theta)) - nz * sinf(theta)) +
ptIn[2] * (nx * nz * (1 - cosf(theta) + ny * sinf(theta)));
ptOut[1] = ptIn[0] * (nx * ny * (1 - cosf(theta)) + nz * sinf(theta)) +
ptIn[1] * (ny * ny * (1 - cosf(theta)) + cosf(theta)) +
ptIn[2] * (ny * nz * (1 - cosf(theta)) - nx * sinf(theta));
ptOut[2] = ptIn[0] * (nx * nz * (1 - cosf(theta) - ny * sinf(theta))) +
ptIn[1] * (ny * nz * (1 -cosf(theta)) + nx * sinf(theta)) +
ptIn[2] * (nz * nz * (1 - cosf(theta)) + cosf(theta));
}
直接给出个算法吧,这个算法直接用矩阵作的,在一般情况下也就不用四元数了.
晕,哥哥看错了,你是问OpenGL,那把上面公式中的矩阵提取出来,注意到这个矩阵是三阶的,最后一行是给你设置平移参数的.可以简单设置为 0 0 0 1
构造好矩阵之后,调用glLoadMatrixf设置ModelView矩阵就OK了,
上面矩阵如何提取?
(cosf(theta) + nx * nx * (1 - cosf(theta)))
(nx * ny * (1 - cosf(theta)) - nz * sinf(theta))
(nx * nz * (1 - cosf(theta) + ny * sinf(theta))) 这是第一列,其他两列也这么提取就可以了
当然这是假设没有平移和缩放变换的