From db3858c13ad0e68e5b51ace9c017d19acec5e136 Mon Sep 17 00:00:00 2001 From: Brian McBee Date: Tue, 20 Nov 2007 04:28:31 +0000 Subject: POS physics. tweaking stair-climbing which broke with my last change --- OpenSim/Region/Physics/POSPlugin/POSPlugin.cs | 26 ++++++++++++++------------ 1 file changed, 14 insertions(+), 12 deletions(-) (limited to 'OpenSim/Region/Physics/POSPlugin') diff --git a/OpenSim/Region/Physics/POSPlugin/POSPlugin.cs b/OpenSim/Region/Physics/POSPlugin/POSPlugin.cs index 4a44438..cc1d16b 100644 --- a/OpenSim/Region/Physics/POSPlugin/POSPlugin.cs +++ b/OpenSim/Region/Physics/POSPlugin/POSPlugin.cs @@ -178,17 +178,8 @@ namespace OpenSim.Region.Physics.POSPlugin } bool forcedZ = false; - character.Position.X = character.Position.X + (character._target_velocity.X * timeStep); - if (check_all_prims(character)) - { - character.Position.X = oldposX; - } - character.Position.Y = character.Position.Y + (character._target_velocity.Y * timeStep); - if (check_all_prims(character)) - { - character.Position.Y = oldposY; - } - float terrainheight = _heightMap[(int)character.Position.Y * 256 + (int)character.Position.X]; + + float terrainheight = _heightMap[(int)(character.Position.Y + (character._target_velocity.Y * timeStep)) * 256 + (int)(character.Position.X + (character._target_velocity.X * timeStep))]; if (character.Position.Z + (character._target_velocity.Z * timeStep) < terrainheight + 2) { character.Position.Z = terrainheight + 1.0f; @@ -208,13 +199,24 @@ namespace OpenSim.Region.Physics.POSPlugin character.Position.Z = oldposZ; // first try Z axis if (check_all_prims(character)) { - character.Position.Z = oldposZ + 0.4f; // try harder + character.Position.Z = oldposZ + 0.5f; // try harder } else { forcedZ = true; } } + character.Position.X = character.Position.X + (character._target_velocity.X * timeStep); + if (check_all_prims(character)) + { + character.Position.X = oldposX; + } + character.Position.Y = character.Position.Y + (character._target_velocity.Y * timeStep); + if (check_all_prims(character)) + { + character.Position.Y = oldposY; + } + if (character.Position.Y < 0) { -- cgit v1.1