1
0
Fork 1
mirror of https://github.com/TES3MP/openmw-tes3mp.git synced 2025-01-19 23:23:52 +00:00

Revert "Started implementing sound time tracking so we can have NPCs' mouths move as they talk."

This reverts commit b897080156.
This commit is contained in:
Kevin Poitra 2014-05-28 15:04:35 -05:00
parent 18314b1707
commit 8516b837ff
3 changed files with 3 additions and 41 deletions

View file

@ -101,9 +101,6 @@ namespace MWBase
virtual void stopSay(const MWWorld::Ptr &reference=MWWorld::Ptr()) = 0; virtual void stopSay(const MWWorld::Ptr &reference=MWWorld::Ptr()) = 0;
///< Stop an actor speaking ///< Stop an actor speaking
virtual float getSoundPlayingTime(const MWWorld::Ptr &reference=MWWorld::Ptr()) = 0;
///< Get the amount of time this sound has been playing.
virtual SoundPtr playTrack(const MWSound::DecoderPtr& decoder, PlayType type) = 0; virtual SoundPtr playTrack(const MWSound::DecoderPtr& decoder, PlayType type) = 0;
///< Play a 2D audio track, using a custom decoder ///< Play a 2D audio track, using a custom decoder

View file

@ -244,7 +244,6 @@ namespace MWSound
MWBase::SoundPtr sound = mOutput->playSound3D(filePath, objpos, 1.0f, basevol, 1.0f, MWBase::SoundPtr sound = mOutput->playSound3D(filePath, objpos, 1.0f, basevol, 1.0f,
20.0f, 1500.0f, Play_Normal|Play_TypeVoice, 0); 20.0f, 1500.0f, Play_Normal|Play_TypeVoice, 0);
mActiveSounds[sound] = std::make_pair(ptr, std::string("_say_sound")); mActiveSounds[sound] = std::make_pair(ptr, std::string("_say_sound"));
mSoundPlayTime[sound] = std::make_pair(ptr, 0);
} }
catch(std::exception &e) catch(std::exception &e)
{ {
@ -262,9 +261,7 @@ namespace MWSound
std::string filePath = "Sound/"+filename; std::string filePath = "Sound/"+filename;
MWBase::SoundPtr sound = mOutput->playSound(filePath, 1.0f, basevol, 1.0f, Play_Normal|Play_TypeVoice, 0); MWBase::SoundPtr sound = mOutput->playSound(filePath, 1.0f, basevol, 1.0f, Play_Normal|Play_TypeVoice, 0);
MWWorld::Ptr ptr = MWWorld::Ptr(); mActiveSounds[sound] = std::make_pair(MWWorld::Ptr(), std::string("_say_sound"));
mActiveSounds[sound] = std::make_pair(ptr, std::string("_say_sound"));
mSoundPlayTime[sound] = std::make_pair(ptr, 0);
} }
catch(std::exception &e) catch(std::exception &e)
{ {
@ -292,18 +289,6 @@ namespace MWSound
} }
} }
float SoundManager::getSoundPlayingTime(const MWWorld::Ptr &ptr)
{
typedef SoundPlayingTimeMap::iterator iter_type;
for(iter_type iterator = mSoundPlayTime.begin(); iterator != mSoundPlayTime.end(); iterator++)
{
if (iterator->second.first == ptr)
return iterator->second.second;
}
return 0;
}
MWBase::SoundPtr SoundManager::playTrack(const DecoderPtr& decoder, PlayType type) MWBase::SoundPtr SoundManager::playTrack(const DecoderPtr& decoder, PlayType type)
{ {
@ -617,11 +602,7 @@ namespace MWSound
while(snditer != mActiveSounds.end()) while(snditer != mActiveSounds.end())
{ {
if(!snditer->first->isPlaying()) if(!snditer->first->isPlaying())
{ mActiveSounds.erase(snditer++);
mActiveSounds.erase(snditer);
mSoundPlayTime.erase(snditer->first);
snditer++;
}
else else
{ {
const MWWorld::Ptr &ptr = snditer->second.first; const MWWorld::Ptr &ptr = snditer->second.first;
@ -645,15 +626,6 @@ namespace MWSound
++snditer; ++snditer;
} }
} }
// Update the total playing time for all sounds.
// This is primarily used for detecting amplitude for NPC mouth animation.
typedef SoundPlayingTimeMap::iterator it_type;
for(it_type iterator = mSoundPlayTime.begin(); iterator != mSoundPlayTime.end(); iterator++)
{
iterator->second.second += duration;
}
} }
void SoundManager::update(float duration) void SoundManager::update(float duration)

View file

@ -44,10 +44,6 @@ namespace MWSound
typedef std::map<MWBase::SoundPtr,PtrIDPair> SoundMap; typedef std::map<MWBase::SoundPtr,PtrIDPair> SoundMap;
SoundMap mActiveSounds; SoundMap mActiveSounds;
typedef std::pair<MWWorld::Ptr, float> PtrFloatPair;
typedef std::map<MWBase::SoundPtr, PtrFloatPair> SoundPlayingTimeMap;
SoundPlayingTimeMap mSoundPlayTime;
MWBase::SoundPtr mUnderwaterSound; MWBase::SoundPtr mUnderwaterSound;
Ogre::Vector3 mListenerPos; Ogre::Vector3 mListenerPos;
@ -109,9 +105,6 @@ namespace MWSound
virtual void stopSay(const MWWorld::Ptr &reference=MWWorld::Ptr()); virtual void stopSay(const MWWorld::Ptr &reference=MWWorld::Ptr());
///< Stop an actor speaking ///< Stop an actor speaking
virtual float getSoundPlayingTime(const MWWorld::Ptr &reference=MWWorld::Ptr());
///< Get the amount of time this sound has been playing.
virtual MWBase::SoundPtr playTrack(const DecoderPtr& decoder, PlayType type); virtual MWBase::SoundPtr playTrack(const DecoderPtr& decoder, PlayType type);
///< Play a 2D audio track, using a custom decoder ///< Play a 2D audio track, using a custom decoder