From: chris yeoh <yeohc@au1.ibm.com>

The attached patch fixes mantis bug 2312 (llGetPos() returns incorrect
values for child prims where the root prim is rotated). Regression
tests still pass.

Incidentally AbsolutePosition which was used before looks a little
suspicious to me as its always going to return the wrong value if the
root prim is rotated. GetWorldPosition does take the rotation into
account, but AbsolutePosition is used in a lot of places.  Though i
don't understand why there is both GetWorldPosition as well as
AbsolutePosition so I've left the latter alone.

[i also cleaned up some indent problems, --- dr scofield]
0.6.0-stable
Dr Scofield 2008-10-07 11:41:43 +00:00
parent 7d525843d0
commit e5a50b6a3b
1 changed files with 13 additions and 16 deletions

View File

@ -91,9 +91,9 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api
config.AddConfig("XEngine"); config.AddConfig("XEngine");
m_ScriptDelayFactor = config.Configs["XEngine"]. m_ScriptDelayFactor = config.Configs["XEngine"].
GetFloat("ScriptDelayFactor", 1.0f); GetFloat("ScriptDelayFactor", 1.0f);
m_ScriptDistanceFactor = config.Configs["XEngine"]. m_ScriptDistanceFactor = config.Configs["XEngine"].
GetFloat("ScriptDistanceLimitFactor", 1.0f); GetFloat("ScriptDistanceLimitFactor", 1.0f);
AsyncCommands = new AsyncCommandManager(ScriptEngine); AsyncCommands = new AsyncCommandManager(ScriptEngine);
} }
@ -937,7 +937,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api
public LSL_Float llGround(LSL_Vector offset) public LSL_Float llGround(LSL_Vector offset)
{ {
m_host.AddScriptLPS(1); m_host.AddScriptLPS(1);
Vector3 pos = m_host.GetWorldPosition(); Vector3 pos = m_host.GetWorldPosition();
int x = (int)(pos.X + offset.x); int x = (int)(pos.X + offset.x);
int y = (int)(pos.Y + offset.y); int y = (int)(pos.Y + offset.y);
return World.GetLandHeight(x, y); return World.GetLandHeight(x, y);
@ -1719,9 +1719,8 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api
public LSL_Vector llGetPos() public LSL_Vector llGetPos()
{ {
m_host.AddScriptLPS(1); m_host.AddScriptLPS(1);
return new LSL_Vector(m_host.AbsolutePosition.X, Vector3 pos = m_host.GetWorldPosition();
m_host.AbsolutePosition.Y, return new LSL_Vector(pos.X, pos.Y, pos.Z);
m_host.AbsolutePosition.Z);
} }
public LSL_Vector llGetLocalPos() public LSL_Vector llGetLocalPos()
@ -4845,21 +4844,19 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api
Vector3 p0 = new Vector3(pos.X, pos.Y, Vector3 p0 = new Vector3(pos.X, pos.Y,
(float)llGround( (float)llGround(
new LSL_Vector(pos.X, pos.Y, pos.Z) new LSL_Vector(pos.X, pos.Y, pos.Z)
)); ));
Vector3 p1 = new Vector3(pos.X + 1, pos.Y, Vector3 p1 = new Vector3(pos.X + 1, pos.Y,
(float)llGround( (float)llGround(
new LSL_Vector(pos.X + 1, pos.Y, pos.Z) new LSL_Vector(pos.X + 1, pos.Y, pos.Z)
)); ));
Vector3 p2 = new Vector3(pos.X, pos.Y + 1, Vector3 p2 = new Vector3(pos.X, pos.Y + 1,
(float)llGround( (float)llGround(
new LSL_Vector(pos.X, pos.Y + 1, pos.Z) new LSL_Vector(pos.X, pos.Y + 1, pos.Z)
)); ));
Vector3 v0 = new Vector3( Vector3 v0 = new Vector3(p1.X - p0.X, p1.Y - p0.Y, p1.Z - p0.Z);
p1.X - p0.X, p1.Y - p0.Y, p1.Z - p0.Z); Vector3 v1 = new Vector3(p2.X - p1.X, p2.Y - p1.Y, p2.Z - p1.Z);
Vector3 v1 = new Vector3(
p2.X - p1.X, p2.Y - p1.Y, p2.Z - p1.Z);
v0.Normalize(); v0.Normalize();
v1.Normalize(); v1.Normalize();