3D point rotation algorithm

前端 未结 2 1212
南方客
南方客 2020-12-09 14:23

I\'m currently working on a JavaScript project which involves 3D point rotation. Using simple trigonometry, I have sketched my own 3D point rotation algorithm, but I have to

相关标签:
2条回答
  • 2020-12-09 14:32

    A rotated vector can be described as a product of a rotation matrix with that vector. The German Wikipedia page on pitch, roll and yaw describes the rotation matrix for given Euler rotation angles.

    With that information, the rotation of all points with the same angles can be written as JavaScript function, where the points array is global:

    function rotate(pitch, roll, yaw) {
        var cosa = Math.cos(yaw);
        var sina = Math.sin(yaw);
    
        var cosb = Math.cos(pitch);
        var sinb = Math.sin(pitch);
    
        var cosc = Math.cos(roll);
        var sinc = Math.sin(roll);
    
        var Axx = cosa*cosb;
        var Axy = cosa*sinb*sinc - sina*cosc;
        var Axz = cosa*sinb*cosc + sina*sinc;
    
        var Ayx = sina*cosb;
        var Ayy = sina*sinb*sinc + cosa*cosc;
        var Ayz = sina*sinb*cosc - cosa*sinc;
    
        var Azx = -sinb;
        var Azy = cosb*sinc;
        var Azz = cosb*cosc;
    
        for (var i = 0; i < points.length; i++) {
            var px = points[i].x;
            var py = points[i].y;
            var pz = points[i].z;
    
            points[i].x = Axx*px + Axy*py + Axz*pz;
            points[i].y = Ayx*px + Ayy*py + Ayz*pz;
            points[i].z = Azx*px + Azy*py + Azz*pz;
        }
    }
    

    Most of that is setting up the rotation matrix as described in the article. The last three lines inside the loop are the matrix multiplication. You have made a point of not wanting to get into matrices, but that's hardly intimidating, is it? Sooner or later you will encounter more matrices and you should be prepared to deal with them. The stuff you need – multiplication, mainly – is simple. The more complicated stuff like inverting matrices is not needed for your requirements.

    Anyway, that performs reasonably fast for 300,000 points. I was able to rotate a point cloud of that size and render it on a 1000px &times 1000px canvas in about 10ms.

    0 讨论(0)
  • 2020-12-09 14:53

    From wikipedia:

    If you multiply your points by each of these matrices they will be rotated by the amount you want.

    For example, if I want to rotate point [1, 0, 0] by 90° around the z axis (in the xy plane), sin(90) = 1 and cos(90) = 0 so you get this:

    | 0 -1  0 |   |1|   |0|
    | 1  0  0 | * |0| = |1|
    | 0  0  1 |   |0|   |0|
    
    0 讨论(0)
提交回复
热议问题