diff options
Diffstat (limited to 'OpenSim/Region')
-rw-r--r-- | OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs | 31 |
1 files changed, 18 insertions, 13 deletions
diff --git a/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs b/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs index 61397cd..38cbdbc 100644 --- a/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs +++ b/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs | |||
@@ -3550,19 +3550,24 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
3550 | m_host.AddScriptLPS(1); | 3550 | m_host.AddScriptLPS(1); |
3551 | 3551 | ||
3552 | // Get the normalized vector to the target | 3552 | // Get the normalized vector to the target |
3553 | LSL_Vector d1 = llVecNorm(target - llGetPos()); | 3553 | LSL_Vector from = llGetPos(); |
3554 | 3554 | ||
3555 | // Get the bearing (yaw) | 3555 | // normalized direction to target |
3556 | LSL_Vector a1 = new LSL_Vector(0,0,0); | 3556 | LSL_Vector dir = llVecNorm(target - from); |
3557 | a1.z = llAtan2(d1.y, d1.x); | ||
3558 | 3557 | ||
3559 | // Get the elevation (pitch) | 3558 | // use vertical to help compute left axis |
3560 | LSL_Vector a2 = new LSL_Vector(0,0,0); | 3559 | // LSL_Vector up = new LSL_Vector(0.0, 0.0, 1.0); |
3561 | a2.y= -llAtan2(d1.z, llSqrt((d1.x * d1.x) + (d1.y * d1.y))); | 3560 | // find normalized left axis parallel to horizon |
3561 | // LSL_Vector left = llVecNorm(LSL_Vector.Cross(up, dir)); | ||
3562 | |||
3563 | LSL_Vector left = new LSL_Vector(-dir.y, dir.x, 0.0f); | ||
3564 | left = llVecNorm(left); | ||
3565 | // make up orthogonal to left and dir | ||
3566 | LSL_Vector up = LSL_Vector.Cross(dir, left); | ||
3562 | 3567 | ||
3563 | LSL_Rotation r1 = llEuler2Rot(a1); | 3568 | // compute rotation based on orthogonal axes |
3564 | LSL_Rotation r2 = llEuler2Rot(a2); | 3569 | // and rotate so Z points to target with X below horizont |
3565 | LSL_Rotation r3 = new LSL_Rotation(0.000000, 0.707107, 0.000000, 0.707107); | 3570 | LSL_Rotation rot = new LSL_Rotation(0.0, 0.707107, 0.0, 0.707107) * llAxes2Rot(dir, left, up); |
3566 | 3571 | ||
3567 | if (m_host.PhysActor == null || !m_host.PhysActor.IsPhysical) | 3572 | if (m_host.PhysActor == null || !m_host.PhysActor.IsPhysical) |
3568 | { | 3573 | { |
@@ -3570,17 +3575,17 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
3570 | if (strength <= 0.0 || damping <= 0.0) | 3575 | if (strength <= 0.0 || damping <= 0.0) |
3571 | return; | 3576 | return; |
3572 | 3577 | ||
3573 | llSetRot(r3 * r2 * r1); | 3578 | llSetRot(rot); |
3574 | } | 3579 | } |
3575 | else | 3580 | else |
3576 | { | 3581 | { |
3577 | if (strength == 0) | 3582 | if (strength == 0) |
3578 | { | 3583 | { |
3579 | llSetRot(r3 * r2 * r1); | 3584 | llSetRot(rot); |
3580 | return; | 3585 | return; |
3581 | } | 3586 | } |
3582 | 3587 | ||
3583 | m_host.StartLookAt((Quaternion)(r3 * r2 * r1), (float)strength, (float)damping); | 3588 | m_host.StartLookAt(rot, (float)strength, (float)damping); |
3584 | } | 3589 | } |
3585 | } | 3590 | } |
3586 | 3591 | ||