Removed zMovePower field in gBattleMoves in favor of a function.
This commit is contained in:
parent
86144c6a53
commit
90021f3be6
5 changed files with 46 additions and 933 deletions
|
@ -26,5 +26,6 @@ const u8 *GetZMoveName(u16 move);
|
||||||
void SetZEffect(void);
|
void SetZEffect(void);
|
||||||
bool32 IsZMoveUsable(u8 battlerId, u16 moveIndex);
|
bool32 IsZMoveUsable(u8 battlerId, u16 moveIndex);
|
||||||
void GetUsableZMoves(u8 battlerId, u16 *moves);
|
void GetUsableZMoves(u8 battlerId, u16 *moves);
|
||||||
|
u16 GetZMovePower(u16 move);
|
||||||
|
|
||||||
#endif // GUARD_BATTLE_Z_MOVE_H
|
#endif // GUARD_BATTLE_Z_MOVE_H
|
|
@ -339,7 +339,6 @@ struct BattleMove
|
||||||
u32 flags;
|
u32 flags;
|
||||||
u8 split;
|
u8 split;
|
||||||
u8 argument;
|
u8 argument;
|
||||||
u8 zMovePower;
|
|
||||||
u8 zMoveEffect;
|
u8 zMoveEffect;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -7,6 +7,7 @@
|
||||||
#include "battle_controllers.h"
|
#include "battle_controllers.h"
|
||||||
#include "battle_interface.h"
|
#include "battle_interface.h"
|
||||||
#include "battle_setup.h"
|
#include "battle_setup.h"
|
||||||
|
#include "battle_z_move.h"
|
||||||
#include "party_menu.h"
|
#include "party_menu.h"
|
||||||
#include "pokemon.h"
|
#include "pokemon.h"
|
||||||
#include "international_string_util.h"
|
#include "international_string_util.h"
|
||||||
|
@ -8532,7 +8533,7 @@ static u16 CalcMoveBasePower(u16 move, u8 battlerAtk, u8 battlerDef)
|
||||||
u32 weight, hpFraction, speed;
|
u32 weight, hpFraction, speed;
|
||||||
|
|
||||||
if (gBattleStruct->zmove.active)
|
if (gBattleStruct->zmove.active)
|
||||||
return gBattleMoves[gBattleStruct->zmove.baseMoves[battlerAtk]].zMovePower;
|
return GetZMovePower(gBattleStruct->zmove.baseMoves[battlerAtk]);
|
||||||
|
|
||||||
switch (gBattleMoves[move].effect)
|
switch (gBattleMoves[move].effect)
|
||||||
{
|
{
|
||||||
|
|
|
@ -535,7 +535,7 @@ bool32 MoveSelectionDisplayZMove(u16 zmove)
|
||||||
static void ZMoveSelectionDisplayPower(u16 move, u16 zMove)
|
static void ZMoveSelectionDisplayPower(u16 move, u16 zMove)
|
||||||
{
|
{
|
||||||
u8 *txtPtr;
|
u8 *txtPtr;
|
||||||
u16 power = gBattleMoves[move].zMovePower;
|
u16 power = GetZMovePower(move);
|
||||||
|
|
||||||
if (zMove >= MOVE_CATASTROPIKA)
|
if (zMove >= MOVE_CATASTROPIKA)
|
||||||
power = gBattleMoves[zMove].power;
|
power = gBattleMoves[zMove].power;
|
||||||
|
@ -698,3 +698,45 @@ static bool32 AreStatsMaxed(u8 battlerId, u8 n)
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
u16 GetZMovePower(u16 move)
|
||||||
|
{
|
||||||
|
if (gBattleMoves[move].split == SPLIT_STATUS)
|
||||||
|
return 0;
|
||||||
|
if (gBattleMoves[move].effect == EFFECT_OHKO)
|
||||||
|
return 180;
|
||||||
|
|
||||||
|
switch (move)
|
||||||
|
{
|
||||||
|
case MOVE_MEGA_DRAIN: return 120;
|
||||||
|
case MOVE_CORE_ENFORCER: return 140;
|
||||||
|
case MOVE_WEATHER_BALL: return 160;
|
||||||
|
case MOVE_HEX: return 160;
|
||||||
|
case MOVE_FLYING_PRESS: return 170;
|
||||||
|
case MOVE_GEAR_GRIND: return 180;
|
||||||
|
case MOVE_V_CREATE: return 220;
|
||||||
|
default:
|
||||||
|
{
|
||||||
|
if (gBattleMoves[move].power >= 140)
|
||||||
|
return 200;
|
||||||
|
else if (gBattleMoves[move].power >= 130)
|
||||||
|
return 195;
|
||||||
|
else if (gBattleMoves[move].power >= 120)
|
||||||
|
return 190;
|
||||||
|
else if (gBattleMoves[move].power >= 110)
|
||||||
|
return 185;
|
||||||
|
else if (gBattleMoves[move].power >= 100)
|
||||||
|
return 180;
|
||||||
|
else if (gBattleMoves[move].power >= 90)
|
||||||
|
return 175;
|
||||||
|
else if (gBattleMoves[move].power >= 80)
|
||||||
|
return 160;
|
||||||
|
else if (gBattleMoves[move].power >= 70)
|
||||||
|
return 140;
|
||||||
|
else if (gBattleMoves[move].power >= 60)
|
||||||
|
return 120;
|
||||||
|
else
|
||||||
|
return 100;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
File diff suppressed because it is too large
Load diff
Loading…
Reference in a new issue