mirror of
https://github.com/vcmi/vcmi.git
synced 2025-01-14 02:33:51 +02:00
Allow custom effect animation on any stack during spell cast.
This commit is contained in:
parent
0f0e67dbe3
commit
caf8ae62cc
@ -1307,11 +1307,11 @@ void CBattleInterface::spellCast( const BattleSpellCast * sc )
|
|||||||
displaySpellEffect(spellID, position);
|
displaySpellEffect(spellID, position);
|
||||||
}
|
}
|
||||||
|
|
||||||
//queuing resist animation
|
//queuing additional animation
|
||||||
for(auto & elem : sc->resisted)
|
for(auto & elem : sc->customEffects)
|
||||||
{
|
{
|
||||||
BattleHex position = curInt->cb->battleGetStackByID(elem, false)->position;
|
BattleHex position = curInt->cb->battleGetStackByID(elem.stack, false)->position;
|
||||||
displayEffect(78, position);
|
displayEffect(elem.effect, position);
|
||||||
}
|
}
|
||||||
|
|
||||||
//displaying message in console
|
//displaying message in console
|
||||||
|
@ -1478,6 +1478,18 @@ struct EndAction : public CPackForClient//3008
|
|||||||
|
|
||||||
struct BattleSpellCast : public CPackForClient//3009
|
struct BattleSpellCast : public CPackForClient//3009
|
||||||
{
|
{
|
||||||
|
///custom effect (resistance, reflection, etc)
|
||||||
|
struct CustomEffect
|
||||||
|
{
|
||||||
|
/// WoG AC format
|
||||||
|
ui32 effect;
|
||||||
|
ui32 stack;
|
||||||
|
template <typename Handler> void serialize(Handler &h, const int version)
|
||||||
|
{
|
||||||
|
h & effect & stack;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
BattleSpellCast(){type = 3009; casterStack = -1;};
|
BattleSpellCast(){type = 3009; casterStack = -1;};
|
||||||
DLL_LINKAGE void applyGs(CGameState *gs);
|
DLL_LINKAGE void applyGs(CGameState *gs);
|
||||||
void applyCl(CClient *cl);
|
void applyCl(CClient *cl);
|
||||||
@ -1488,13 +1500,13 @@ struct BattleSpellCast : public CPackForClient//3009
|
|||||||
ui8 skill; //caster's skill level
|
ui8 skill; //caster's skill level
|
||||||
ui8 manaGained; //mana channeling ability
|
ui8 manaGained; //mana channeling ability
|
||||||
BattleHex tile; //destination tile (may not be set in some global/mass spells
|
BattleHex tile; //destination tile (may not be set in some global/mass spells
|
||||||
std::vector<ui32> resisted; //ids of creatures that resisted this spell
|
std::vector<CustomEffect> customEffects;
|
||||||
std::set<ui32> affectedCres; //ids of creatures affected by this spell, generally used if spell does not set any effect (like dispel or cure)
|
std::set<ui32> affectedCres; //ids of creatures affected by this spell, generally used if spell does not set any effect (like dispel or cure)
|
||||||
si32 casterStack;// -1 if not cated by creature, >=0 caster stack ID
|
si32 casterStack;// -1 if not cated by creature, >=0 caster stack ID
|
||||||
bool castByHero; //if true - spell has been casted by hero, otherwise by a creature
|
bool castByHero; //if true - spell has been casted by hero, otherwise by a creature
|
||||||
template <typename Handler> void serialize(Handler &h, const int version)
|
template <typename Handler> void serialize(Handler &h, const int version)
|
||||||
{
|
{
|
||||||
h & dmgToDisplay & side & id & skill & manaGained & tile & resisted & affectedCres & casterStack & castByHero;
|
h & dmgToDisplay & side & id & skill & manaGained & tile & customEffects & affectedCres & casterStack & castByHero;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -265,20 +265,29 @@ void DefaultSpellMechanics::battleCast(const SpellCastEnvironment * env, BattleS
|
|||||||
//resistance is applied only to negative spells
|
//resistance is applied only to negative spells
|
||||||
if(owner->isNegative())
|
if(owner->isNegative())
|
||||||
{
|
{
|
||||||
|
std::vector <const CStack*> resisted;
|
||||||
for(auto s : attackedCres)
|
for(auto s : attackedCres)
|
||||||
{
|
{
|
||||||
const int prob = std::min((s)->magicResistance(), 100); //probability of resistance in %
|
const int prob = std::min((s)->magicResistance(), 100); //probability of resistance in %
|
||||||
|
|
||||||
if(env->getRandomGenerator().nextInt(99) < prob)
|
if(env->getRandomGenerator().nextInt(99) < prob)
|
||||||
{
|
{
|
||||||
sc.resisted.push_back(s->ID);
|
resisted.push_back(s);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
vstd::erase_if(attackedCres, [&sc](const CStack * s)
|
vstd::erase_if(attackedCres, [&resisted](const CStack * s)
|
||||||
{
|
{
|
||||||
return vstd::contains(sc.resisted, s->ID);
|
return vstd::contains(resisted, s);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
for(auto s : resisted)
|
||||||
|
{
|
||||||
|
BattleSpellCast::CustomEffect effect;
|
||||||
|
effect.effect = 78;
|
||||||
|
effect.stack = s->ID;
|
||||||
|
sc.customEffects.push_back(effect);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
for(auto cre : attackedCres)
|
for(auto cre : attackedCres)
|
||||||
|
Loading…
Reference in New Issue
Block a user