From 3300ef5db76cdbffd01b67cc6047c20b119f3db8 Mon Sep 17 00:00:00 2001 From: Allofich Date: Thu, 1 Sep 2016 02:27:02 +0900 Subject: [PATCH] Don't apply projectile effects multiple times --- apps/openmw/mwmechanics/spellcasting.cpp | 15 ++++++++++++++- 1 file changed, 14 insertions(+), 1 deletion(-) diff --git a/apps/openmw/mwmechanics/spellcasting.cpp b/apps/openmw/mwmechanics/spellcasting.cpp index a9c0bb9f7..38191ec4a 100644 --- a/apps/openmw/mwmechanics/spellcasting.cpp +++ b/apps/openmw/mwmechanics/spellcasting.cpp @@ -307,6 +307,9 @@ namespace MWMechanics std::string sound; osg::Vec3f fallbackDirection (0,1,0); + + bool isFirstProjectile = true; + for (std::vector::const_iterator iter (effects.mList.begin()); iter!=effects.mList.end(); ++iter) { @@ -335,8 +338,18 @@ namespace MWMechanics osg::Vec3f(mTarget.getRefData().getPosition().asVec3())- osg::Vec3f(mCaster.getRefData().getPosition().asVec3()); - MWBase::Environment::get().getWorld()->launchMagicBolt(model, sound, mId, speed, + // Only send the effects data with the first projectile, so we don't have the impact sounds + // playing multiple times. + if (isFirstProjectile) + MWBase::Environment::get().getWorld()->launchMagicBolt(model, sound, mId, speed, false, effects, mCaster, mSourceName, fallbackDirection); + else + { + const ESM::EffectList empty; + MWBase::Environment::get().getWorld()->launchMagicBolt(model, sound, mId, speed, + false, empty, mCaster, mSourceName, fallbackDirection); + } + isFirstProjectile = false; } }