To find the angle between the two vectors, you need to normalize them (so they have length of 1 unit) by doing this (v is the vector you want to normalize):
`float distance = sqrt(v.x*v.x + v.y*v.y + v.z*v.z);
v.x = v.x/distance;
v.y = v.y/distance;
v.z = v.z/distance;
`
Then find the dot product of the two normalized vectors (Va and Vb):
`float dotProduct = Va.x*Vb.x + Va.y*Vb.y + Va.z*Vb.z;
`
This gives you the cosine of the angle, so simple do:
`acos(dotProduct);
`
This will give you the angle. I think this post was a bit late :S |
Comment onRe^2: Rotate a 3D vector