|
|
|
@ -1424,7 +1424,9 @@ namespace MWWorld
|
|
|
|
|
|
|
|
|
|
pos.z() += 20; // place slightly above. will snap down to ground with code below
|
|
|
|
|
|
|
|
|
|
if (force || !ptr.getClass().isActor() || (!isFlying(ptr) && !isSwimming(ptr) && isActorCollisionEnabled(ptr)))
|
|
|
|
|
// We still should trace down dead persistent actors - they do not use the "swimdeath" animation.
|
|
|
|
|
bool swims = ptr.getClass().isActor() && isSwimming(ptr) && !(ptr.getClass().isPersistent(ptr) && ptr.getClass().getCreatureStats(ptr).isDeathAnimationFinished());
|
|
|
|
|
if (force || !ptr.getClass().isActor() || (!isFlying(ptr) && !swims && isActorCollisionEnabled(ptr)))
|
|
|
|
|
{
|
|
|
|
|
osg::Vec3f traced = mPhysics->traceDown(ptr, pos, Constants::CellSizeInUnits);
|
|
|
|
|
if (traced.z() < pos.z())
|
|
|
|
|