1
0
mirror of https://github.com/vcmi/vcmi.git synced 2025-01-12 02:28:11 +02:00

Merge remote-tracking branch 'remotes/godric3/customBattleMusic' into develop

This commit is contained in:
AlexVinS 2017-11-15 22:39:14 +03:00
commit 9cf3f4fe93

View File

@ -20,6 +20,7 @@
#include "../lib/filesystem/Filesystem.h"
#include "../lib/StringConstants.h"
#include "../lib/CRandomGenerator.h"
#include "../lib/VCMIDirs.h"
#define VCMI_SOUND_NAME(x)
#define VCMI_SOUND_FILE(y) #y,
@ -252,18 +253,34 @@ CMusicHandler::CMusicHandler():
listener(settings.listen["general"]["music"])
{
listener(std::bind(&CMusicHandler::onVolumeChange, this, _1));
// Map music IDs
// Vectors for helper
const std::string setEnemy[] = {"AITheme0", "AITheme1", "AITheme2"};
const std::string setBattle[] = {"Combat01", "Combat02", "Combat03", "Combat04"};
auto fillSet = [=](std::string setName, const std::string list[], size_t amount)
auto mp3Folders = CResourceHandler::get()->getFilteredFiles([](const ResourceID & id) -> bool
{
for (size_t i=0; i < amount; i++)
addEntryToSet(setName, i, "music/" + list[i]);
};
fillSet("enemy-turn", setEnemy, ARRAY_COUNT(setEnemy));
fillSet("battle", setBattle, ARRAY_COUNT(setBattle));
if (id.getType() != EResType::DIRECTORY)
return false;
if (!(boost::algorithm::iends_with(id.getName(), "mp3")))
return false;
return true;
});
boost::filesystem::path userDataPath = VCMIDirs::get().userDataPath();
int battleMusicID = 0;
int AIThemeID = 0;
for (ResourceID folder : mp3Folders)
{
const boost::filesystem::directory_iterator enddir;
for (boost::filesystem::directory_iterator dir(userDataPath / folder.getName()); dir != enddir; ++dir)
{
if (is_regular(dir->status()))
{
std::string name = dir->path().filename().string();
if (boost::algorithm::istarts_with(name, "Combat"))
addEntryToSet("battle", battleMusicID++, "Music/" + name);
else if (boost::algorithm::istarts_with(name, "AITheme"))
addEntryToSet("enemy-turn", AIThemeID++, "Music/" + name);
}
}
}
JsonNode terrains(ResourceID("config/terrains.json"));
for (auto entry : terrains.Struct())