aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim
diff options
context:
space:
mode:
Diffstat (limited to 'OpenSim')
-rw-r--r--OpenSim/Region/PhysicsModules/ubOde/ODECharacter.cs56
1 files changed, 30 insertions, 26 deletions
diff --git a/OpenSim/Region/PhysicsModules/ubOde/ODECharacter.cs b/OpenSim/Region/PhysicsModules/ubOde/ODECharacter.cs
index 5320912..7ad5e3d 100644
--- a/OpenSim/Region/PhysicsModules/ubOde/ODECharacter.cs
+++ b/OpenSim/Region/PhysicsModules/ubOde/ODECharacter.cs
@@ -1435,37 +1435,41 @@ namespace OpenSim.Region.PhysicsModule.ubOde
1435 1435
1436 if(!m_freemove) 1436 if(!m_freemove)
1437 { 1437 {
1438
1439 // if velocity is zero, use position control; otherwise, velocity control 1438 // if velocity is zero, use position control; otherwise, velocity control
1440 if(tviszero && m_iscolliding && !m_flying) 1439 if(tviszero)
1441 { 1440 {
1442 // keep track of where we stopped. No more slippin' & slidin' 1441 if(m_iscolliding || m_flying)
1443 if(!_zeroFlag)
1444 { 1442 {
1445 _zeroFlag = true; 1443 // keep track of where we stopped. No more slippin' & slidin'
1446 _zeroPosition = localpos; 1444 if (!_zeroFlag)
1445 {
1446 _zeroFlag = true;
1447 _zeroPosition = localpos;
1448 }
1449 if(m_pidControllerActive)
1450 {
1451 // We only want to deactivate the PID Controller if we think we want to have our surrogate
1452 // react to the physics scene by moving it's position.
1453 // Avatar to Avatar collisions
1454 // Prim to avatar collisions
1455
1456 vec.X = -vel.X * PID_D * 2f + (_zeroPosition.X - localpos.X) * (PID_P * 5);
1457 vec.Y = -vel.Y * PID_D * 2f + (_zeroPosition.Y - localpos.Y) * (PID_P * 5);
1458 if(vel.Z > 0)
1459 vec.Z += -vel.Z * PID_D + (_zeroPosition.Z - localpos.Z) * PID_P;
1460 else
1461 vec.Z += (-vel.Z * PID_D + (_zeroPosition.Z - localpos.Z) * PID_P) * 0.2f;
1462 }
1447 } 1463 }
1448 if(m_pidControllerActive) 1464 else
1449 { 1465 {
1450 // We only want to deactivate the PID Controller if we think we want to have our surrogate 1466 _zeroFlag = false;
1451 // react to the physics scene by moving it's position. 1467 vec.X += (ctz.X - vel.X) * PID_D * 0.833f;
1452 // Avatar to Avatar collisions 1468 vec.Y += (ctz.Y - vel.Y) * PID_D * 0.833f;
1453 // Prim to avatar collisions 1469 // hack for breaking on fall
1454 1470 if (ctz.Z == -9999f)
1455 vec.X = -vel.X * PID_D * 2f + (_zeroPosition.X - localpos.X) * (PID_P * 5); 1471 vec.Z += -vel.Z * PID_D - m_parent_scene.gravityz * m_mass;
1456 vec.Y = -vel.Y * PID_D * 2f + (_zeroPosition.Y - localpos.Y) * (PID_P * 5);
1457 if(vel.Z > 0)
1458 vec.Z += -vel.Z * PID_D + (_zeroPosition.Z - localpos.Z) * PID_P;
1459 else
1460 vec.Z += (-vel.Z * PID_D + (_zeroPosition.Z - localpos.Z) * PID_P) * 0.2f;
1461 /*
1462 if (flying)
1463 {
1464 vec.Z += -vel.Z * PID_D + (_zeroPosition.Z - localpos.Z) * PID_P;
1465 }
1466 */
1467 } 1472 }
1468 //PidStatus = true;
1469 } 1473 }
1470 else 1474 else
1471 { 1475 {
@@ -1539,7 +1543,7 @@ namespace OpenSim.Region.PhysicsModule.ubOde
1539 vec.X += (ctz.X - vel.X) * PID_D * 0.833f; 1543 vec.X += (ctz.X - vel.X) * PID_D * 0.833f;
1540 vec.Y += (ctz.Y - vel.Y) * PID_D * 0.833f; 1544 vec.Y += (ctz.Y - vel.Y) * PID_D * 0.833f;
1541 // hack for breaking on fall 1545 // hack for breaking on fall
1542 if(ctz.Z == -9999f) 1546 if (ctz.Z == -9999f)
1543 vec.Z += -vel.Z * PID_D - m_parent_scene.gravityz * m_mass; 1547 vec.Z += -vel.Z * PID_D - m_parent_scene.gravityz * m_mass;
1544 } 1548 }
1545 } 1549 }