Registered Member
|
Howdy,
I have a game object that I want to hug an arbitrary surface as it moves by aligning it's up vector to the surface normal. My code works ok on a flat surface but spins incorrectly when it hits a surface triangle with a different normal and has to rotate. Here's the code I'm using. Can anyone tell me what I'm doing wrong?
|
Moderator
|
Why do you use quaternion for that purpose? You can directly assemble your world transTransform matrix by assigning the normal vector to the third column, and then apply two cross product to orthogonalize it.
|
Registered Member
|
I chose quaternion for this purpose because my object needs to maintain it's heading ( rotation around up ) as it travels along the surface mesh. I don't have much experience with quaternions butI thought using a quaternion would mean only the up vector would rotate... leaving the right and front vectors the same which is what I need If I assemble the transform matrix using cross products, where do I get the vector to use in first cross product with the up vector? It has to be perpendicular to the up vector and there are an infinite number to choose from. Thanks for the help! hurley |
Moderator
|
They all have to change anyway, e.g.:
|
Registered Member
|
But this way I have to try to compute a new heading every time since the right and front are rotating around up. I've got it working with quaternions now with a little help from google. This code keeps the body sitting on the surface and maintains the same general heading without any extra work as it travels along
|
Moderator
|
I guess that the best choice depends on your application. "my" solution minimize the rotation of the head vector, while "yours" balances the in-plane rotation between the head and right vectors.
|
Moderator
|
btw, don't miss the built-in setFromTwoVectors() function: http://eigen.tuxfamily.org/dox/classEig ... cadf821452
|
Registered Member
|
Thanks I started there but couldn't get it to work because I didn't know enough to use prerotate. I'm using it now and it works great ... but I have a new problem. I need to be able to flip the object so it's top is aligned to the surface instead of it's bottom. I've tried using setFromTwoVectors() again using the surface normal and it's opposite vector. It works ok with some surface normals but becomes unstable over others. Here's a video of what's happening and the code I'm using. Can you tell me what I'm doing wrong? Thanks for the help! http://www.hurleyworks.com/media/flash/AlignToAxis/AlignToAxis.html
|
Moderator
|
You should do the flip at end, not when computing the alignment rotation.
|
Registered Member
|
I've tried that but get the same result though as in the video
|
Moderator
|
Oh, I did not look carefully your initial code, but the problem is:
q2.setFromTwoVectors(surfaceNormal, surfaceNormal * -1.0f); for which there exist an infinity of solution. You should rather post-rotate with a rotation around the x or y axis depending on the expected behavior. |
Registered Member
|
I couldn't get that to work for me but I did find a simple elegant solution that works for all cases. ... I just flipped the newUp vector if I needed to flip the object. It works perfectly for me. Thanks very much for your help!
|
Registered users: Baidu [Spider], Bing [Bot], Google [Bot], rblackwell