From 39bc11681e305809aab09185dcae625ec6399f2a Mon Sep 17 00:00:00 2001 From: scrawl Date: Sun, 5 Oct 2014 22:59:24 +0200 Subject: [PATCH] Fix broken onGround status when levitating --- apps/openmw/mwworld/physicssystem.cpp | 13 +++++-------- 1 file changed, 5 insertions(+), 8 deletions(-) diff --git a/apps/openmw/mwworld/physicssystem.cpp b/apps/openmw/mwworld/physicssystem.cpp index 7c39939ff..ec6f04be1 100644 --- a/apps/openmw/mwworld/physicssystem.cpp +++ b/apps/openmw/mwworld/physicssystem.cpp @@ -309,9 +309,6 @@ namespace MWWorld */ OEngine::Physic::ActorTracer tracer; - bool isOnGround = physicActor->getOnGround(); - if (movement.z > 0.f) - isOnGround = false; Ogre::Vector3 inertia(0.0f); Ogre::Vector3 velocity; @@ -428,8 +425,6 @@ namespace MWWorld if((ptr.getClass().canSwim(ptr) && !ptr.getClass().canWalk(ptr)) && newPosition.z > (waterlevel - halfExtents.z * 0.5)) newPosition = oldPosition; - else // Only on the ground if there's gravity - isOnGround = !(newPosition.z < waterlevel || isFlying); } else { @@ -446,10 +441,11 @@ namespace MWWorld } } - if (!(inertia.z > 0.f) && !(newPosition.z < waterlevel || isFlying)) + bool isOnGround = false; + if (!(inertia.z > 0.f) && !(newPosition.z < waterlevel)) { Ogre::Vector3 from = newPosition; - Ogre::Vector3 to = newPosition - (isOnGround ? + Ogre::Vector3 to = newPosition - (physicActor->getOnGround() ? Ogre::Vector3(0,0,sStepSize+2.f) : Ogre::Vector3(0,0,2.f)); tracer.doTrace(colobj, from, to, engine); if(tracer.mFraction < 1.0f && getSlope(tracer.mPlaneNormal) <= sMaxSlope) @@ -462,7 +458,8 @@ namespace MWWorld if (standingOn->getBroadphaseHandle()->m_collisionFilterGroup == OEngine::Physic::CollisionType_Water) physicActor->setWalkingOnWater(true); - newPosition.z = tracer.mEndPos.z + 1.0f; + if (!isFlying) + newPosition.z = tracer.mEndPos.z + 1.0f; isOnGround = true; }