mirror of
https://github.com/Ninjdai1/pokeemerald.git
synced 2025-01-19 09:54:19 +01:00
Merge branch 'battleItemFixes' into battleItemTests
This commit is contained in:
commit
632668e8b2
@ -2077,6 +2077,14 @@
|
|||||||
various \battler, VARIOUS_ACTIVATE_TERRAIN_CHANGE_ABILITIES
|
various \battler, VARIOUS_ACTIVATE_TERRAIN_CHANGE_ABILITIES
|
||||||
.endm
|
.endm
|
||||||
|
|
||||||
|
.macro trytrainerslidezmovemsg battler:req
|
||||||
|
various \battler, VARIOUS_TRY_TRAINER_SLIDE_MSG_Z_MOVE
|
||||||
|
.endm
|
||||||
|
|
||||||
|
.macro trytrainerslidemegaevolutionmsg battler:req
|
||||||
|
various \battler, VARIOUS_TRY_TRAINER_SLIDE_MSG_MEGA_EVOLUTION
|
||||||
|
.endm
|
||||||
|
|
||||||
@ helpful macros
|
@ helpful macros
|
||||||
.macro setstatchanger stat:req, stages:req, down:req
|
.macro setstatchanger stat:req, stages:req, down:req
|
||||||
setbyte sSTATCHANGER, \stat | \stages << 3 | \down << 7
|
setbyte sSTATCHANGER, \stat | \stages << 3 | \down << 7
|
||||||
|
@ -24463,6 +24463,7 @@ General_TurnTrap:
|
|||||||
jumpargeq 0, TRAP_ANIM_MAGMA_STORM, Status_MagmaStorm
|
jumpargeq 0, TRAP_ANIM_MAGMA_STORM, Status_MagmaStorm
|
||||||
jumpargeq 0, TRAP_ANIM_INFESTATION, Status_Infestation
|
jumpargeq 0, TRAP_ANIM_INFESTATION, Status_Infestation
|
||||||
jumpargeq 0, TRAP_ANIM_SNAP_TRAP, Status_Snap_Trap
|
jumpargeq 0, TRAP_ANIM_SNAP_TRAP, Status_Snap_Trap
|
||||||
|
jumpargeq 0, TRAP_ANIM_THUNDER_CAGE, Status_Thunder_Cage
|
||||||
goto Status_BindWrap
|
goto Status_BindWrap
|
||||||
Status_BindWrap:
|
Status_BindWrap:
|
||||||
loadspritegfx ANIM_TAG_TENDRILS
|
loadspritegfx ANIM_TAG_TENDRILS
|
||||||
@ -24549,6 +24550,10 @@ Status_Clamp:
|
|||||||
waitforvisualfinish
|
waitforvisualfinish
|
||||||
end
|
end
|
||||||
|
|
||||||
|
Status_Thunder_Cage:
|
||||||
|
@ TODO
|
||||||
|
goto Move_THUNDER_CAGE
|
||||||
|
|
||||||
Status_Snap_Trap: @ placeholder
|
Status_Snap_Trap: @ placeholder
|
||||||
goto Move_BITE
|
goto Move_BITE
|
||||||
|
|
||||||
|
@ -7871,6 +7871,8 @@ BattleScript_FocusPunchSetUp::
|
|||||||
end2
|
end2
|
||||||
|
|
||||||
BattleScript_MegaEvolution::
|
BattleScript_MegaEvolution::
|
||||||
|
printstring STRINGID_EMPTYSTRING3
|
||||||
|
trytrainerslidemegaevolutionmsg BS_ATTACKER
|
||||||
printstring STRINGID_MEGAEVOREACTING
|
printstring STRINGID_MEGAEVOREACTING
|
||||||
BattleScript_MegaEvolutionAfeterString:
|
BattleScript_MegaEvolutionAfeterString:
|
||||||
waitmessage B_WAIT_TIME_LONG
|
waitmessage B_WAIT_TIME_LONG
|
||||||
@ -7886,6 +7888,8 @@ BattleScript_MegaEvolutionAfeterString:
|
|||||||
end2
|
end2
|
||||||
|
|
||||||
BattleScript_WishMegaEvolution::
|
BattleScript_WishMegaEvolution::
|
||||||
|
printstring STRINGID_EMPTYSTRING3
|
||||||
|
trytrainerslidemegaevolutionmsg BS_ATTACKER
|
||||||
printstring STRINGID_FERVENTWISHREACHED
|
printstring STRINGID_FERVENTWISHREACHED
|
||||||
goto BattleScript_MegaEvolutionAfeterString
|
goto BattleScript_MegaEvolutionAfeterString
|
||||||
|
|
||||||
@ -10075,6 +10079,8 @@ BattleScript_JabocaRowapBerryActivate_Dmg:
|
|||||||
|
|
||||||
@ z moves / effects
|
@ z moves / effects
|
||||||
BattleScript_ZMoveActivateDamaging::
|
BattleScript_ZMoveActivateDamaging::
|
||||||
|
printstring STRINGID_EMPTYSTRING3
|
||||||
|
trytrainerslidezmovemsg BS_ATTACKER
|
||||||
printstring STRINGID_ZPOWERSURROUNDS
|
printstring STRINGID_ZPOWERSURROUNDS
|
||||||
playanimation BS_ATTACKER, B_ANIM_ZMOVE_ACTIVATE, NULL
|
playanimation BS_ATTACKER, B_ANIM_ZMOVE_ACTIVATE, NULL
|
||||||
printstring STRINGID_ZMOVEUNLEASHED
|
printstring STRINGID_ZMOVEUNLEASHED
|
||||||
@ -10082,6 +10088,8 @@ BattleScript_ZMoveActivateDamaging::
|
|||||||
return
|
return
|
||||||
|
|
||||||
BattleScript_ZMoveActivateStatus::
|
BattleScript_ZMoveActivateStatus::
|
||||||
|
printstring STRINGID_EMPTYSTRING3
|
||||||
|
trytrainerslidezmovemsg BS_ATTACKER
|
||||||
savetarget
|
savetarget
|
||||||
printstring STRINGID_ZPOWERSURROUNDS
|
printstring STRINGID_ZPOWERSURROUNDS
|
||||||
playanimation BS_ATTACKER, B_ANIM_ZMOVE_ACTIVATE, NULL
|
playanimation BS_ATTACKER, B_ANIM_ZMOVE_ACTIVATE, NULL
|
||||||
|
@ -49,14 +49,13 @@ BattleScript_UseItemMessage:
|
|||||||
BattleScript_ItemRestoreHP::
|
BattleScript_ItemRestoreHP::
|
||||||
call BattleScript_UseItemMessage
|
call BattleScript_UseItemMessage
|
||||||
itemrestorehp
|
itemrestorehp
|
||||||
printstring STRINGID_ITEMRESTOREDSPECIESHEALTH
|
|
||||||
waitmessage B_WAIT_TIME_LONG
|
|
||||||
jumpifbyte CMP_EQUAL, gBattleCommunication, TRUE, BattleScript_ItemRestoreHP_SendOutRevivedBattler
|
jumpifbyte CMP_EQUAL, gBattleCommunication, TRUE, BattleScript_ItemRestoreHP_SendOutRevivedBattler
|
||||||
bichalfword gMoveResultFlags, MOVE_RESULT_NO_EFFECT
|
bichalfword gMoveResultFlags, MOVE_RESULT_NO_EFFECT
|
||||||
orword gHitMarker, HITMARKER_IGNORE_SUBSTITUTE
|
orword gHitMarker, HITMARKER_IGNORE_SUBSTITUTE
|
||||||
healthbarupdate BS_ATTACKER
|
healthbarupdate BS_ATTACKER
|
||||||
datahpupdate BS_ATTACKER
|
datahpupdate BS_ATTACKER
|
||||||
updatestatusicon BS_ATTACKER
|
printstring STRINGID_ITEMRESTOREDSPECIESHEALTH
|
||||||
|
waitmessage B_WAIT_TIME_LONG
|
||||||
end
|
end
|
||||||
|
|
||||||
BattleScript_ItemRestoreHP_SendOutRevivedBattler:
|
BattleScript_ItemRestoreHP_SendOutRevivedBattler:
|
||||||
@ -68,9 +67,9 @@ BattleScript_ItemRestoreHP_SendOutRevivedBattler:
|
|||||||
BattleScript_ItemCureStatus::
|
BattleScript_ItemCureStatus::
|
||||||
call BattleScript_UseItemMessage
|
call BattleScript_UseItemMessage
|
||||||
itemcurestatus
|
itemcurestatus
|
||||||
|
updatestatusicon BS_ATTACKER
|
||||||
printstring STRINGID_ITEMCUREDSPECIESSTATUS
|
printstring STRINGID_ITEMCUREDSPECIESSTATUS
|
||||||
waitmessage B_WAIT_TIME_LONG
|
waitmessage B_WAIT_TIME_LONG
|
||||||
updatestatusicon BS_ATTACKER
|
|
||||||
end
|
end
|
||||||
|
|
||||||
BattleScript_ItemHealAndCureStatus::
|
BattleScript_ItemHealAndCureStatus::
|
||||||
@ -84,6 +83,8 @@ BattleScript_ItemHealAndCureStatus::
|
|||||||
healthbarupdate BS_ATTACKER
|
healthbarupdate BS_ATTACKER
|
||||||
datahpupdate BS_ATTACKER
|
datahpupdate BS_ATTACKER
|
||||||
updatestatusicon BS_ATTACKER
|
updatestatusicon BS_ATTACKER
|
||||||
|
printstring STRINGID_ITEMRESTOREDSPECIESHEALTH
|
||||||
|
waitmessage B_WAIT_TIME_LONG
|
||||||
end
|
end
|
||||||
|
|
||||||
BattleScript_ItemIncreaseStat::
|
BattleScript_ItemIncreaseStat::
|
||||||
|
@ -517,7 +517,7 @@ struct ZMoveData
|
|||||||
u8 splits[MAX_BATTLERS_COUNT];
|
u8 splits[MAX_BATTLERS_COUNT];
|
||||||
};
|
};
|
||||||
|
|
||||||
struct StolenItem
|
struct LostItem
|
||||||
{
|
{
|
||||||
u16 originalItem:15;
|
u16 originalItem:15;
|
||||||
u16 stolen:1;
|
u16 stolen:1;
|
||||||
@ -640,7 +640,7 @@ struct BattleStruct
|
|||||||
u16 moveEffect2; // For Knock Off
|
u16 moveEffect2; // For Knock Off
|
||||||
u16 changedSpecies[PARTY_SIZE]; // For Zygarde or future forms when multiple mons can change into the same pokemon.
|
u16 changedSpecies[PARTY_SIZE]; // For Zygarde or future forms when multiple mons can change into the same pokemon.
|
||||||
u8 quickClawBattlerId;
|
u8 quickClawBattlerId;
|
||||||
struct StolenItem itemStolen[PARTY_SIZE]; // Player's team that had items stolen (two bytes per party member)
|
struct LostItem itemLost[PARTY_SIZE]; // Player's team that had items consumed or stolen (two bytes per party member)
|
||||||
u8 blunderPolicy:1; // should blunder policy activate
|
u8 blunderPolicy:1; // should blunder policy activate
|
||||||
u8 swapDamageCategory:1; // Photon Geyser, Shell Side Arm, Light That Burns the Sky
|
u8 swapDamageCategory:1; // Photon Geyser, Shell Side Arm, Light That Burns the Sky
|
||||||
u8 forcedSwitch:4; // For each battler
|
u8 forcedSwitch:4; // For each battler
|
||||||
@ -661,6 +661,14 @@ struct BattleStruct
|
|||||||
u8 storedLunarDance:4; // Each battler as a bit.
|
u8 storedLunarDance:4; // Each battler as a bit.
|
||||||
u16 supremeOverlordModifier[MAX_BATTLERS_COUNT];
|
u16 supremeOverlordModifier[MAX_BATTLERS_COUNT];
|
||||||
u8 itemPartyIndex[MAX_BATTLERS_COUNT];
|
u8 itemPartyIndex[MAX_BATTLERS_COUNT];
|
||||||
|
bool8 trainerSlideHalfHpMsgDone;
|
||||||
|
u8 trainerSlideFirstCriticalHitMsgState:2;
|
||||||
|
u8 trainerSlideFirstSuperEffectiveHitMsgState:2;
|
||||||
|
u8 trainerSlideFirstSTABMoveMsgState:2;
|
||||||
|
u8 trainerSlidePlayerMonUnaffectedMsgState:2;
|
||||||
|
bool8 trainerSlideMegaEvolutionMsgDone;
|
||||||
|
bool8 trainerSlideZMoveMsgDone;
|
||||||
|
bool8 trainerSlideBeforeFirstTurnMsgDone;
|
||||||
};
|
};
|
||||||
|
|
||||||
#define F_DYNAMIC_TYPE_1 (1 << 6)
|
#define F_DYNAMIC_TYPE_1 (1 << 6)
|
||||||
|
@ -229,6 +229,14 @@ enum
|
|||||||
TRAINER_SLIDE_LAST_SWITCHIN,
|
TRAINER_SLIDE_LAST_SWITCHIN,
|
||||||
TRAINER_SLIDE_LAST_LOW_HP,
|
TRAINER_SLIDE_LAST_LOW_HP,
|
||||||
TRAINER_SLIDE_FIRST_DOWN,
|
TRAINER_SLIDE_FIRST_DOWN,
|
||||||
|
TRAINER_SLIDE_LAST_HALF_HP,
|
||||||
|
TRAINER_SLIDE_FIRST_CRITICAL_HIT,
|
||||||
|
TRAINER_SLIDE_FIRST_SUPER_EFFECTIVE_HIT,
|
||||||
|
TRAINER_SLIDE_FIRST_STAB_MOVE,
|
||||||
|
TRAINER_SLIDE_PLAYER_MON_UNAFFECTED,
|
||||||
|
TRAINER_SLIDE_MEGA_EVOLUTION,
|
||||||
|
TRAINER_SLIDE_Z_MOVE,
|
||||||
|
TRAINER_SLIDE_BEFORE_FIRST_TURN,
|
||||||
};
|
};
|
||||||
|
|
||||||
void BufferStringBattle(u16 stringID);
|
void BufferStringBattle(u16 stringID);
|
||||||
|
@ -197,7 +197,7 @@ bool32 IsPartnerMonFromSameTrainer(u8 battlerId);
|
|||||||
u8 GetSplitBasedOnStats(u8 battlerId);
|
u8 GetSplitBasedOnStats(u8 battlerId);
|
||||||
void SortBattlersBySpeed(u8 *battlers, bool8 slowToFast);
|
void SortBattlersBySpeed(u8 *battlers, bool8 slowToFast);
|
||||||
bool32 TestSheerForceFlag(u8 battler, u16 move);
|
bool32 TestSheerForceFlag(u8 battler, u16 move);
|
||||||
void TryRestoreStolenItems(void);
|
void TryRestoreHeldItems(void);
|
||||||
bool32 CanStealItem(u8 battlerStealing, u8 battlerItem, u16 item);
|
bool32 CanStealItem(u8 battlerStealing, u8 battlerItem, u16 item);
|
||||||
void TrySaveExchangedItem(u8 battlerId, u16 stolenItem);
|
void TrySaveExchangedItem(u8 battlerId, u16 stolenItem);
|
||||||
bool32 IsPartnerMonFromSameTrainer(u8 battlerId);
|
bool32 IsPartnerMonFromSameTrainer(u8 battlerId);
|
||||||
|
@ -126,6 +126,7 @@
|
|||||||
#define B_X_ITEMS_BUFF GEN_LATEST // In Gen7+, the X Items raise a stat by 2 stages instead of 1.
|
#define B_X_ITEMS_BUFF GEN_LATEST // In Gen7+, the X Items raise a stat by 2 stages instead of 1.
|
||||||
#define B_MENTAL_HERB GEN_LATEST // In Gen5+, the Mental Herb cures Taunt, Encore, Torment, Heal Block, and Disable in addition to Infatuation from before.
|
#define B_MENTAL_HERB GEN_LATEST // In Gen5+, the Mental Herb cures Taunt, Encore, Torment, Heal Block, and Disable in addition to Infatuation from before.
|
||||||
#define B_TRAINERS_KNOCK_OFF_ITEMS TRUE // If TRUE, trainers can steal/swap your items (non-berries are restored after battle). In vanilla games trainers cannot steal items.
|
#define B_TRAINERS_KNOCK_OFF_ITEMS TRUE // If TRUE, trainers can steal/swap your items (non-berries are restored after battle). In vanilla games trainers cannot steal items.
|
||||||
|
#define B_RESTORE_HELD_BATTLE_ITEMS TRUE // In Gen9 all non berry items are restored after battle.
|
||||||
#define B_SOUL_DEW_BOOST GEN_LATEST // In Gens3-6, Soul Dew boosts Lati@s' Sp. Atk and Sp. Def. In Gen7+ it boosts the power of their Psychic and Dragon type moves instead.
|
#define B_SOUL_DEW_BOOST GEN_LATEST // In Gens3-6, Soul Dew boosts Lati@s' Sp. Atk and Sp. Def. In Gen7+ it boosts the power of their Psychic and Dragon type moves instead.
|
||||||
#define B_NET_BALL_MODIFIER GEN_LATEST // In Gen7+, Net Ball's catch multiplier is x5 instead of x3.
|
#define B_NET_BALL_MODIFIER GEN_LATEST // In Gen7+, Net Ball's catch multiplier is x5 instead of x3.
|
||||||
#define B_DIVE_BALL_MODIFIER GEN_LATEST // In Gen4+, Dive Ball's effectiveness increases by when Surfing or Fishing.
|
#define B_DIVE_BALL_MODIFIER GEN_LATEST // In Gen4+, Dive Ball's effectiveness increases by when Surfing or Fishing.
|
||||||
@ -155,6 +156,9 @@
|
|||||||
#define VAR_TERRAIN 0 // If this var has a value, assigning a STATUS_FIELD_xx_TERRAIN to it before battle causes the battle to start with that terrain active
|
#define VAR_TERRAIN 0 // If this var has a value, assigning a STATUS_FIELD_xx_TERRAIN to it before battle causes the battle to start with that terrain active
|
||||||
#define B_VAR_WILD_AI_FLAGS 0 // If not 0, you can use this var to add to default wild AI flags. NOT usable with flags above (1 << 15)
|
#define B_VAR_WILD_AI_FLAGS 0 // If not 0, you can use this var to add to default wild AI flags. NOT usable with flags above (1 << 15)
|
||||||
|
|
||||||
|
// Flag and Var settings
|
||||||
|
#define B_RESET_FLAGS_VARS_AFTER_WHITEOUT TRUE // If TRUE, Overworld_ResetBattleFlagsAndVars will reset battle-related Flags and Vars when the player whites out.
|
||||||
|
|
||||||
// Terrain settings
|
// Terrain settings
|
||||||
#define B_TERRAIN_BG_CHANGE TRUE // If set to TRUE, terrain moves permanently change the default battle background until the effect fades.
|
#define B_TERRAIN_BG_CHANGE TRUE // If set to TRUE, terrain moves permanently change the default battle background until the effect fades.
|
||||||
#define B_THUNDERSTORM_TERRAIN TRUE // If TRUE, overworld Thunderstorm generates Rain and Electric Terrain as in Gen 8.
|
#define B_THUNDERSTORM_TERRAIN TRUE // If TRUE, overworld Thunderstorm generates Rain and Electric Terrain as in Gen 8.
|
||||||
|
@ -583,6 +583,7 @@
|
|||||||
#define TRAP_ANIM_MAGMA_STORM 5
|
#define TRAP_ANIM_MAGMA_STORM 5
|
||||||
#define TRAP_ANIM_INFESTATION 6
|
#define TRAP_ANIM_INFESTATION 6
|
||||||
#define TRAP_ANIM_SNAP_TRAP 7
|
#define TRAP_ANIM_SNAP_TRAP 7
|
||||||
|
#define TRAP_ANIM_THUNDER_CAGE 8
|
||||||
|
|
||||||
// Weather defines for battle animation scripts.
|
// Weather defines for battle animation scripts.
|
||||||
#define ANIM_WEATHER_NONE 0
|
#define ANIM_WEATHER_NONE 0
|
||||||
|
@ -260,6 +260,8 @@
|
|||||||
#define VARIOUS_HIT_SWITCH_TARGET_FAILED 168
|
#define VARIOUS_HIT_SWITCH_TARGET_FAILED 168
|
||||||
#define VARIOUS_JUMP_IF_SHELL_TRAP 169
|
#define VARIOUS_JUMP_IF_SHELL_TRAP 169
|
||||||
#define VARIOUS_TRY_REVIVAL_BLESSING 170
|
#define VARIOUS_TRY_REVIVAL_BLESSING 170
|
||||||
|
#define VARIOUS_TRY_TRAINER_SLIDE_MSG_Z_MOVE 171
|
||||||
|
#define VARIOUS_TRY_TRAINER_SLIDE_MSG_MEGA_EVOLUTION 172
|
||||||
|
|
||||||
// Cmd_manipulatedamage
|
// Cmd_manipulatedamage
|
||||||
#define DMG_CHANGE_SIGN 0
|
#define DMG_CHANGE_SIGN 0
|
||||||
|
@ -651,8 +651,9 @@
|
|||||||
#define STRINGID_ITEMRESTOREDSPECIESHEALTH 649
|
#define STRINGID_ITEMRESTOREDSPECIESHEALTH 649
|
||||||
#define STRINGID_ITEMCUREDSPECIESSTATUS 650
|
#define STRINGID_ITEMCUREDSPECIESSTATUS 650
|
||||||
#define STRINGID_ITEMRESTOREDSPECIESPP 651
|
#define STRINGID_ITEMRESTOREDSPECIESPP 651
|
||||||
|
#define STRINGID_THUNDERCAGETRAPPED 652
|
||||||
|
|
||||||
#define BATTLESTRINGS_COUNT 652
|
#define BATTLESTRINGS_COUNT 653
|
||||||
|
|
||||||
// This is the string id that gBattleStringsTable starts with.
|
// This is the string id that gBattleStringsTable starts with.
|
||||||
// String ids before this (e.g. STRINGID_INTROMSG) are not in the table,
|
// String ids before this (e.g. STRINGID_INTROMSG) are not in the table,
|
||||||
@ -926,7 +927,8 @@
|
|||||||
#define B_MSG_WRAPPED_MAGMA_STORM 6
|
#define B_MSG_WRAPPED_MAGMA_STORM 6
|
||||||
#define B_MSG_WRAPPED_INFESTATION 7
|
#define B_MSG_WRAPPED_INFESTATION 7
|
||||||
#define B_MSG_WRAPPED_SNAP_TRAP 8
|
#define B_MSG_WRAPPED_SNAP_TRAP 8
|
||||||
#define NUM_TRAPPING_MOVES 9
|
#define B_MSG_WRAPPED_THUNDER_CAGE 9
|
||||||
|
#define NUM_TRAPPING_MOVES 10
|
||||||
|
|
||||||
// z effects
|
// z effects
|
||||||
#define B_MSG_Z_RESET_STATS 0
|
#define B_MSG_Z_RESET_STATS 0
|
||||||
|
@ -1129,7 +1129,7 @@ bool32 CanTargetFaintAi(u8 battlerDef, u8 battlerAtk)
|
|||||||
{
|
{
|
||||||
s32 i, dmg;
|
s32 i, dmg;
|
||||||
u32 unusable = AI_DATA->moveLimitations[battlerDef];
|
u32 unusable = AI_DATA->moveLimitations[battlerDef];
|
||||||
u16 *moves = gBattleResources->battleHistory->usedMoves[battlerDef];
|
u16 *moves = GetMovesArray(battlerDef);
|
||||||
|
|
||||||
for (i = 0; i < MAX_MON_MOVES; i++)
|
for (i = 0; i < MAX_MON_MOVES; i++)
|
||||||
{
|
{
|
||||||
|
@ -2736,22 +2736,36 @@ void AnimTask_SetAttackerTargetLeftPos(u8 taskId)
|
|||||||
|
|
||||||
void AnimTask_GetTrappedMoveAnimId(u8 taskId)
|
void AnimTask_GetTrappedMoveAnimId(u8 taskId)
|
||||||
{
|
{
|
||||||
if (gBattleSpritesDataPtr->animationData->animArg == MOVE_FIRE_SPIN)
|
switch (gBattleSpritesDataPtr->animationData->animArg)
|
||||||
|
{
|
||||||
|
case MOVE_FIRE_SPIN:
|
||||||
gBattleAnimArgs[0] = TRAP_ANIM_FIRE_SPIN;
|
gBattleAnimArgs[0] = TRAP_ANIM_FIRE_SPIN;
|
||||||
else if (gBattleSpritesDataPtr->animationData->animArg == MOVE_WHIRLPOOL)
|
break;
|
||||||
|
case MOVE_WHIRLPOOL:
|
||||||
gBattleAnimArgs[0] = TRAP_ANIM_WHIRLPOOL;
|
gBattleAnimArgs[0] = TRAP_ANIM_WHIRLPOOL;
|
||||||
else if (gBattleSpritesDataPtr->animationData->animArg == MOVE_CLAMP)
|
break;
|
||||||
|
case MOVE_CLAMP:
|
||||||
gBattleAnimArgs[0] = TRAP_ANIM_CLAMP;
|
gBattleAnimArgs[0] = TRAP_ANIM_CLAMP;
|
||||||
else if (gBattleSpritesDataPtr->animationData->animArg == MOVE_SAND_TOMB)
|
break;
|
||||||
|
case MOVE_SAND_TOMB:
|
||||||
gBattleAnimArgs[0] = TRAP_ANIM_SAND_TOMB;
|
gBattleAnimArgs[0] = TRAP_ANIM_SAND_TOMB;
|
||||||
else if (gBattleSpritesDataPtr->animationData->animArg == MOVE_MAGMA_STORM)
|
break;
|
||||||
|
case MOVE_MAGMA_STORM:
|
||||||
gBattleAnimArgs[0] = TRAP_ANIM_MAGMA_STORM;
|
gBattleAnimArgs[0] = TRAP_ANIM_MAGMA_STORM;
|
||||||
else if (gBattleSpritesDataPtr->animationData->animArg == MOVE_INFESTATION)
|
break;
|
||||||
|
case MOVE_INFESTATION:
|
||||||
gBattleAnimArgs[0] = TRAP_ANIM_INFESTATION;
|
gBattleAnimArgs[0] = TRAP_ANIM_INFESTATION;
|
||||||
else if (gBattleSpritesDataPtr->animationData->animArg == MOVE_SNAP_TRAP)
|
break;
|
||||||
|
case MOVE_SNAP_TRAP:
|
||||||
gBattleAnimArgs[0] = TRAP_ANIM_SNAP_TRAP;
|
gBattleAnimArgs[0] = TRAP_ANIM_SNAP_TRAP;
|
||||||
else
|
break;
|
||||||
|
case MOVE_THUNDER_CAGE:
|
||||||
|
gBattleAnimArgs[0] = TRAP_ANIM_THUNDER_CAGE;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
gBattleAnimArgs[0] = TRAP_ANIM_BIND;
|
gBattleAnimArgs[0] = TRAP_ANIM_BIND;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
DestroyAnimVisualTask(taskId);
|
DestroyAnimVisualTask(taskId);
|
||||||
}
|
}
|
||||||
|
@ -3190,7 +3190,7 @@ static void BattleStartClearSetData(void)
|
|||||||
{
|
{
|
||||||
gBattleStruct->usedHeldItems[i][B_SIDE_PLAYER] = 0;
|
gBattleStruct->usedHeldItems[i][B_SIDE_PLAYER] = 0;
|
||||||
gBattleStruct->usedHeldItems[i][B_SIDE_OPPONENT] = 0;
|
gBattleStruct->usedHeldItems[i][B_SIDE_OPPONENT] = 0;
|
||||||
gBattleStruct->itemStolen[i].originalItem = GetMonData(&gPlayerParty[i], MON_DATA_HELD_ITEM);
|
gBattleStruct->itemLost[i].originalItem = GetMonData(&gPlayerParty[i], MON_DATA_HELD_ITEM);
|
||||||
gPartyCriticalHits[i] = 0;
|
gPartyCriticalHits[i] = 0;
|
||||||
gBattleStruct->allowedToChangeFormInWeather[i][B_SIDE_PLAYER] = FALSE;
|
gBattleStruct->allowedToChangeFormInWeather[i][B_SIDE_PLAYER] = FALSE;
|
||||||
gBattleStruct->allowedToChangeFormInWeather[i][B_SIDE_OPPONENT] = FALSE;
|
gBattleStruct->allowedToChangeFormInWeather[i][B_SIDE_OPPONENT] = FALSE;
|
||||||
@ -3921,6 +3921,9 @@ static void TryDoEventsBeforeFirstTurn(void)
|
|||||||
StopCryAndClearCrySongs();
|
StopCryAndClearCrySongs();
|
||||||
BattleScriptExecute(BattleScript_ArenaTurnBeginning);
|
BattleScriptExecute(BattleScript_ArenaTurnBeginning);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ((i = ShouldDoTrainerSlide(GetBattlerAtPosition(B_POSITION_OPPONENT_LEFT), TRAINER_SLIDE_BEFORE_FIRST_TURN)))
|
||||||
|
BattleScriptExecute(i == 1 ? BattleScript_TrainerASlideMsgEnd2 : BattleScript_TrainerBSlideMsgEnd2);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void HandleEndTurn_ContinueBattle(void)
|
static void HandleEndTurn_ContinueBattle(void)
|
||||||
@ -4013,6 +4016,16 @@ void BattleTurnPassed(void)
|
|||||||
BattleScriptExecute(BattleScript_ArenaTurnBeginning);
|
BattleScriptExecute(BattleScript_ArenaTurnBeginning);
|
||||||
else if ((i = ShouldDoTrainerSlide(GetBattlerAtPosition(B_POSITION_OPPONENT_LEFT), TRAINER_SLIDE_LAST_LOW_HP)))
|
else if ((i = ShouldDoTrainerSlide(GetBattlerAtPosition(B_POSITION_OPPONENT_LEFT), TRAINER_SLIDE_LAST_LOW_HP)))
|
||||||
BattleScriptExecute(i == 1 ? BattleScript_TrainerASlideMsgEnd2 : BattleScript_TrainerBSlideMsgEnd2);
|
BattleScriptExecute(i == 1 ? BattleScript_TrainerASlideMsgEnd2 : BattleScript_TrainerBSlideMsgEnd2);
|
||||||
|
else if ((i = ShouldDoTrainerSlide(GetBattlerAtPosition(B_POSITION_OPPONENT_LEFT), TRAINER_SLIDE_LAST_HALF_HP)))
|
||||||
|
BattleScriptExecute(i == 1 ? BattleScript_TrainerASlideMsgEnd2 : BattleScript_TrainerBSlideMsgEnd2);
|
||||||
|
else if ((i = ShouldDoTrainerSlide(GetBattlerAtPosition(B_POSITION_OPPONENT_LEFT), TRAINER_SLIDE_FIRST_CRITICAL_HIT)))
|
||||||
|
BattleScriptExecute(i == 1 ? BattleScript_TrainerASlideMsgEnd2 : BattleScript_TrainerBSlideMsgEnd2);
|
||||||
|
else if ((i = ShouldDoTrainerSlide(GetBattlerAtPosition(B_POSITION_OPPONENT_LEFT), TRAINER_SLIDE_FIRST_SUPER_EFFECTIVE_HIT)))
|
||||||
|
BattleScriptExecute(i == 1 ? BattleScript_TrainerASlideMsgEnd2 : BattleScript_TrainerBSlideMsgEnd2);
|
||||||
|
else if ((i = ShouldDoTrainerSlide(GetBattlerAtPosition(B_POSITION_OPPONENT_LEFT), TRAINER_SLIDE_FIRST_STAB_MOVE)))
|
||||||
|
BattleScriptExecute(i == 1 ? BattleScript_TrainerASlideMsgEnd2 : BattleScript_TrainerBSlideMsgEnd2);
|
||||||
|
else if ((i = ShouldDoTrainerSlide(GetBattlerAtPosition(B_POSITION_OPPONENT_LEFT), TRAINER_SLIDE_PLAYER_MON_UNAFFECTED)))
|
||||||
|
BattleScriptExecute(i == 1 ? BattleScript_TrainerASlideMsgEnd2 : BattleScript_TrainerBSlideMsgEnd2);
|
||||||
}
|
}
|
||||||
|
|
||||||
u8 IsRunningFromBattleImpossible(void)
|
u8 IsRunningFromBattleImpossible(void)
|
||||||
@ -5388,9 +5401,9 @@ static void HandleEndTurn_FinishBattle(void)
|
|||||||
TestRunner_Battle_AfterLastTurn();
|
TestRunner_Battle_AfterLastTurn();
|
||||||
BeginFastPaletteFade(3);
|
BeginFastPaletteFade(3);
|
||||||
FadeOutMapMusic(5);
|
FadeOutMapMusic(5);
|
||||||
#if B_TRAINERS_KNOCK_OFF_ITEMS == TRUE
|
#if B_TRAINERS_KNOCK_OFF_ITEMS == TRUE || B_RESTORE_HELD_BATTLE_ITEMS == TRUE
|
||||||
if (gBattleTypeFlags & BATTLE_TYPE_TRAINER)
|
if (gBattleTypeFlags & BATTLE_TYPE_TRAINER)
|
||||||
TryRestoreStolenItems();
|
TryRestoreHeldItems();
|
||||||
#endif
|
#endif
|
||||||
for (i = 0; i < PARTY_SIZE; i++)
|
for (i = 0; i < PARTY_SIZE; i++)
|
||||||
{
|
{
|
||||||
|
@ -465,7 +465,7 @@ const u8 *const gPokeblockWasTooXStringTable[FLAVOR_COUNT] =
|
|||||||
[FLAVOR_SOUR] = sText_PokeblockWasTooSour
|
[FLAVOR_SOUR] = sText_PokeblockWasTooSour
|
||||||
};
|
};
|
||||||
|
|
||||||
static const u8 sText_PlayerUsedItem[] = _("{B_PLAYER_NAME} used\n{B_LAST_ITEM}!");
|
static const u8 sText_PlayerUsedItem[] = _("You used\n{B_LAST_ITEM}!");
|
||||||
static const u8 sText_WallyUsedItem[] = _("WALLY used\n{B_LAST_ITEM}!");
|
static const u8 sText_WallyUsedItem[] = _("WALLY used\n{B_LAST_ITEM}!");
|
||||||
static const u8 sText_Trainer1UsedItem[] = _("{B_ATK_TRAINER_CLASS} {B_ATK_TRAINER_NAME}\nused {B_LAST_ITEM}!");
|
static const u8 sText_Trainer1UsedItem[] = _("{B_ATK_TRAINER_CLASS} {B_ATK_TRAINER_NAME}\nused {B_LAST_ITEM}!");
|
||||||
static const u8 sText_TrainerBlockedBall[] = _("The TRAINER blocked the BALL!");
|
static const u8 sText_TrainerBlockedBall[] = _("The TRAINER blocked the BALL!");
|
||||||
@ -783,12 +783,14 @@ static const u8 sText_ShellTrapDidntWork[] = _("{B_ATK_NAME_WITH_PREFIX}'s shell
|
|||||||
static const u8 sText_CouldntFullyProtect[] = _("{B_DEF_NAME_WITH_PREFIX} couldn't fully protect\nitself and got hurt!");
|
static const u8 sText_CouldntFullyProtect[] = _("{B_DEF_NAME_WITH_PREFIX} couldn't fully protect\nitself and got hurt!");
|
||||||
static const u8 sText_StockpiledEffectWoreOff[] = _("{B_ATK_NAME_WITH_PREFIX}'s stockpiled\neffect wore off!");
|
static const u8 sText_StockpiledEffectWoreOff[] = _("{B_ATK_NAME_WITH_PREFIX}'s stockpiled\neffect wore off!");
|
||||||
static const u8 sText_PkmnRevivedReadyToFight[] = _("{B_BUFF1} was revived and\nis ready to fight again!");
|
static const u8 sText_PkmnRevivedReadyToFight[] = _("{B_BUFF1} was revived and\nis ready to fight again!");
|
||||||
static const u8 sText_ItemRestoredSpeciesHealth[] = _("{B_LAST_ITEM} restored\n{B_BUFF1}'s health!");
|
static const u8 sText_ItemRestoredSpeciesHealth[] = _("{B_BUFF1} had its\nHP restored!");
|
||||||
static const u8 sText_ItemCuredSpeciesStatus[] = _("{B_LAST_ITEM} cured\n{B_BUFF1}'s status!");
|
static const u8 sText_ItemCuredSpeciesStatus[] = _("{B_BUFF1} had\nits status healed!");
|
||||||
static const u8 sText_ItemRestoredSpeciesPP[] = _("{B_LAST_ITEM} restored\n{B_BUFF1}'s PP!");
|
static const u8 sText_ItemRestoredSpeciesPP[] = _("{B_BUFF1} had its\nPP restored!");
|
||||||
|
static const u8 sText_AtkTrappedDef[] = _("{B_ATK_NAME_WITH_PREFIX} trapped\nthe {B_DEF_NAME_WITH_PREFIX}!");
|
||||||
|
|
||||||
const u8 *const gBattleStringsTable[BATTLESTRINGS_COUNT] =
|
const u8 *const gBattleStringsTable[BATTLESTRINGS_COUNT] =
|
||||||
{
|
{
|
||||||
|
[STRINGID_THUNDERCAGETRAPPED - BATTLESTRINGS_TABLE_START] = sText_AtkTrappedDef,
|
||||||
[STRINGID_ITEMRESTOREDSPECIESHEALTH - BATTLESTRINGS_TABLE_START] = sText_ItemRestoredSpeciesHealth,
|
[STRINGID_ITEMRESTOREDSPECIESHEALTH - BATTLESTRINGS_TABLE_START] = sText_ItemRestoredSpeciesHealth,
|
||||||
[STRINGID_ITEMCUREDSPECIESSTATUS - BATTLESTRINGS_TABLE_START] = sText_ItemCuredSpeciesStatus,
|
[STRINGID_ITEMCUREDSPECIESSTATUS - BATTLESTRINGS_TABLE_START] = sText_ItemCuredSpeciesStatus,
|
||||||
[STRINGID_ITEMRESTOREDSPECIESPP - BATTLESTRINGS_TABLE_START] = sText_ItemRestoredSpeciesPP,
|
[STRINGID_ITEMRESTOREDSPECIESPP - BATTLESTRINGS_TABLE_START] = sText_ItemRestoredSpeciesPP,
|
||||||
@ -1679,6 +1681,7 @@ const u16 gWrappedStringIds[NUM_TRAPPING_MOVES] =
|
|||||||
[B_MSG_WRAPPED_MAGMA_STORM] = STRINGID_TRAPPEDBYSWIRLINGMAGMA, // MOVE_MAGMA_STORM
|
[B_MSG_WRAPPED_MAGMA_STORM] = STRINGID_TRAPPEDBYSWIRLINGMAGMA, // MOVE_MAGMA_STORM
|
||||||
[B_MSG_WRAPPED_INFESTATION] = STRINGID_INFESTATION, // MOVE_INFESTATION
|
[B_MSG_WRAPPED_INFESTATION] = STRINGID_INFESTATION, // MOVE_INFESTATION
|
||||||
[B_MSG_WRAPPED_SNAP_TRAP] = STRINGID_PKMNINSNAPTRAP, // MOVE_SNAP_TRAP
|
[B_MSG_WRAPPED_SNAP_TRAP] = STRINGID_PKMNINSNAPTRAP, // MOVE_SNAP_TRAP
|
||||||
|
[B_MSG_WRAPPED_THUNDER_CAGE]= STRINGID_THUNDERCAGETRAPPED, // MOVE_THUNDER_CAGE
|
||||||
};
|
};
|
||||||
|
|
||||||
const u16 gMistUsedStringIds[] =
|
const u16 gMistUsedStringIds[] =
|
||||||
@ -3893,6 +3896,14 @@ struct TrainerSlide
|
|||||||
const u8 *msgLastSwitchIn;
|
const u8 *msgLastSwitchIn;
|
||||||
const u8 *msgLastLowHp;
|
const u8 *msgLastLowHp;
|
||||||
const u8 *msgFirstDown;
|
const u8 *msgFirstDown;
|
||||||
|
const u8 *msgLastHalfHp;
|
||||||
|
const u8 *msgFirstCriticalHit;
|
||||||
|
const u8 *msgFirstSuperEffectiveHit;
|
||||||
|
const u8 *msgFirstSTABMove;
|
||||||
|
const u8 *msgPlayerMonUnaffected;
|
||||||
|
const u8 *msgMegaEvolution;
|
||||||
|
const u8 *msgZMove;
|
||||||
|
const u8 *msgBeforeFirstTurn;
|
||||||
};
|
};
|
||||||
|
|
||||||
static const struct TrainerSlide sTrainerSlides[] =
|
static const struct TrainerSlide sTrainerSlides[] =
|
||||||
@ -3904,6 +3915,14 @@ static const struct TrainerSlide sTrainerSlides[] =
|
|||||||
.msgLastSwitchIn = sText_AarghAlmostHadIt,
|
.msgLastSwitchIn = sText_AarghAlmostHadIt,
|
||||||
.msgLastLowHp = sText_BoxIsFull,
|
.msgLastLowHp = sText_BoxIsFull,
|
||||||
.msgFirstDown = sText_123Poof,
|
.msgFirstDown = sText_123Poof,
|
||||||
|
.msgLastHalfHp = sText_ShootSoClose,
|
||||||
|
.msgFirstCriticalHit = sText_CriticalHit,
|
||||||
|
.msgFirstSuperEffectiveHit = sText_SuperEffective,
|
||||||
|
.msgFirstSTABMove = sText_ABoosted,
|
||||||
|
.msgPlayerMonUnaffected = sText_ButNoEffect,
|
||||||
|
.msgMegaEvolution = sText_PowderExplodes,
|
||||||
|
.msgZMove = sText_Electromagnetism,
|
||||||
|
.msgBeforeFirstTurn = sText_GravityIntensified,
|
||||||
},
|
},
|
||||||
*/
|
*/
|
||||||
};
|
};
|
||||||
@ -3924,12 +3943,35 @@ static u32 GetEnemyMonCount(u32 firstId, u32 lastId, bool32 onlyAlive)
|
|||||||
return count;
|
return count;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool32 IsBattlerHpLow(u32 battler)
|
enum
|
||||||
{
|
{
|
||||||
if ((gBattleMons[battler].hp * 100) / gBattleMons[battler].maxHP < 25)
|
LESS_THAN,
|
||||||
return TRUE;
|
EQUAL,
|
||||||
else
|
GREATER_THAN,
|
||||||
return FALSE;
|
LESS_THAN_OR_EQUAL,
|
||||||
|
GREATER_THAN_OR_EQUAL,
|
||||||
|
NOT_EQUAL,
|
||||||
|
};
|
||||||
|
|
||||||
|
u32 BattlerHPPercentage(u32 battlerId, u32 operation, u32 threshold)
|
||||||
|
{
|
||||||
|
switch (operation)
|
||||||
|
{
|
||||||
|
case LESS_THAN:
|
||||||
|
return gBattleMons[battlerId].hp < (gBattleMons[battlerId].maxHP / threshold);
|
||||||
|
case EQUAL:
|
||||||
|
return gBattleMons[battlerId].hp == (gBattleMons[battlerId].maxHP / threshold);
|
||||||
|
case GREATER_THAN:
|
||||||
|
return gBattleMons[battlerId].hp > (gBattleMons[battlerId].maxHP / threshold);
|
||||||
|
case LESS_THAN_OR_EQUAL:
|
||||||
|
return gBattleMons[battlerId].hp <= (gBattleMons[battlerId].maxHP / threshold);
|
||||||
|
case GREATER_THAN_OR_EQUAL:
|
||||||
|
return gBattleMons[battlerId].hp >= (gBattleMons[battlerId].maxHP / threshold);
|
||||||
|
case NOT_EQUAL:
|
||||||
|
return gBattleMons[battlerId].hp != (gBattleMons[battlerId].maxHP / threshold);
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
u32 ShouldDoTrainerSlide(u32 battlerId, u32 which)
|
u32 ShouldDoTrainerSlide(u32 battlerId, u32 which)
|
||||||
@ -3977,7 +4019,7 @@ u32 ShouldDoTrainerSlide(u32 battlerId, u32 which)
|
|||||||
case TRAINER_SLIDE_LAST_LOW_HP:
|
case TRAINER_SLIDE_LAST_LOW_HP:
|
||||||
if (sTrainerSlides[i].msgLastLowHp != NULL
|
if (sTrainerSlides[i].msgLastLowHp != NULL
|
||||||
&& GetEnemyMonCount(firstId, lastId, TRUE) == 1
|
&& GetEnemyMonCount(firstId, lastId, TRUE) == 1
|
||||||
&& IsBattlerHpLow(battlerId)
|
&& BattlerHPPercentage(battlerId, GREATER_THAN_OR_EQUAL, 4)
|
||||||
&& !gBattleStruct->trainerSlideLowHpMsgDone)
|
&& !gBattleStruct->trainerSlideLowHpMsgDone)
|
||||||
{
|
{
|
||||||
gBattleStruct->trainerSlideLowHpMsgDone = TRUE;
|
gBattleStruct->trainerSlideLowHpMsgDone = TRUE;
|
||||||
@ -3992,6 +4034,79 @@ u32 ShouldDoTrainerSlide(u32 battlerId, u32 which)
|
|||||||
return retValue;
|
return retValue;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
case TRAINER_SLIDE_LAST_HALF_HP:
|
||||||
|
if (sTrainerSlides[i].msgLastHalfHp != NULL
|
||||||
|
&& GetEnemyMonCount(firstId, lastId, TRUE) == GetEnemyMonCount(firstId, lastId, FALSE) - 1
|
||||||
|
&& BattlerHPPercentage(battlerId, LESS_THAN_OR_EQUAL, 2) && BattlerHPPercentage(battlerId, GREATER_THAN, 4)
|
||||||
|
&& !gBattleStruct->trainerSlideHalfHpMsgDone)
|
||||||
|
{
|
||||||
|
gBattleStruct->trainerSlideHalfHpMsgDone = TRUE;
|
||||||
|
gBattleStruct->trainerSlideMsg = sTrainerSlides[i].msgLastHalfHp;
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case TRAINER_SLIDE_FIRST_CRITICAL_HIT:
|
||||||
|
if (sTrainerSlides[i].msgFirstCriticalHit != NULL && gBattleStruct->trainerSlideFirstCriticalHitMsgState == 1)
|
||||||
|
{
|
||||||
|
gBattleStruct->trainerSlideFirstCriticalHitMsgState = 2;
|
||||||
|
gBattleStruct->trainerSlideMsg = sTrainerSlides[i].msgFirstCriticalHit;
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case TRAINER_SLIDE_FIRST_SUPER_EFFECTIVE_HIT:
|
||||||
|
if (sTrainerSlides[i].msgFirstSuperEffectiveHit != NULL
|
||||||
|
&& gBattleStruct->trainerSlideFirstSuperEffectiveHitMsgState == 1
|
||||||
|
&& gBattleMons[battlerId].hp)
|
||||||
|
{
|
||||||
|
gBattleStruct->trainerSlideFirstSuperEffectiveHitMsgState = 2;
|
||||||
|
gBattleStruct->trainerSlideMsg = sTrainerSlides[i].msgFirstSuperEffectiveHit;
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case TRAINER_SLIDE_FIRST_STAB_MOVE:
|
||||||
|
if (sTrainerSlides[i].msgFirstSTABMove != NULL
|
||||||
|
&& gBattleStruct->trainerSlideFirstSTABMoveMsgState == 1
|
||||||
|
&& GetEnemyMonCount(firstId, lastId, TRUE) == GetEnemyMonCount(firstId, lastId, FALSE))
|
||||||
|
{
|
||||||
|
gBattleStruct->trainerSlideFirstSTABMoveMsgState = 2;
|
||||||
|
gBattleStruct->trainerSlideMsg = sTrainerSlides[i].msgFirstSTABMove;
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case TRAINER_SLIDE_PLAYER_MON_UNAFFECTED:
|
||||||
|
if (sTrainerSlides[i].msgPlayerMonUnaffected != NULL
|
||||||
|
&& gBattleStruct->trainerSlidePlayerMonUnaffectedMsgState == 1
|
||||||
|
&& GetEnemyMonCount(firstId, lastId, TRUE) == GetEnemyMonCount(firstId, lastId, FALSE))
|
||||||
|
{
|
||||||
|
gBattleStruct->trainerSlidePlayerMonUnaffectedMsgState = 2;
|
||||||
|
gBattleStruct->trainerSlideMsg = sTrainerSlides[i].msgPlayerMonUnaffected;
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case TRAINER_SLIDE_MEGA_EVOLUTION:
|
||||||
|
if (sTrainerSlides[i].msgMegaEvolution != NULL && !gBattleStruct->trainerSlideMegaEvolutionMsgDone)
|
||||||
|
{
|
||||||
|
gBattleStruct->trainerSlideMegaEvolutionMsgDone = TRUE;
|
||||||
|
gBattleStruct->trainerSlideMsg = sTrainerSlides[i].msgMegaEvolution;
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case TRAINER_SLIDE_Z_MOVE:
|
||||||
|
if (sTrainerSlides[i].msgZMove != NULL && !gBattleStruct->trainerSlideZMoveMsgDone)
|
||||||
|
{
|
||||||
|
gBattleStruct->trainerSlideZMoveMsgDone = TRUE;
|
||||||
|
gBattleStruct->trainerSlideMsg = sTrainerSlides[i].msgZMove;
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case TRAINER_SLIDE_BEFORE_FIRST_TURN:
|
||||||
|
if (sTrainerSlides[i].msgBeforeFirstTurn != NULL && !gBattleStruct->trainerSlideBeforeFirstTurnMsgDone)
|
||||||
|
{
|
||||||
|
gBattleStruct->trainerSlideBeforeFirstTurnMsgDone = TRUE;
|
||||||
|
gBattleStruct->trainerSlideMsg = sTrainerSlides[i].msgBeforeFirstTurn;
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -2568,6 +2568,11 @@ static void Cmd_critmessage(void)
|
|||||||
if (gIsCriticalHit == TRUE && !(gMoveResultFlags & MOVE_RESULT_NO_EFFECT))
|
if (gIsCriticalHit == TRUE && !(gMoveResultFlags & MOVE_RESULT_NO_EFFECT))
|
||||||
{
|
{
|
||||||
PrepareStringBattle(STRINGID_CRITICALHIT, gBattlerAttacker);
|
PrepareStringBattle(STRINGID_CRITICALHIT, gBattlerAttacker);
|
||||||
|
|
||||||
|
// Signal for the trainer slide-in system.
|
||||||
|
if (GetBattlerSide(gBattlerTarget) != B_SIDE_PLAYER && gBattleStruct->trainerSlideFirstCriticalHitMsgState != 2)
|
||||||
|
gBattleStruct->trainerSlideFirstCriticalHitMsgState = 1;
|
||||||
|
|
||||||
gBattleCommunication[MSG_DISPLAY] = 1;
|
gBattleCommunication[MSG_DISPLAY] = 1;
|
||||||
}
|
}
|
||||||
gBattlescriptCurrInstr = cmd->nextInstr;
|
gBattlescriptCurrInstr = cmd->nextInstr;
|
||||||
@ -2647,7 +2652,13 @@ static void Cmd_resultmessage(void)
|
|||||||
{
|
{
|
||||||
case MOVE_RESULT_SUPER_EFFECTIVE:
|
case MOVE_RESULT_SUPER_EFFECTIVE:
|
||||||
if (!gMultiHitCounter) // Don't print effectiveness on each hit in a multi hit attack
|
if (!gMultiHitCounter) // Don't print effectiveness on each hit in a multi hit attack
|
||||||
|
{
|
||||||
|
// Signal for the trainer slide-in system.
|
||||||
|
if (GetBattlerSide(gBattlerTarget) != B_SIDE_PLAYER && gBattleStruct->trainerSlideFirstSuperEffectiveHitMsgState != 2)
|
||||||
|
gBattleStruct->trainerSlideFirstSuperEffectiveHitMsgState = 1;
|
||||||
|
|
||||||
stringId = STRINGID_SUPEREFFECTIVE;
|
stringId = STRINGID_SUPEREFFECTIVE;
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
case MOVE_RESULT_NOT_VERY_EFFECTIVE:
|
case MOVE_RESULT_NOT_VERY_EFFECTIVE:
|
||||||
if (!gMultiHitCounter)
|
if (!gMultiHitCounter)
|
||||||
@ -7892,7 +7903,7 @@ static void BestowItem(u32 battlerAtk, u32 battlerDef)
|
|||||||
// Called by Cmd_removeitem. itemId represents the item that was removed, not being given.
|
// Called by Cmd_removeitem. itemId represents the item that was removed, not being given.
|
||||||
static bool32 TrySymbiosis(u32 battler, u32 itemId)
|
static bool32 TrySymbiosis(u32 battler, u32 itemId)
|
||||||
{
|
{
|
||||||
if (!gBattleStruct->itemStolen[gBattlerPartyIndexes[battler]].stolen
|
if (!gBattleStruct->itemLost[gBattlerPartyIndexes[battler]].stolen
|
||||||
&& gBattleStruct->changedItems[battler] == ITEM_NONE
|
&& gBattleStruct->changedItems[battler] == ITEM_NONE
|
||||||
&& GetBattlerHoldEffect(battler, TRUE) != HOLD_EFFECT_EJECT_BUTTON
|
&& GetBattlerHoldEffect(battler, TRUE) != HOLD_EFFECT_EJECT_BUTTON
|
||||||
&& GetBattlerHoldEffect(battler, TRUE) != HOLD_EFFECT_EJECT_PACK
|
&& GetBattlerHoldEffect(battler, TRUE) != HOLD_EFFECT_EJECT_PACK
|
||||||
@ -11185,15 +11196,6 @@ static void Cmd_various(void)
|
|||||||
AbilityBattleEffects(ABILITYEFFECT_ON_WEATHER, gActiveBattler, 0, 0, 0);
|
AbilityBattleEffects(ABILITYEFFECT_ON_WEATHER, gActiveBattler, 0, 0, 0);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
case VARIOUS_JUMP_IF_SHELL_TRAP:
|
|
||||||
{
|
|
||||||
VARIOUS_ARGS(const u8 *jumpInstr);
|
|
||||||
if (gProtectStructs[gActiveBattler].shellTrap)
|
|
||||||
gBattlescriptCurrInstr = cmd->jumpInstr;
|
|
||||||
else
|
|
||||||
gBattlescriptCurrInstr = cmd->nextInstr;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
case VARIOUS_ACTIVATE_TERRAIN_CHANGE_ABILITIES:
|
case VARIOUS_ACTIVATE_TERRAIN_CHANGE_ABILITIES:
|
||||||
{
|
{
|
||||||
VARIOUS_ARGS();
|
VARIOUS_ARGS();
|
||||||
@ -11226,6 +11228,15 @@ static void Cmd_various(void)
|
|||||||
gBattlescriptCurrInstr = cmd->nextInstr;
|
gBattlescriptCurrInstr = cmd->nextInstr;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
case VARIOUS_JUMP_IF_SHELL_TRAP:
|
||||||
|
{
|
||||||
|
VARIOUS_ARGS(const u8 *jumpInstr);
|
||||||
|
if (gProtectStructs[gActiveBattler].shellTrap)
|
||||||
|
gBattlescriptCurrInstr = cmd->jumpInstr;
|
||||||
|
else
|
||||||
|
gBattlescriptCurrInstr = cmd->nextInstr;
|
||||||
|
return;
|
||||||
|
}
|
||||||
case VARIOUS_TRY_REVIVAL_BLESSING:
|
case VARIOUS_TRY_REVIVAL_BLESSING:
|
||||||
{
|
{
|
||||||
VARIOUS_ARGS(const u8 *failInstr);
|
VARIOUS_ARGS(const u8 *failInstr);
|
||||||
@ -11270,6 +11281,30 @@ static void Cmd_various(void)
|
|||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
case VARIOUS_TRY_TRAINER_SLIDE_MSG_Z_MOVE:
|
||||||
|
{
|
||||||
|
VARIOUS_ARGS();
|
||||||
|
if ((i = ShouldDoTrainerSlide(gActiveBattler, TRAINER_SLIDE_Z_MOVE)))
|
||||||
|
{
|
||||||
|
gBattleScripting.battler = gActiveBattler;
|
||||||
|
BattleScriptPush(cmd->nextInstr);
|
||||||
|
gBattlescriptCurrInstr = (i == 1 ? BattleScript_TrainerASlideMsgRet : BattleScript_TrainerBSlideMsgRet);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case VARIOUS_TRY_TRAINER_SLIDE_MSG_MEGA_EVOLUTION:
|
||||||
|
{
|
||||||
|
VARIOUS_ARGS();
|
||||||
|
if ((i = ShouldDoTrainerSlide(gActiveBattler, TRAINER_SLIDE_MEGA_EVOLUTION)))
|
||||||
|
{
|
||||||
|
gBattleScripting.battler = gActiveBattler;
|
||||||
|
BattleScriptPush(cmd->nextInstr);
|
||||||
|
gBattlescriptCurrInstr = (i == 1 ? BattleScript_TrainerASlideMsgRet : BattleScript_TrainerBSlideMsgRet);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
} // End of switch (cmd->id)
|
} // End of switch (cmd->id)
|
||||||
|
|
||||||
gBattlescriptCurrInstr = cmd->nextInstr;
|
gBattlescriptCurrInstr = cmd->nextInstr;
|
||||||
|
@ -1531,6 +1531,12 @@ void PrepareStringBattle(u16 stringId, u8 battler)
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
// Signal for the trainer slide-in system.
|
||||||
|
if ((stringId == STRINGID_ITDOESNTAFFECT || stringId == STRINGID_PKMNWASNTAFFECTED || stringId == STRINGID_PKMNUNAFFECTED)
|
||||||
|
&& GetBattlerSide(gBattlerTarget) == B_SIDE_OPPONENT
|
||||||
|
&& gBattleStruct->trainerSlidePlayerMonUnaffectedMsgState != 2)
|
||||||
|
gBattleStruct->trainerSlidePlayerMonUnaffectedMsgState = 1;
|
||||||
|
|
||||||
gActiveBattler = battler;
|
gActiveBattler = battler;
|
||||||
BtlController_EmitPrintString(BUFFER_A, stringId);
|
BtlController_EmitPrintString(BUFFER_A, stringId);
|
||||||
MarkBattlerForControllerExec(gActiveBattler);
|
MarkBattlerForControllerExec(gActiveBattler);
|
||||||
@ -9848,6 +9854,10 @@ static u16 CalcTypeEffectivenessMultiplierInternal(u16 move, u8 moveType, u8 bat
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Signal for the trainer slide-in system.
|
||||||
|
if (GetBattlerSide(battlerDef) != B_SIDE_PLAYER && modifier && gBattleStruct->trainerSlideFirstSTABMoveMsgState != 2)
|
||||||
|
gBattleStruct->trainerSlideFirstSTABMoveMsgState = 1;
|
||||||
|
|
||||||
return modifier;
|
return modifier;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -10536,18 +10546,20 @@ void SortBattlersBySpeed(u8 *battlers, bool8 slowToFast)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void TryRestoreStolenItems(void)
|
void TryRestoreHeldItems(void)
|
||||||
{
|
{
|
||||||
u32 i;
|
u32 i;
|
||||||
u16 stolenItem = ITEM_NONE;
|
u16 lostItem = ITEM_NONE;
|
||||||
|
|
||||||
for (i = 0; i < PARTY_SIZE; i++)
|
for (i = 0; i < PARTY_SIZE; i++)
|
||||||
{
|
{
|
||||||
if (gBattleStruct->itemStolen[i].stolen)
|
#if B_RESTORE_HELD_BATTLE_ITEMS == FALSE
|
||||||
|
if (gBattleStruct->itemLost[i].stolen)
|
||||||
|
#endif
|
||||||
{
|
{
|
||||||
stolenItem = gBattleStruct->itemStolen[i].originalItem;
|
lostItem = gBattleStruct->itemLost[i].originalItem;
|
||||||
if (stolenItem != ITEM_NONE && ItemId_GetPocket(stolenItem) != POCKET_BERRIES)
|
if (lostItem != ITEM_NONE && ItemId_GetPocket(lostItem) != POCKET_BERRIES)
|
||||||
SetMonData(&gPlayerParty[i], MON_DATA_HELD_ITEM, &stolenItem); // Restore stolen non-berry items
|
SetMonData(&gPlayerParty[i], MON_DATA_HELD_ITEM, &lostItem); // Restore stolen non-berry items
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -10601,8 +10613,8 @@ void TrySaveExchangedItem(u8 battlerId, u16 stolenItem)
|
|||||||
if (gBattleTypeFlags & BATTLE_TYPE_TRAINER
|
if (gBattleTypeFlags & BATTLE_TYPE_TRAINER
|
||||||
&& !(gBattleTypeFlags & BATTLE_TYPE_FRONTIER)
|
&& !(gBattleTypeFlags & BATTLE_TYPE_FRONTIER)
|
||||||
&& GetBattlerSide(battlerId) == B_SIDE_PLAYER
|
&& GetBattlerSide(battlerId) == B_SIDE_PLAYER
|
||||||
&& stolenItem == gBattleStruct->itemStolen[gBattlerPartyIndexes[battlerId]].originalItem)
|
&& stolenItem == gBattleStruct->itemLost[gBattlerPartyIndexes[battlerId]].originalItem)
|
||||||
gBattleStruct->itemStolen[gBattlerPartyIndexes[battlerId]].stolen = TRUE;
|
gBattleStruct->itemLost[gBattlerPartyIndexes[battlerId]].stolen = TRUE;
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -215,11 +215,7 @@ bool32 IsViableZMove(u8 battlerId, u16 move)
|
|||||||
|
|
||||||
if (move != MOVE_NONE && zMove != MOVE_Z_STATUS && gBattleMoves[move].type == ItemId_GetSecondaryId(item))
|
if (move != MOVE_NONE && zMove != MOVE_Z_STATUS && gBattleMoves[move].type == ItemId_GetSecondaryId(item))
|
||||||
{
|
{
|
||||||
if (IS_MOVE_STATUS(move))
|
|
||||||
gBattleStruct->zmove.chosenZMove = move;
|
|
||||||
else
|
|
||||||
gBattleStruct->zmove.chosenZMove = GetTypeBasedZMove(move, battlerId);
|
gBattleStruct->zmove.chosenZMove = GetTypeBasedZMove(move, battlerId);
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1229,10 +1229,11 @@ void ItemUseInBattle_BagMenu(u8 taskId)
|
|||||||
{
|
{
|
||||||
PlaySE(SE_SELECT);
|
PlaySE(SE_SELECT);
|
||||||
RemoveUsedItem();
|
RemoveUsedItem();
|
||||||
|
ScheduleBgCopyTilemapToVram(2);
|
||||||
if (!InBattlePyramid())
|
if (!InBattlePyramid())
|
||||||
DisplayItemMessage(taskId, FONT_NORMAL, gStringVar4, Task_FadeAndCloseBagMenu);
|
gTasks[taskId].func = Task_FadeAndCloseBagMenu;
|
||||||
else
|
else
|
||||||
DisplayItemMessageInBattlePyramid(taskId, gStringVar4, CloseBattlePyramidBag);
|
gTasks[taskId].func = CloseBattlePyramidBag;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -401,6 +401,25 @@ void Overworld_ResetStateAfterDigEscRope(void)
|
|||||||
FlagClear(FLAG_SYS_USE_FLASH);
|
FlagClear(FLAG_SYS_USE_FLASH);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if B_RESET_FLAGS_VARS_AFTER_WHITEOUT == TRUE
|
||||||
|
void Overworld_ResetBattleFlagsAndVars(void)
|
||||||
|
{
|
||||||
|
#if VAR_TERRAIN != 0
|
||||||
|
VarSet(VAR_TERRAIN, 0);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if B_VAR_WILD_AI_FLAGS != 0
|
||||||
|
VarSet(B_VAR_WILD_AI_FLAGS,0);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
FlagClear(B_FLAG_INVERSE_BATTLE);
|
||||||
|
FlagClear(B_FLAG_FORCE_DOUBLE_WILD);
|
||||||
|
FlagClear(B_SMART_WILD_AI_FLAG);
|
||||||
|
FlagClear(B_FLAG_NO_BAG_USE);
|
||||||
|
FlagClear(B_FLAG_NO_CATCHING);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
static void Overworld_ResetStateAfterWhiteOut(void)
|
static void Overworld_ResetStateAfterWhiteOut(void)
|
||||||
{
|
{
|
||||||
ResetInitialPlayerAvatarState();
|
ResetInitialPlayerAvatarState();
|
||||||
@ -409,8 +428,8 @@ static void Overworld_ResetStateAfterWhiteOut(void)
|
|||||||
FlagClear(FLAG_SYS_SAFARI_MODE);
|
FlagClear(FLAG_SYS_SAFARI_MODE);
|
||||||
FlagClear(FLAG_SYS_USE_STRENGTH);
|
FlagClear(FLAG_SYS_USE_STRENGTH);
|
||||||
FlagClear(FLAG_SYS_USE_FLASH);
|
FlagClear(FLAG_SYS_USE_FLASH);
|
||||||
#if VAR_TERRAIN != 0
|
#if B_RESET_FLAGS_VARS_AFTER_WHITEOUT == TRUE
|
||||||
VarSet(VAR_TERRAIN, 0);
|
Overworld_ResetBattleFlagsAndVars();
|
||||||
#endif
|
#endif
|
||||||
// If you were defeated by Kyogre/Groudon and the step counter has
|
// If you were defeated by Kyogre/Groudon and the step counter has
|
||||||
// maxed out, end the abnormal weather.
|
// maxed out, end the abnormal weather.
|
||||||
|
@ -4470,11 +4470,8 @@ void ItemUseCB_BattleScript(u8 taskId, TaskFunc task)
|
|||||||
gBattleStruct->itemPartyIndex[gBattlerInMenuId] = GetPartyIdFromBattleSlot(gPartyMenu.slotId);
|
gBattleStruct->itemPartyIndex[gBattlerInMenuId] = GetPartyIdFromBattleSlot(gPartyMenu.slotId);
|
||||||
gPartyMenuUseExitCallback = TRUE;
|
gPartyMenuUseExitCallback = TRUE;
|
||||||
PlaySE(SE_SELECT);
|
PlaySE(SE_SELECT);
|
||||||
CopyItemName(gSpecialVar_ItemId, gStringVar2);
|
|
||||||
StringExpandPlaceholders(gStringVar4, gText_PlayerUsedVar2);
|
|
||||||
DisplayPartyMenuMessage(gStringVar4, TRUE);
|
|
||||||
ScheduleBgCopyTilemapToVram(2);
|
|
||||||
RemoveBagItem(gSpecialVar_ItemId, 1);
|
RemoveBagItem(gSpecialVar_ItemId, 1);
|
||||||
|
ScheduleBgCopyTilemapToVram(2);
|
||||||
gTasks[taskId].func = task;
|
gTasks[taskId].func = task;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -4943,9 +4940,6 @@ static void TryUseItemOnMove(u8 taskId)
|
|||||||
gChosenMovePos = ptr->data1;
|
gChosenMovePos = ptr->data1;
|
||||||
gPartyMenuUseExitCallback = TRUE;
|
gPartyMenuUseExitCallback = TRUE;
|
||||||
RemoveBagItem(gSpecialVar_ItemId, 1);
|
RemoveBagItem(gSpecialVar_ItemId, 1);
|
||||||
CopyItemName(gSpecialVar_ItemId, gStringVar2);
|
|
||||||
StringExpandPlaceholders(gStringVar4, gText_PlayerUsedVar2);
|
|
||||||
DisplayPartyMenuMessage(gStringVar4, TRUE);
|
|
||||||
ScheduleBgCopyTilemapToVram(2);
|
ScheduleBgCopyTilemapToVram(2);
|
||||||
gTasks[taskId].func = Task_ClosePartyMenuAfterText;
|
gTasks[taskId].func = Task_ClosePartyMenuAfterText;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user