mirror of
https://github.com/vcmi/vcmi.git
synced 2025-01-10 00:43:59 +02:00
It is now possible to define custom battle opening sound and custom music
for a battlefield
This commit is contained in:
parent
358008fca9
commit
9c5d5d7c5a
@ -35,6 +35,7 @@
|
|||||||
#include "../adventureMap/AdventureMapInterface.h"
|
#include "../adventureMap/AdventureMapInterface.h"
|
||||||
|
|
||||||
#include "../../CCallback.h"
|
#include "../../CCallback.h"
|
||||||
|
#include "../../lib/BattleFieldHandler.h"
|
||||||
#include "../../lib/CStack.h"
|
#include "../../lib/CStack.h"
|
||||||
#include "../../lib/CConfigHandler.h"
|
#include "../../lib/CConfigHandler.h"
|
||||||
#include "../../lib/CGeneralTextHandler.h"
|
#include "../../lib/CGeneralTextHandler.h"
|
||||||
@ -113,6 +114,9 @@ void BattleInterface::playIntroSoundAndUnlockInterface()
|
|||||||
onIntroSoundPlayed();
|
onIntroSoundPlayed();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
auto bfieldType = getBattle()->battleGetBattlefieldType();
|
||||||
|
const auto & battlefieldSound = bfieldType.getInfo()->musicFilename;
|
||||||
|
|
||||||
std::vector<soundBase::soundID> battleIntroSounds =
|
std::vector<soundBase::soundID> battleIntroSounds =
|
||||||
{
|
{
|
||||||
soundBase::battle00, soundBase::battle01,
|
soundBase::battle00, soundBase::battle01,
|
||||||
@ -120,7 +124,13 @@ void BattleInterface::playIntroSoundAndUnlockInterface()
|
|||||||
soundBase::battle05, soundBase::battle06, soundBase::battle07
|
soundBase::battle05, soundBase::battle06, soundBase::battle07
|
||||||
};
|
};
|
||||||
|
|
||||||
int battleIntroSoundChannel = CCS->soundh->playSoundFromSet(battleIntroSounds);
|
int battleIntroSoundChannel = -1;
|
||||||
|
|
||||||
|
if (!battlefieldSound.empty())
|
||||||
|
battleIntroSoundChannel = CCS->soundh->playSound(battlefieldSound);
|
||||||
|
else
|
||||||
|
battleIntroSoundChannel = CCS->soundh->playSoundFromSet(battleIntroSounds);
|
||||||
|
|
||||||
if (battleIntroSoundChannel != -1)
|
if (battleIntroSoundChannel != -1)
|
||||||
{
|
{
|
||||||
CCS->soundh->setCallback(battleIntroSoundChannel, onIntroPlayed);
|
CCS->soundh->setCallback(battleIntroSoundChannel, onIntroPlayed);
|
||||||
@ -144,7 +154,13 @@ void BattleInterface::onIntroSoundPlayed()
|
|||||||
if (openingPlaying())
|
if (openingPlaying())
|
||||||
openingEnd();
|
openingEnd();
|
||||||
|
|
||||||
CCS->musich->playMusicFromSet("battle", true, true);
|
auto bfieldType = getBattle()->battleGetBattlefieldType();
|
||||||
|
const auto & battlefieldMusic = bfieldType.getInfo()->musicFilename;
|
||||||
|
|
||||||
|
if (!battlefieldMusic.empty())
|
||||||
|
CCS->musich->playMusic(battlefieldMusic, true, true);
|
||||||
|
else
|
||||||
|
CCS->musich->playMusicFromSet("battle", true, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
void BattleInterface::openingEnd()
|
void BattleInterface::openingEnd()
|
||||||
|
@ -24,6 +24,18 @@
|
|||||||
"format" : "imageFile",
|
"format" : "imageFile",
|
||||||
"description" : "Background image for this battlefield"
|
"description" : "Background image for this battlefield"
|
||||||
},
|
},
|
||||||
|
"music" :
|
||||||
|
{
|
||||||
|
"description" : "Optional, filename for custom music to play during combat on this terrain",
|
||||||
|
"type" : "string",
|
||||||
|
"format" : "musicFile"
|
||||||
|
},
|
||||||
|
"openingSound" :
|
||||||
|
{
|
||||||
|
"description" : "Optional, filename for custom sound to play during combat opening on this terrain",
|
||||||
|
"type" : "string",
|
||||||
|
"format" : "musicFile"
|
||||||
|
},
|
||||||
"impassableHexes" : {
|
"impassableHexes" : {
|
||||||
"type" : "array",
|
"type" : "array",
|
||||||
"description" : "List of battle hexes that will be always blocked on this battlefield (e.g. ship to ship battles)",
|
"description" : "List of battle hexes that will be always blocked on this battlefield (e.g. ship to ship battles)",
|
||||||
|
@ -1,17 +1,23 @@
|
|||||||
```jsonc
|
```jsonc
|
||||||
// Human-readable name of the battlefield
|
// Human-readable name of the battlefield
|
||||||
"name" : ""
|
"name" : "",
|
||||||
|
|
||||||
// If set to true, obstacles will be taken from "specialBattlefields" property of an obstacle
|
// If set to true, obstacles will be taken from "specialBattlefields" property of an obstacle
|
||||||
// If set to false, obstacles will be taken from "allowedTerrains" instead
|
// If set to false, obstacles will be taken from "allowedTerrains" instead
|
||||||
"isSpecial" : false
|
"isSpecial" : false,
|
||||||
|
|
||||||
// List of bonuses that will affect all battles on this battlefield
|
// List of bonuses that will affect all battles on this battlefield
|
||||||
"bonuses" : { BONUS_FORMAT }
|
"bonuses" : { BONUS_FORMAT },
|
||||||
|
|
||||||
// Background image for this battlefield
|
// Background image for this battlefield
|
||||||
"graphics" : ""
|
"graphics" : "",
|
||||||
|
|
||||||
|
// Optional, filename for custom music to play during combat on this terrain
|
||||||
|
"music" : "",
|
||||||
|
|
||||||
|
// Optional, filename for custom sound to play during combat opening on this terrain
|
||||||
|
"openingSound" : "",
|
||||||
|
|
||||||
// List of battle hexes that will be always blocked on this battlefield (e.g. ship to ship battles)
|
// List of battle hexes that will be always blocked on this battlefield (e.g. ship to ship battles)
|
||||||
"impassableHexes" : [ 10, 20, 50 ]
|
"impassableHexes" : [ 10, 20, 50 ],
|
||||||
```
|
```
|
@ -40,6 +40,9 @@ std::shared_ptr<BattleFieldInfo> BattleFieldHandler::loadFromJson(const std::str
|
|||||||
for(auto node : json["impassableHexes"].Vector())
|
for(auto node : json["impassableHexes"].Vector())
|
||||||
info->impassableHexes.emplace_back(node.Integer());
|
info->impassableHexes.emplace_back(node.Integer());
|
||||||
|
|
||||||
|
info->openingSoundFilename = AudioPath::fromJson(json["openingSound"]);
|
||||||
|
info->musicFilename = AudioPath::fromJson(json["music"]);
|
||||||
|
|
||||||
return info;
|
return info;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -32,6 +32,8 @@ public:
|
|||||||
std::string icon;
|
std::string icon;
|
||||||
si32 iconIndex;
|
si32 iconIndex;
|
||||||
std::vector<BattleHex> impassableHexes;
|
std::vector<BattleHex> impassableHexes;
|
||||||
|
AudioPath openingSoundFilename;
|
||||||
|
AudioPath musicFilename;
|
||||||
|
|
||||||
BattleFieldInfo()
|
BattleFieldInfo()
|
||||||
: BattleFieldInfo(BattleField::NONE, "")
|
: BattleFieldInfo(BattleField::NONE, "")
|
||||||
|
Loading…
Reference in New Issue
Block a user