mirror of
https://github.com/OpenMW/openmw.git
synced 2025-01-20 21:23:52 +00:00
Play sounds for multi-effect projectile
This commit is contained in:
parent
37f07f7435
commit
f49ebee56a
2 changed files with 21 additions and 10 deletions
|
@ -168,9 +168,11 @@ namespace MWWorld
|
|||
createModel(state, ptr.getClass().getModel(ptr), pos, orient, true);
|
||||
|
||||
MWBase::SoundManager *sndMgr = MWBase::Environment::get().getSoundManager();
|
||||
if (projectileIDs.size() == 1)
|
||||
state.mSound = sndMgr->playSound3D(pos, sounds.at(0), 1.0f, 1.0f, MWBase::SoundManager::Play_TypeSfx, MWBase::SoundManager::Play_Loop);
|
||||
|
||||
for (size_t it = 0; it != sounds.size(); it++)
|
||||
{
|
||||
state.mSound.push_back(sndMgr->playSound3D(pos, sounds.at(it), 1.0f, 1.0f, MWBase::SoundManager::Play_TypeSfx, MWBase::SoundManager::Play_Loop));
|
||||
}
|
||||
|
||||
mMagicBolts.push_back(state);
|
||||
}
|
||||
|
||||
|
@ -212,8 +214,10 @@ namespace MWWorld
|
|||
osg::Vec3f pos(it->mNode->getPosition());
|
||||
osg::Vec3f newPos = pos + direction * duration * speed;
|
||||
|
||||
if (it->mSound.get())
|
||||
it->mSound->setPosition(newPos);
|
||||
for (size_t soundIter = 0; soundIter != it->mSound.size(); soundIter++)
|
||||
{
|
||||
it->mSound.at(soundIter)->setPosition(newPos);
|
||||
}
|
||||
|
||||
it->mNode->setPosition(newPos);
|
||||
|
||||
|
@ -253,7 +257,11 @@ namespace MWWorld
|
|||
MWBase::Environment::get().getWorld()->explodeSpell(pos, it->mEffects, caster, result.mHitObject,
|
||||
ESM::RT_Target, it->mSpellId, it->mSourceName);
|
||||
|
||||
MWBase::Environment::get().getSoundManager()->stopSound(it->mSound);
|
||||
for (size_t soundIter = 0; soundIter != it->mSound.size(); soundIter++)
|
||||
{
|
||||
MWBase::Environment::get().getSoundManager()->stopSound(it->mSound.at(soundIter));
|
||||
}
|
||||
|
||||
mParent->removeChild(it->mNode);
|
||||
|
||||
it = mMagicBolts.erase(it);
|
||||
|
@ -333,7 +341,10 @@ namespace MWWorld
|
|||
for (std::vector<MagicBoltState>::iterator it = mMagicBolts.begin(); it != mMagicBolts.end(); ++it)
|
||||
{
|
||||
mParent->removeChild(it->mNode);
|
||||
MWBase::Environment::get().getSoundManager()->stopSound(it->mSound);
|
||||
for (size_t soundIter = 0; soundIter != it->mSound.size(); soundIter++)
|
||||
{
|
||||
MWBase::Environment::get().getSoundManager()->stopSound(it->mSound.at(soundIter));
|
||||
}
|
||||
}
|
||||
mMagicBolts.clear();
|
||||
}
|
||||
|
@ -442,8 +453,8 @@ namespace MWWorld
|
|||
createModel(state, model, osg::Vec3f(esm.mPosition), osg::Quat(esm.mOrientation), true);
|
||||
|
||||
MWBase::SoundManager *sndMgr = MWBase::Environment::get().getSoundManager();
|
||||
state.mSound = sndMgr->playSound3D(esm.mPosition, esm.mSound, 1.0f, 1.0f,
|
||||
MWBase::SoundManager::Play_TypeSfx, MWBase::SoundManager::Play_Loop);
|
||||
state.mSound.push_back(sndMgr->playSound3D(esm.mPosition, esm.mSound, 1.0f, 1.0f,
|
||||
MWBase::SoundManager::Play_TypeSfx, MWBase::SoundManager::Play_Loop));
|
||||
state.mSoundId.push_back(esm.mSound);
|
||||
|
||||
mMagicBolts.push_back(state);
|
||||
|
|
|
@ -104,7 +104,7 @@ namespace MWWorld
|
|||
|
||||
bool mStack;
|
||||
|
||||
MWBase::SoundPtr mSound;
|
||||
std::vector<MWBase::SoundPtr> mSound;
|
||||
std::vector<std::string> mSoundId;
|
||||
};
|
||||
|
||||
|
|
Loading…
Reference in a new issue