forked from mirror/openmw-tes3mp
Hold a separate list for voice sound buffers
This fixes say. Ideally voices would be streamed, but the loudness/"lip" buffer extraction should be separated from the buffer loading code.
This commit is contained in:
parent
4571218827
commit
f4c22ec49e
3 changed files with 51 additions and 27 deletions
|
@ -816,7 +816,7 @@ void OpenAL_Output::unloadSound(Sound_Handle data)
|
||||||
MWBase::SoundPtr OpenAL_Output::playSound(Sound_Handle data, float vol, float basevol, float pitch, int flags,float offset)
|
MWBase::SoundPtr OpenAL_Output::playSound(Sound_Handle data, float vol, float basevol, float pitch, int flags,float offset)
|
||||||
{
|
{
|
||||||
boost::shared_ptr<OpenAL_Sound> sound;
|
boost::shared_ptr<OpenAL_Sound> sound;
|
||||||
ALuint src=0;
|
ALuint src;
|
||||||
|
|
||||||
if(mFreeSources.empty())
|
if(mFreeSources.empty())
|
||||||
fail("No free sources");
|
fail("No free sources");
|
||||||
|
@ -851,7 +851,7 @@ MWBase::SoundPtr OpenAL_Output::playSound3D(Sound_Handle data, const osg::Vec3f
|
||||||
float min, float max, int flags, float offset)
|
float min, float max, int flags, float offset)
|
||||||
{
|
{
|
||||||
boost::shared_ptr<OpenAL_Sound> sound;
|
boost::shared_ptr<OpenAL_Sound> sound;
|
||||||
ALuint src=0;
|
ALuint src;
|
||||||
|
|
||||||
if(mFreeSources.empty())
|
if(mFreeSources.empty())
|
||||||
fail("No free sources");
|
fail("No free sources");
|
||||||
|
|
|
@ -101,6 +101,13 @@ namespace MWSound
|
||||||
mOutput->unloadSound(sfxiter->second.mHandle);
|
mOutput->unloadSound(sfxiter->second.mHandle);
|
||||||
sfxiter->second.mHandle = 0;
|
sfxiter->second.mHandle = 0;
|
||||||
}
|
}
|
||||||
|
sfxiter = mVoiceSoundBuffers.begin();
|
||||||
|
for(;sfxiter != mVoiceSoundBuffers.end();++sfxiter)
|
||||||
|
{
|
||||||
|
if(sfxiter->second.mHandle)
|
||||||
|
mOutput->unloadSound(sfxiter->second.mHandle);
|
||||||
|
sfxiter->second.mHandle = 0;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
mUnderwaterSound.reset();
|
mUnderwaterSound.reset();
|
||||||
mActiveSounds.clear();
|
mActiveSounds.clear();
|
||||||
|
@ -162,6 +169,35 @@ namespace MWSound
|
||||||
return &sfxiter->second;
|
return &sfxiter->second;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const Sound_Buffer *SoundManager::lookupVoice(const std::string &voicefile)
|
||||||
|
{
|
||||||
|
NameBufferMap::iterator sfxiter = mVoiceSoundBuffers.find(voicefile);
|
||||||
|
if(sfxiter == mVoiceSoundBuffers.end())
|
||||||
|
{
|
||||||
|
MWBase::World* world = MWBase::Environment::get().getWorld();
|
||||||
|
static const float fAudioMinDistanceMult = world->getStore().get<ESM::GameSetting>().find("fAudioMinDistanceMult")->getFloat();
|
||||||
|
static const float fAudioMaxDistanceMult = world->getStore().get<ESM::GameSetting>().find("fAudioMaxDistanceMult")->getFloat();
|
||||||
|
static const float fAudioVoiceDefaultMinDistance = world->getStore().get<ESM::GameSetting>().find("fAudioVoiceDefaultMinDistance")->getFloat();
|
||||||
|
static const float fAudioVoiceDefaultMaxDistance = world->getStore().get<ESM::GameSetting>().find("fAudioVoiceDefaultMaxDistance")->getFloat();
|
||||||
|
|
||||||
|
float minDistance = fAudioVoiceDefaultMinDistance * fAudioMinDistanceMult;
|
||||||
|
float maxDistance = fAudioVoiceDefaultMaxDistance * fAudioMaxDistanceMult;
|
||||||
|
minDistance = std::max(minDistance, 1.f);
|
||||||
|
maxDistance = std::max(minDistance, maxDistance);
|
||||||
|
|
||||||
|
sfxiter = mVoiceSoundBuffers.insert(std::make_pair(
|
||||||
|
voicefile, Sound_Buffer("sound/"+voicefile, 1.0f, minDistance, maxDistance)
|
||||||
|
)).first;
|
||||||
|
mVFS->normalizeFilename(sfxiter->second.mResourceName);
|
||||||
|
sfxiter->second.mHandle = mOutput->loadSound(sfxiter->second.mResourceName);
|
||||||
|
}
|
||||||
|
else if(!sfxiter->second.mHandle)
|
||||||
|
sfxiter->second.mHandle = mOutput->loadSound(sfxiter->second.mResourceName);
|
||||||
|
|
||||||
|
return &sfxiter->second;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
// Gets the combined volume settings for the given sound type
|
// Gets the combined volume settings for the given sound type
|
||||||
float SoundManager::volumeFromType(PlayType type) const
|
float SoundManager::volumeFromType(PlayType type) const
|
||||||
{
|
{
|
||||||
|
@ -286,35 +322,21 @@ namespace MWSound
|
||||||
startRandomTitle();
|
startRandomTitle();
|
||||||
}
|
}
|
||||||
|
|
||||||
void SoundManager::say(const MWWorld::Ptr &ptr, const std::string& filename)
|
void SoundManager::say(const MWWorld::Ptr &ptr, const std::string &filename)
|
||||||
{
|
{
|
||||||
if(!mOutput->isInitialized())
|
if(!mOutput->isInitialized())
|
||||||
return;
|
return;
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
#if 0
|
const Sound_Buffer *sfx = lookupVoice(Misc::StringUtils::lowerCase(filename));
|
||||||
float basevol = volumeFromType(Play_TypeVoice);
|
float basevol = volumeFromType(Play_TypeVoice);
|
||||||
std::string filePath = "sound/"+filename;
|
|
||||||
const ESM::Position &pos = ptr.getRefData().getPosition();
|
const ESM::Position &pos = ptr.getRefData().getPosition();
|
||||||
const osg::Vec3f objpos(pos.asVec3());
|
const osg::Vec3f objpos(pos.asVec3());
|
||||||
|
|
||||||
MWBase::World* world = MWBase::Environment::get().getWorld();
|
MWBase::SoundPtr sound = mOutput->playSound3D(sfx->mHandle,
|
||||||
static const float fAudioMinDistanceMult = world->getStore().get<ESM::GameSetting>().find("fAudioMinDistanceMult")->getFloat();
|
objpos, sfx->mVolume, basevol, 1.0f, sfx->mMinDist, sfx->mMaxDist, Play_Normal|Play_TypeVoice, 0
|
||||||
static const float fAudioMaxDistanceMult = world->getStore().get<ESM::GameSetting>().find("fAudioMaxDistanceMult")->getFloat();
|
);
|
||||||
static const float fAudioVoiceDefaultMinDistance = world->getStore().get<ESM::GameSetting>().find("fAudioVoiceDefaultMinDistance")->getFloat();
|
|
||||||
static const float fAudioVoiceDefaultMaxDistance = world->getStore().get<ESM::GameSetting>().find("fAudioVoiceDefaultMaxDistance")->getFloat();
|
|
||||||
|
|
||||||
float minDistance = fAudioVoiceDefaultMinDistance * fAudioMinDistanceMult;
|
|
||||||
float maxDistance = fAudioVoiceDefaultMaxDistance * fAudioMaxDistanceMult;
|
|
||||||
minDistance = std::max(minDistance, 1.f);
|
|
||||||
maxDistance = std::max(minDistance, maxDistance);
|
|
||||||
|
|
||||||
MWBase::SoundPtr sound = mOutput->playSound3D(filePath, objpos, 1.0f, basevol, 1.0f,
|
|
||||||
minDistance, maxDistance, Play_Normal|Play_TypeVoice, 0, true);
|
|
||||||
mActiveSounds[sound] = std::make_pair(ptr, std::string("_say_sound"));
|
mActiveSounds[sound] = std::make_pair(ptr, std::string("_say_sound"));
|
||||||
#else
|
|
||||||
throw std::runtime_error("say disabled");
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
catch(std::exception &e)
|
catch(std::exception &e)
|
||||||
{
|
{
|
||||||
|
@ -343,15 +365,13 @@ namespace MWSound
|
||||||
return;
|
return;
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
#if 0
|
const Sound_Buffer *sfx = lookupVoice(Misc::StringUtils::lowerCase(filename));
|
||||||
float basevol = volumeFromType(Play_TypeVoice);
|
float basevol = volumeFromType(Play_TypeVoice);
|
||||||
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(sfx->mHandle,
|
||||||
|
sfx->mVolume, basevol, 1.0f, Play_Normal|Play_TypeVoice, 0
|
||||||
|
);
|
||||||
mActiveSounds[sound] = std::make_pair(MWWorld::Ptr(), std::string("_say_sound"));
|
mActiveSounds[sound] = std::make_pair(MWWorld::Ptr(), std::string("_say_sound"));
|
||||||
#else
|
|
||||||
throw std::runtime_error("say disabled");
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
catch(std::exception &e)
|
catch(std::exception &e)
|
||||||
{
|
{
|
||||||
|
|
|
@ -46,6 +46,9 @@ namespace MWSound
|
||||||
|
|
||||||
typedef std::map<std::string,Sound_Buffer> NameBufferMap;
|
typedef std::map<std::string,Sound_Buffer> NameBufferMap;
|
||||||
NameBufferMap mSoundBuffers;
|
NameBufferMap mSoundBuffers;
|
||||||
|
// Should stream voices, but that requires handling the "lip" data
|
||||||
|
// separately from buffer loading.
|
||||||
|
NameBufferMap mVoiceSoundBuffers;
|
||||||
|
|
||||||
boost::shared_ptr<Sound> mMusic;
|
boost::shared_ptr<Sound> mMusic;
|
||||||
std::string mCurrentPlaylist;
|
std::string mCurrentPlaylist;
|
||||||
|
@ -64,6 +67,7 @@ namespace MWSound
|
||||||
int mPausedSoundTypes;
|
int mPausedSoundTypes;
|
||||||
|
|
||||||
const Sound_Buffer *lookup(const std::string &soundId);
|
const Sound_Buffer *lookup(const std::string &soundId);
|
||||||
|
const Sound_Buffer *lookupVoice(const std::string &voicefile);
|
||||||
|
|
||||||
void streamMusicFull(const std::string& filename);
|
void streamMusicFull(const std::string& filename);
|
||||||
bool isPlaying(const MWWorld::Ptr &ptr, const std::string &id) const;
|
bool isPlaying(const MWWorld::Ptr &ptr, const std::string &id) const;
|
||||||
|
|
Loading…
Reference in a new issue