|
|
@ -245,20 +245,30 @@ namespace MWSound
|
|
|
|
|
|
|
|
|
|
|
|
DecoderPtr SoundManager::loadVoice(const std::string &voicefile)
|
|
|
|
DecoderPtr SoundManager::loadVoice(const std::string &voicefile)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
DecoderPtr decoder = getDecoder();
|
|
|
|
try
|
|
|
|
// Workaround: Bethesda at some point converted some of the files to mp3, but the references were kept as .wav.
|
|
|
|
{
|
|
|
|
if(mVFS->exists(voicefile))
|
|
|
|
DecoderPtr decoder = getDecoder();
|
|
|
|
decoder->open(voicefile);
|
|
|
|
|
|
|
|
else
|
|
|
|
// Workaround: Bethesda at some point converted some of the files to mp3, but the references were kept as .wav.
|
|
|
|
|
|
|
|
if(mVFS->exists(voicefile))
|
|
|
|
|
|
|
|
decoder->open(voicefile);
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
std::string file = voicefile;
|
|
|
|
|
|
|
|
std::string::size_type pos = file.rfind('.');
|
|
|
|
|
|
|
|
if(pos != std::string::npos)
|
|
|
|
|
|
|
|
file = file.substr(0, pos)+".mp3";
|
|
|
|
|
|
|
|
decoder->open(file);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return decoder;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
catch(std::exception &e)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
std::string file = voicefile;
|
|
|
|
Log(Debug::Error) << "Failed to load audio from " << voicefile << ": " << e.what();
|
|
|
|
std::string::size_type pos = file.rfind('.');
|
|
|
|
|
|
|
|
if(pos != std::string::npos)
|
|
|
|
|
|
|
|
file = file.substr(0, pos)+".mp3";
|
|
|
|
|
|
|
|
decoder->open(file);
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
return decoder;
|
|
|
|
return nullptr;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
Sound *SoundManager::getSoundRef()
|
|
|
|
Sound *SoundManager::getSoundRef()
|
|
|
@ -471,6 +481,8 @@ namespace MWSound
|
|
|
|
|
|
|
|
|
|
|
|
mVFS->normalizeFilename(voicefile);
|
|
|
|
mVFS->normalizeFilename(voicefile);
|
|
|
|
DecoderPtr decoder = loadVoice(voicefile);
|
|
|
|
DecoderPtr decoder = loadVoice(voicefile);
|
|
|
|
|
|
|
|
if (!decoder)
|
|
|
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
|
|
|
|
MWBase::World *world = MWBase::Environment::get().getWorld();
|
|
|
|
MWBase::World *world = MWBase::Environment::get().getWorld();
|
|
|
|
const osg::Vec3f pos = world->getActorHeadTransform(ptr).getTrans();
|
|
|
|
const osg::Vec3f pos = world->getActorHeadTransform(ptr).getTrans();
|
|
|
@ -503,6 +515,8 @@ namespace MWSound
|
|
|
|
|
|
|
|
|
|
|
|
mVFS->normalizeFilename(voicefile);
|
|
|
|
mVFS->normalizeFilename(voicefile);
|
|
|
|
DecoderPtr decoder = loadVoice(voicefile);
|
|
|
|
DecoderPtr decoder = loadVoice(voicefile);
|
|
|
|
|
|
|
|
if (!decoder)
|
|
|
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
|
|
|
|
stopSay(MWWorld::ConstPtr());
|
|
|
|
stopSay(MWWorld::ConstPtr());
|
|
|
|
Stream *sound = playVoice(decoder, osg::Vec3f(), true);
|
|
|
|
Stream *sound = playVoice(decoder, osg::Vec3f(), true);
|
|
|
|