1
0
Fork 0
mirror of https://github.com/OpenMW/openmw.git synced 2025-10-24 03:26:40 +00:00

Revert "Implement a Fisher-Yates shuffle on background music"

This commit is contained in:
scrawl 2017-08-20 20:20:27 +00:00 committed by GitHub
parent dbb8a5c959
commit f0dea8b8e6
2 changed files with 9 additions and 18 deletions

View file

@ -271,6 +271,7 @@ namespace MWSound
return sound;
}
// Gets the combined volume settings for the given sound type
float SoundManager::volumeFromType(PlayType type) const
{
@ -297,6 +298,7 @@ namespace MWSound
return volume;
}
void SoundManager::stopMusic()
{
if(mMusic)
@ -365,9 +367,7 @@ namespace MWSound
}
mMusicFiles[mCurrentPlaylist] = filelist;
mMusicToPlay.reserve(mMusicToPlay.size() + filelist.size());
for(int it = 0; it < filelist.size(); it++)
mMusicToPlay.push_back(it);
}
else
filelist = mMusicFiles[mCurrentPlaylist];
@ -375,23 +375,15 @@ namespace MWSound
if(filelist.empty())
return;
// Do a Fisher-Yates shuffle
if(mMusicFiles.size() == 0)
int i = Misc::Rng::rollDice(filelist.size());
// Don't play the same music track twice in a row
if (filelist[i] == mLastPlayedMusic)
{
mMusicToPlay.reserve(filelist.size());
for (int it = 0; it < filelist.size(); it++)
mMusicToPlay.push_back(it);
i = (i+1) % filelist.size();
}
int i = Misc::Rng::rollDice(mMusicToPlay.size());
// Fix last played music being the same after another shuffle
if(filelist[mMusicToPlay[i]] == mLastPlayedMusic)
i = (i+1) % mMusicToPlay.size();
advanceMusic(filelist[mMusicToPlay[i]]);
mMusicToPlay[i] = mMusicToPlay.back();
mMusicToPlay.pop_back();
advanceMusic(filelist[i]);
}
bool SoundManager::isMusicPlaying()

View file

@ -49,7 +49,6 @@ namespace MWSound
// Caches available music tracks by <playlist name, (sound files) >
std::map<std::string, std::vector<std::string> > mMusicFiles;
std::vector<int> mMusicToPlay; // The list of music files not played yet
std::string mLastPlayedMusic; // The music file that was last played
float mMasterVolume;