mirror of
https://github.com/Ninjdai1/pokeemerald.git
synced 2024-12-26 11:44:17 +01:00
merge w be
This commit is contained in:
commit
940a165be7
@ -1886,6 +1886,36 @@
|
|||||||
various \battler, VARIOUS_TRY_TO_APPLY_MIMICRY
|
various \battler, VARIOUS_TRY_TO_APPLY_MIMICRY
|
||||||
.4byte \ptr
|
.4byte \ptr
|
||||||
.endm
|
.endm
|
||||||
|
|
||||||
|
.macro trynoretreat battler:req, ptr:req
|
||||||
|
various \battler, VARIOUS_TRY_NO_RETREAT
|
||||||
|
.4byte \ptr
|
||||||
|
.endm
|
||||||
|
|
||||||
|
.macro trytarshot battler:req, ptr:req
|
||||||
|
various \battler, VARIOUS_TRY_TAR_SHOT
|
||||||
|
.4byte \ptr
|
||||||
|
.endm
|
||||||
|
|
||||||
|
.macro cantarshotwork battler:req, ptr:req
|
||||||
|
various \battler, VARIOUS_CAN_TAR_SHOT_WORK
|
||||||
|
.4byte \ptr
|
||||||
|
.endm
|
||||||
|
|
||||||
|
.macro checkpoltergeist battler:req, ptr:req
|
||||||
|
various \battler, VARIOUS_CHECK_POLTERGEIST
|
||||||
|
.4byte \ptr
|
||||||
|
.endm
|
||||||
|
|
||||||
|
.macro setoctolock battler:req, ptr:req
|
||||||
|
various \battler, VARIOUS_SET_OCTOLOCK
|
||||||
|
.4byte \ptr
|
||||||
|
.endm
|
||||||
|
|
||||||
|
.macro cutonethirdhpraisestats ptr:req
|
||||||
|
various BS_ATTACKER, VARIOUS_CUT_1_3_HP_RAISE_STATS
|
||||||
|
.4byte \ptr
|
||||||
|
.endm
|
||||||
|
|
||||||
.macro photongeysercheck
|
.macro photongeysercheck
|
||||||
various BS_ATTACKER, VARIOUS_PHOTON_GEYSER_CHECK
|
various BS_ATTACKER, VARIOUS_PHOTON_GEYSER_CHECK
|
||||||
|
@ -5,6 +5,7 @@
|
|||||||
#include "constants/moves.h"
|
#include "constants/moves.h"
|
||||||
#include "constants/pokemon.h"
|
#include "constants/pokemon.h"
|
||||||
#include "constants/items.h"
|
#include "constants/items.h"
|
||||||
|
#include "constants/battle_config.h"
|
||||||
.include "asm/macros.inc"
|
.include "asm/macros.inc"
|
||||||
.include "asm/macros/battle_anim_script.inc"
|
.include "asm/macros/battle_anim_script.inc"
|
||||||
.include "constants/constants.inc"
|
.include "constants/constants.inc"
|
||||||
@ -2505,20 +2506,30 @@ Move_GIGA_IMPACT:
|
|||||||
loadspritegfx ANIM_TAG_IMPACT
|
loadspritegfx ANIM_TAG_IMPACT
|
||||||
monbg ANIM_DEF_PARTNER
|
monbg ANIM_DEF_PARTNER
|
||||||
setalpha 12, 8
|
setalpha 12, 8
|
||||||
|
createvisualtask AnimTask_IsContest, 2
|
||||||
|
jumprettrue SetGigaImpactContestsBG
|
||||||
|
createvisualtask AnimTask_IsTargetPlayerSide, 2
|
||||||
|
jumpretfalse SetGigaImpactOpponentBG
|
||||||
|
goto SetGigaImpactPlayerBG
|
||||||
|
SetGigaImpactOpponentBG:
|
||||||
|
fadetobg BG_GIGA_IMPACT_OPPONENT
|
||||||
|
goto GigaImpactContinuity
|
||||||
|
SetGigaImpactPlayerBG:
|
||||||
|
fadetobg BG_GIGA_IMPACT_PLAYER
|
||||||
|
goto GigaImpactContinuity
|
||||||
|
SetGigaImpactContestsBG:
|
||||||
|
fadetobg BG_GIGA_IMPACT_CONTEST
|
||||||
|
goto GigaImpactContinuity
|
||||||
|
GigaImpactContinuity:
|
||||||
playsewithpan SE_M_TAKE_DOWN, SOUND_PAN_ATTACKER
|
playsewithpan SE_M_TAKE_DOWN, SOUND_PAN_ATTACKER
|
||||||
createsprite gVerticalDipSpriteTemplate, ANIM_ATTACKER, 2, 6, 1, ANIM_ATTACKER
|
createsprite gVerticalDipSpriteTemplate, ANIM_ATTACKER, 2, 6, 1, ANIM_ATTACKER
|
||||||
waitforvisualfinish
|
waitforvisualfinish
|
||||||
delay 11
|
delay 11
|
||||||
createsprite gSlideMonToOffsetSpriteTemplate, ANIM_ATTACKER, 2, 0, 26, 0, 0, 5
|
createsprite gSlideMonToOffsetSpriteTemplate, ANIM_ATTACKER, 2, 0, 26, 0, 0, 5
|
||||||
delay 6
|
delay 6
|
||||||
@monbg ANIM_DEF_PARTNER
|
waitbgfadeout
|
||||||
@setalpha 12, 8
|
|
||||||
@createvisualtask AnimTask_WindUpLunge, 5, 7, 0, -18, 8, 23, 10, 40, 10
|
|
||||||
@delay 35
|
|
||||||
createsprite gComplexPaletteBlendSpriteTemplate, 2, 7, 31, 3, 1, 0, 10, 0, 0
|
|
||||||
createsprite gBasicHitSplatSpriteTemplate, 4, 4, -10, 0, 1, 0
|
createsprite gBasicHitSplatSpriteTemplate, 4, 4, -10, 0, 1, 0
|
||||||
playsewithpan SE_M_MEGA_KICK2, SOUND_PAN_TARGET
|
playsewithpan SE_M_MEGA_KICK2, SOUND_PAN_TARGET
|
||||||
call SetImpactBackground
|
|
||||||
delay 1
|
delay 1
|
||||||
createsprite gSlideMonToOffsetSpriteTemplate 2, 5, 1, -16, 0, 0, 4
|
createsprite gSlideMonToOffsetSpriteTemplate 2, 5, 1, -16, 0, 0, 4
|
||||||
waitforvisualfinish
|
waitforvisualfinish
|
||||||
@ -2533,6 +2544,7 @@ Move_GIGA_IMPACT:
|
|||||||
blendoff
|
blendoff
|
||||||
restorebg
|
restorebg
|
||||||
waitbgfadein
|
waitbgfadein
|
||||||
|
waitforvisualfinish
|
||||||
end
|
end
|
||||||
|
|
||||||
Move_NASTY_PLOT:
|
Move_NASTY_PLOT:
|
||||||
@ -7278,7 +7290,7 @@ Move_RELIC_SONG:
|
|||||||
monbg ANIM_DEF_PARTNER
|
monbg ANIM_DEF_PARTNER
|
||||||
launchtask AnimTask_MusicNotesRainbowBlend 0x2 0x0
|
launchtask AnimTask_MusicNotesRainbowBlend 0x2 0x0
|
||||||
waitforvisualfinish
|
waitforvisualfinish
|
||||||
panse_1B 0x1DF, SOUND_PAN_ATTACKER, SOUND_PAN_TARGET, 0x2, 0x0 @ ???
|
createvisualtask SoundTask_PlayCryWithEcho, 2, ANIM_ATTACKER, 2
|
||||||
launchtask AnimTask_UproarDistortion 0x2 0x1 0x0
|
launchtask AnimTask_UproarDistortion 0x2 0x1 0x0
|
||||||
launchtemplate gUproarRingSpriteTemplate 0x3 0x6 0x0 0x0 0x0 0x0 0x1f 0x8
|
launchtemplate gUproarRingSpriteTemplate 0x3 0x6 0x0 0x0 0x0 0x0 0x1f 0x8
|
||||||
launchtemplate gJaggedMusicNoteSpriteTemplate 0x2 0x4 0x0 0x1d 0xfff4 0x0
|
launchtemplate gJaggedMusicNoteSpriteTemplate 0x2 0x4 0x0 0x1d 0xfff4 0x0
|
||||||
@ -14081,7 +14093,87 @@ Move_RISING_VOLTAGE::
|
|||||||
end @to do:
|
end @to do:
|
||||||
|
|
||||||
Move_TERRAIN_PULSE::
|
Move_TERRAIN_PULSE::
|
||||||
end @to do:
|
loadspritegfx ANIM_TAG_DRAGON_PULSE
|
||||||
|
monbg ANIM_TARGET
|
||||||
|
setalpha 12, 8
|
||||||
|
createsprite gSimplePaletteBlendSpriteTemplate, ANIM_ATTACKER, 2, 1, 1, 0, 7, RGB_BLACK
|
||||||
|
launchtask AnimTask_TerrainPulse 0x5 0x0
|
||||||
|
jumpargeq 0x0, TYPE_ELECTRIC, TerrainPulseElectric
|
||||||
|
jumpargeq 0x0, TYPE_GRASS, TerrainPulseGrass
|
||||||
|
jumpargeq 0x0, TYPE_FAIRY, TerrainPulseFairy
|
||||||
|
jumpargeq 0x0, TYPE_PSYCHIC, TerrainPulsePsychic
|
||||||
|
TerrainPulseNormal:
|
||||||
|
createvisualtask AnimTask_BlendParticle, 5, ANIM_TAG_DRAGON_PULSE, 0, 12, 12, RGB_WHITE
|
||||||
|
waitforvisualfinish
|
||||||
|
playsewithpan SE_M_PSYBEAM, SOUND_PAN_ATTACKER
|
||||||
|
createsoundtask SoundTask_LoopSEAdjustPanning, SE_M_PSYBEAM2, SOUND_PAN_ATTACKER, SOUND_PAN_TARGET, 3, 4, 0, 15
|
||||||
|
call DragonPulseParticle
|
||||||
|
call DragonPulseParticle
|
||||||
|
createvisualtask AnimTask_SwayMon, 5, 0, 2, 51200, 24, ANIM_TARGET
|
||||||
|
createvisualtask AnimTask_BlendColorCycle, 2, 4, 2, 2, 0, 12, RGB_WHITE
|
||||||
|
goto TerrainPulseEnd
|
||||||
|
|
||||||
|
TerrainPulseElectric:
|
||||||
|
createvisualtask AnimTask_BlendParticle, 5, ANIM_TAG_DRAGON_PULSE, 0, 12, 12, RGB(27, 27, 0)
|
||||||
|
waitforvisualfinish
|
||||||
|
playsewithpan SE_M_PSYBEAM, SOUND_PAN_ATTACKER
|
||||||
|
createsoundtask SoundTask_LoopSEAdjustPanning, SE_M_PSYBEAM2, SOUND_PAN_ATTACKER, SOUND_PAN_TARGET, 3, 4, 0, 15
|
||||||
|
call DragonPulseParticle
|
||||||
|
call DragonPulseParticle
|
||||||
|
createvisualtask AnimTask_SwayMon, 5, 0, 4, 51200, 24, ANIM_TARGET
|
||||||
|
createvisualtask AnimTask_BlendColorCycle, 2, 4, 2, 2, 0, 12, RGB(27, 27, 0)
|
||||||
|
goto TerrainPulseEnd
|
||||||
|
|
||||||
|
TerrainPulseGrass:
|
||||||
|
createvisualtask AnimTask_BlendParticle, 5, ANIM_TAG_DRAGON_PULSE, 0, 12, 12, RGB(11, 26, 11)
|
||||||
|
waitforvisualfinish
|
||||||
|
playsewithpan SE_M_PSYBEAM, SOUND_PAN_ATTACKER
|
||||||
|
createsoundtask SoundTask_LoopSEAdjustPanning, SE_M_PSYBEAM2, SOUND_PAN_ATTACKER, SOUND_PAN_TARGET, 3, 4, 0, 15
|
||||||
|
call DragonPulseParticle
|
||||||
|
call DragonPulseParticle
|
||||||
|
createvisualtask AnimTask_SwayMon, 5, 0, 4, 51200, 24, ANIM_TARGET
|
||||||
|
createvisualtask AnimTask_BlendColorCycle, 2, 4, 2, 2, 0, 12, RGB(11, 26, 11)
|
||||||
|
goto TerrainPulseEnd
|
||||||
|
|
||||||
|
TerrainPulseFairy:
|
||||||
|
createvisualtask AnimTask_BlendParticle, 5, ANIM_TAG_DRAGON_PULSE, 0, 12, 12, RGB(31, 24, 31)
|
||||||
|
waitforvisualfinish
|
||||||
|
playsewithpan SE_M_PSYBEAM, SOUND_PAN_ATTACKER
|
||||||
|
createsoundtask SoundTask_LoopSEAdjustPanning, SE_M_PSYBEAM2, SOUND_PAN_ATTACKER, SOUND_PAN_TARGET, 3, 4, 0, 15
|
||||||
|
call DragonPulseParticle
|
||||||
|
call DragonPulseParticle
|
||||||
|
createvisualtask AnimTask_SwayMon, 5, 0, 4, 51200, 24, ANIM_TARGET
|
||||||
|
createvisualtask AnimTask_BlendColorCycle, 2, 4, 2, 2, 0, 12, RGB(31, 24, 31)
|
||||||
|
goto TerrainPulseEnd
|
||||||
|
|
||||||
|
TerrainPulsePsychic:
|
||||||
|
createvisualtask AnimTask_BlendParticle, 5, ANIM_TAG_DRAGON_PULSE, 0, 12, 12, RGB(27, 0, 13)
|
||||||
|
waitforvisualfinish
|
||||||
|
playsewithpan SE_M_PSYBEAM, SOUND_PAN_ATTACKER
|
||||||
|
createsoundtask SoundTask_LoopSEAdjustPanning, SE_M_PSYBEAM2, SOUND_PAN_ATTACKER, SOUND_PAN_TARGET, 3, 4, 0, 15
|
||||||
|
call DragonPulseParticle
|
||||||
|
call DragonPulseParticle
|
||||||
|
createvisualtask AnimTask_SwayMon, 5, 0, 4, 51200, 24, ANIM_TARGET
|
||||||
|
createvisualtask AnimTask_BlendColorCycle, 2, 4, 2, 2, 0, 12, RGB(27, 0, 13)
|
||||||
|
goto TerrainPulseEnd
|
||||||
|
|
||||||
|
TerrainPulseEnd:
|
||||||
|
call DragonPulseParticle
|
||||||
|
call DragonPulseParticle
|
||||||
|
call DragonPulseParticle
|
||||||
|
call DragonPulseParticle
|
||||||
|
call DragonPulseParticle
|
||||||
|
call DragonPulseParticle
|
||||||
|
call DragonPulseParticle
|
||||||
|
call DragonPulseParticle
|
||||||
|
call DragonPulseParticle
|
||||||
|
waitforvisualfinish
|
||||||
|
delay 1
|
||||||
|
createsprite gSimplePaletteBlendSpriteTemplate, ANIM_ATTACKER, 2, 1, 1, 7, 0, RGB_BLACK
|
||||||
|
waitforvisualfinish
|
||||||
|
blendoff
|
||||||
|
clearmonbg ANIM_TARGET
|
||||||
|
end
|
||||||
|
|
||||||
Move_SKITTER_SMACK::
|
Move_SKITTER_SMACK::
|
||||||
end @to do:
|
end @to do:
|
||||||
@ -23353,17 +23445,50 @@ Move_SKY_UPPERCUT:
|
|||||||
end
|
end
|
||||||
|
|
||||||
Move_SECRET_POWER:
|
Move_SECRET_POWER:
|
||||||
|
createvisualtask AnimTask_GetFieldTerrain, 5
|
||||||
|
jumpargeq 0, STATUS_FIELD_MISTY_TERRAIN, Move_FAIRY_WIND
|
||||||
|
jumpargeq 0, STATUS_FIELD_GRASSY_TERRAIN, Move_NEEDLE_ARM
|
||||||
|
jumpargeq 0, STATUS_FIELD_ELECTRIC_TERRAIN, Move_THUNDER_SHOCK
|
||||||
|
jumpargeq 0, STATUS_FIELD_PSYCHIC_TERRAIN, Move_CONFUSION
|
||||||
createvisualtask AnimTask_GetBattleTerrain, 5
|
createvisualtask AnimTask_GetBattleTerrain, 5
|
||||||
jumpargeq 0, BATTLE_TERRAIN_GRASS, Move_NEEDLE_ARM
|
jumpargeq 0, BATTLE_TERRAIN_GRASS, Move_NEEDLE_ARM
|
||||||
jumpargeq 0, BATTLE_TERRAIN_LONG_GRASS, Move_MAGICAL_LEAF
|
jumpargeq 0, BATTLE_TERRAIN_LONG_GRASS, Move_MAGICAL_LEAF
|
||||||
jumpargeq 0, BATTLE_TERRAIN_SAND, Move_MUD_SHOT
|
jumpargeq 0, BATTLE_TERRAIN_SAND, Move_MUD_SHOT
|
||||||
jumpargeq 0, BATTLE_TERRAIN_UNDERWATER, Move_WATERFALL
|
jumpargeq 0, BATTLE_TERRAIN_UNDERWATER, Move_WATERFALL
|
||||||
jumpargeq 0, BATTLE_TERRAIN_WATER, Move_SURF
|
jumpargeq 0, BATTLE_TERRAIN_WATER, Move_SURF
|
||||||
jumpargeq 0, BATTLE_TERRAIN_POND, Move_BUBBLE_BEAM
|
jumpargeq 0, BATTLE_TERRAIN_POND, Move_BUBBLE_BEAM
|
||||||
jumpargeq 0, BATTLE_TERRAIN_MOUNTAIN, Move_ROCK_THROW
|
jumpargeq 0, BATTLE_TERRAIN_MOUNTAIN, Move_ROCK_THROW
|
||||||
jumpargeq 0, BATTLE_TERRAIN_CAVE, Move_BITE
|
jumpargeq 0, BATTLE_TERRAIN_CAVE, Move_BITE
|
||||||
jumpargeq 0, BATTLE_TERRAIN_BUILDING, Move_STRENGTH
|
jumpargeq 0, BATTLE_TERRAIN_BUILDING, Move_STRENGTH
|
||||||
|
jumpargeq 0, BATTLE_TERRAIN_SOARING, Move_GUST
|
||||||
|
jumpargeq 0, BATTLE_TERRAIN_SKY_PILLAR, Move_GUST
|
||||||
|
jumpargeq 0, BATTLE_TERRAIN_BURIAL_GROUND, Move_SHADOW_SNEAK
|
||||||
|
jumpargeq 0, BATTLE_TERRAIN_PUDDLE, Move_MUD_SHOT
|
||||||
|
jumpargeq 0, BATTLE_TERRAIN_MARSH, Move_MUD_SHOT
|
||||||
|
jumpargeq 0, BATTLE_TERRAIN_SWAMP, Move_MUD_SHOT
|
||||||
|
.if B_SECRET_POWER_ANIMATION >= GEN_7
|
||||||
|
jumpargeq 0, BATTLE_TERRAIN_SNOW, Move_ICE_SHARD
|
||||||
|
.else
|
||||||
|
jumpargeq 0, BATTLE_TERRAIN_SNOW, Move_AVALANCHE
|
||||||
|
.endif
|
||||||
|
jumpargeq 0, BATTLE_TERRAIN_ICE, Move_ICE_SHARD
|
||||||
|
jumpargeq 0, BATTLE_TERRAIN_VOLCANO, Move_INCINERATE
|
||||||
|
jumpargeq 0, BATTLE_TERRAIN_DISTORTION_WORLD, Move_POUND
|
||||||
|
jumpargeq 0, BATTLE_TERRAIN_SPACE, Move_SWIFT
|
||||||
|
jumpargeq 0, BATTLE_TERRAIN_ULTRA_SPACE, Move_PSYWAVE
|
||||||
|
.if B_SECRET_POWER_ANIMATION >= GEN_7
|
||||||
|
jumpargeq 0, BATTLE_TERRAIN_BUILDING, Move_SPIT_UP
|
||||||
|
goto Move_SPIT_UP
|
||||||
|
.elseif B_SECRET_POWER_ANIMATION == GEN_6
|
||||||
|
jumpargeq 0, BATTLE_TERRAIN_BUILDING, Move_BODY_SLAM
|
||||||
|
goto Move_BODY_SLAM
|
||||||
|
.elseif B_SECRET_POWER_ANIMATION == GEN_5 || B_SECRET_POWER_ANIMATION == GEN_4
|
||||||
|
jumpargeq 0, BATTLE_TERRAIN_BUILDING, Move_BODY_SLAM
|
||||||
|
goto Move_MUD_SLAP
|
||||||
|
.else
|
||||||
|
jumpargeq 0, BATTLE_TERRAIN_BUILDING, Move_STRENGTH
|
||||||
goto Move_SLAM
|
goto Move_SLAM
|
||||||
|
.endif
|
||||||
|
|
||||||
Move_TWISTER:
|
Move_TWISTER:
|
||||||
loadspritegfx ANIM_TAG_LEAF
|
loadspritegfx ANIM_TAG_LEAF
|
||||||
|
@ -395,6 +395,14 @@ gBattleScriptsForMoveEffects::
|
|||||||
.4byte BattleScript_EffectAuraWheel @ EFFECT_AURA_WHEEL
|
.4byte BattleScript_EffectAuraWheel @ EFFECT_AURA_WHEEL
|
||||||
.4byte BattleScript_EffectPhotonGeyser @ EFFECT_PHOTON_GEYSER
|
.4byte BattleScript_EffectPhotonGeyser @ EFFECT_PHOTON_GEYSER
|
||||||
.4byte BattleScript_EffectShellSideArm @ EFFECT_SHELL_SIDE_ARM
|
.4byte BattleScript_EffectShellSideArm @ EFFECT_SHELL_SIDE_ARM
|
||||||
|
.4byte BattleScript_EffectHit @ EFFECT_TERRAIN_PULSE
|
||||||
|
.4byte BattleScript_EffectJawLock @ EFFECT_JAW_LOCK
|
||||||
|
.4byte BattleScript_EffectNoRetreat @ EFFECT_NO_RETREAT
|
||||||
|
.4byte BattleScript_EffectTarShot @ EFFECT_TAR_SHOT
|
||||||
|
.4byte BattleScript_EffectPoltergeist @ EFFECT_POLTERGEIST
|
||||||
|
.4byte BattleScript_EffectOctolock @ EFFECT_OCTOLOCK
|
||||||
|
.4byte BattleScript_EffectClangorousSoul @ EFFECT_CLANGOROUS_SOUL
|
||||||
|
.4byte BattleScript_EffectHit @ EFFECT_BOLT_BEAK
|
||||||
|
|
||||||
BattleScript_EffectShellSideArm:
|
BattleScript_EffectShellSideArm:
|
||||||
shellsidearmcheck
|
shellsidearmcheck
|
||||||
@ -432,6 +440,113 @@ BattleScript_EffectAuraWheel: @ Aura Wheel can only be used by Morpeko
|
|||||||
waitmessage B_WAIT_TIME_LONG
|
waitmessage B_WAIT_TIME_LONG
|
||||||
goto BattleScript_MoveEnd
|
goto BattleScript_MoveEnd
|
||||||
|
|
||||||
|
BattleScript_EffectClangorousSoul:
|
||||||
|
attackcanceler
|
||||||
|
attackstring
|
||||||
|
ppreduce
|
||||||
|
cutonethirdhpraisestats BattleScript_ButItFailed
|
||||||
|
orword gHitMarker, HITMARKER_IGNORE_SUBSTITUTE | HITMARKER_SKIP_DMG_TRACK | HITMARKER_PASSIVE_DAMAGE | HITMARKER_IGNORE_DISGUISE
|
||||||
|
attackanimation
|
||||||
|
waitanimation
|
||||||
|
healthbarupdate BS_ATTACKER
|
||||||
|
datahpupdate BS_ATTACKER
|
||||||
|
call BattleScript_AllStatsUp
|
||||||
|
goto BattleScript_MoveEnd
|
||||||
|
|
||||||
|
BattleScript_EffectOctolock:
|
||||||
|
attackcanceler
|
||||||
|
jumpifsubstituteblocks BattleScript_ButItFailedAtkStringPpReduce
|
||||||
|
accuracycheck BattleScript_PrintMoveMissed, ACC_CURR_MOVE
|
||||||
|
attackstring
|
||||||
|
ppreduce
|
||||||
|
setoctolock BS_TARGET, BattleScript_ButItFailed
|
||||||
|
attackanimation
|
||||||
|
waitanimation
|
||||||
|
printstring STRINGID_CANTESCAPEBECAUSEOFCURRENTMOVE
|
||||||
|
waitmessage B_WAIT_TIME_LONG
|
||||||
|
goto BattleScript_MoveEnd
|
||||||
|
|
||||||
|
BattleScript_OctolockEndTurn::
|
||||||
|
setbyte sSTAT_ANIM_PLAYED, FALSE
|
||||||
|
jumpifstat BS_TARGET, CMP_GREATER_THAN, STAT_DEF, MIN_STAT_STAGE, BattleScript_OctolockLowerDef
|
||||||
|
jumpifstat BS_TARGET, CMP_GREATER_THAN, STAT_SPDEF, MIN_STAT_STAGE, BattleScript_OctolockTryLowerSpDef
|
||||||
|
goto BattleScript_OctolockEnd2
|
||||||
|
BattleScript_OctolockLowerDef:
|
||||||
|
jumpifability BS_TARGET, ABILITY_BIG_PECKS, BattleScript_OctolockTryLowerSpDef
|
||||||
|
playstatchangeanimation BS_ATTACKER, BIT_DEF | BIT_SPDEF, STAT_CHANGE_NEGATIVE
|
||||||
|
setbyte sSTAT_ANIM_PLAYED, TRUE
|
||||||
|
setstatchanger STAT_DEF, 1, TRUE
|
||||||
|
statbuffchange STAT_BUFF_ALLOW_PTR, BattleScript_OctolockTryLowerSpDef
|
||||||
|
jumpifbyte CMP_EQUAL, cMULTISTRING_CHOOSER, B_MSG_STAT_WONT_DECREASE, BattleScript_OctolockTryLowerSpDef
|
||||||
|
printfromtable gStatUpStringIds
|
||||||
|
waitmessage B_WAIT_TIME_LONG
|
||||||
|
BattleScript_OctolockTryLowerSpDef:
|
||||||
|
jumpifbyte CMP_EQUAL, sSTAT_ANIM_PLAYED, TRUE, BattleScript_OctolockSkipSpDefAnim
|
||||||
|
playstatchangeanimation BS_ATTACKER, BIT_SPDEF, STAT_CHANGE_NEGATIVE
|
||||||
|
BattleScript_OctolockSkipSpDefAnim:
|
||||||
|
setstatchanger STAT_SPDEF, 1, TRUE
|
||||||
|
statbuffchange STAT_BUFF_ALLOW_PTR, BattleScript_OctolockEnd2
|
||||||
|
jumpifbyte CMP_EQUAL, cMULTISTRING_CHOOSER, B_MSG_STAT_WONT_DECREASE, BattleScript_OctolockEnd2
|
||||||
|
printfromtable gStatUpStringIds
|
||||||
|
waitmessage B_WAIT_TIME_LONG
|
||||||
|
BattleScript_OctolockEnd2::
|
||||||
|
end2
|
||||||
|
|
||||||
|
BattleScript_EffectPoltergeist:
|
||||||
|
attackcanceler
|
||||||
|
attackstring
|
||||||
|
ppreduce
|
||||||
|
checkpoltergeist BS_TARGET, BattleScript_ButItFailed
|
||||||
|
printstring STRINGID_ABOUTTOUSEPOLTERGEIST
|
||||||
|
waitmessage B_WAIT_TIME_LONG
|
||||||
|
goto BattleScript_HitFromCritCalc
|
||||||
|
|
||||||
|
BattleScript_EffectTarShot:
|
||||||
|
attackcanceler
|
||||||
|
jumpifsubstituteblocks BattleScript_ButItFailedAtkStringPpReduce
|
||||||
|
accuracycheck BattleScript_PrintMoveMissed, ACC_CURR_MOVE
|
||||||
|
cantarshotwork BS_TARGET, BattleScript_ButItFailedAtkStringPpReduce
|
||||||
|
attackstring
|
||||||
|
ppreduce
|
||||||
|
setstatchanger STAT_SPEED, 1, TRUE
|
||||||
|
attackanimation
|
||||||
|
waitanimation
|
||||||
|
statbuffchange STAT_BUFF_ALLOW_PTR, BattleScript_TryTarShot
|
||||||
|
setgraphicalstatchangevalues
|
||||||
|
playanimation BS_TARGET, B_ANIM_STATS_CHANGE, sB_ANIM_ARG1
|
||||||
|
printfromtable gStatDownStringIds
|
||||||
|
waitmessage B_WAIT_TIME_LONG
|
||||||
|
BattleScript_TryTarShot:
|
||||||
|
trytarshot BS_TARGET, BattleScript_MoveEnd
|
||||||
|
printstring STRINGID_PKMNBECAMEWEAKERTOFIRE
|
||||||
|
waitmessage B_WAIT_TIME_LONG
|
||||||
|
goto BattleScript_MoveEnd
|
||||||
|
|
||||||
|
BattleScript_EffectNoRetreat:
|
||||||
|
attackcanceler
|
||||||
|
accuracycheck BattleScript_PrintMoveMissed, ACC_CURR_MOVE
|
||||||
|
attackstring
|
||||||
|
ppreduce
|
||||||
|
trynoretreat BS_TARGET, BattleScript_ButItFailed
|
||||||
|
attackanimation
|
||||||
|
waitanimation
|
||||||
|
call BattleScript_AllStatsUp
|
||||||
|
jumpifstatus2 BS_TARGET, STATUS2_ESCAPE_PREVENTION, BattleScript_MoveEnd
|
||||||
|
setmoveeffect MOVE_EFFECT_PREVENT_ESCAPE
|
||||||
|
seteffectprimary
|
||||||
|
printstring STRINGID_CANTESCAPEDUETOUSEDMOVE
|
||||||
|
waitmessage B_WAIT_TIME_LONG
|
||||||
|
goto BattleScript_MoveEnd
|
||||||
|
|
||||||
|
BattleScript_EffectJawLock:
|
||||||
|
setmoveeffect MOVE_EFFECT_TRAP_BOTH | MOVE_EFFECT_CERTAIN
|
||||||
|
goto BattleScript_EffectHit
|
||||||
|
|
||||||
|
BattleScript_BothCanNoLongerEscape::
|
||||||
|
printstring STRINGID_BOTHCANNOLONGERESCAPE
|
||||||
|
waitmessage B_WAIT_TIME_LONG
|
||||||
|
return
|
||||||
|
|
||||||
BattleScript_EffectHyperspaceFury:
|
BattleScript_EffectHyperspaceFury:
|
||||||
jumpifspecies BS_ATTACKER, SPECIES_HOOPA_UNBOUND, BattleScript_EffectHyperspaceFuryUnbound
|
jumpifspecies BS_ATTACKER, SPECIES_HOOPA_UNBOUND, BattleScript_EffectHyperspaceFuryUnbound
|
||||||
jumpifspecies BS_ATTACKER, SPECIES_HOOPA, BattleScript_ButHoopaCantUseIt
|
jumpifspecies BS_ATTACKER, SPECIES_HOOPA, BattleScript_ButHoopaCantUseIt
|
||||||
@ -1767,7 +1882,7 @@ BattleScript_EffectSoak:
|
|||||||
attackanimation
|
attackanimation
|
||||||
waitanimation
|
waitanimation
|
||||||
trysoak BattleScript_ButItFailed
|
trysoak BattleScript_ButItFailed
|
||||||
printstring STRINGID_TRANSFORMEDINTOWATERTYPE
|
printstring STRINGID_TARGETCHANGEDTYPE
|
||||||
waitmessage B_WAIT_TIME_LONG
|
waitmessage B_WAIT_TIME_LONG
|
||||||
goto BattleScript_MoveEnd
|
goto BattleScript_MoveEnd
|
||||||
|
|
||||||
@ -6368,7 +6483,7 @@ BattleScript_AttackerItemStatRaise::
|
|||||||
playanimation BS_ATTACKER, B_ANIM_STATS_CHANGE, sB_ANIM_ARG1
|
playanimation BS_ATTACKER, B_ANIM_STATS_CHANGE, sB_ANIM_ARG1
|
||||||
waitanimation
|
waitanimation
|
||||||
printstring STRINGID_USINGITEMSTATOFPKMNROSE
|
printstring STRINGID_USINGITEMSTATOFPKMNROSE
|
||||||
waitmessage 0x40
|
waitmessage B_WAIT_TIME_LONG
|
||||||
removeitem BS_ATTACKER
|
removeitem BS_ATTACKER
|
||||||
BattleScript_AttackerItemStatRaiseRet:
|
BattleScript_AttackerItemStatRaiseRet:
|
||||||
return
|
return
|
||||||
@ -9034,7 +9149,7 @@ BattleScript_StickyBarbTransfer::
|
|||||||
BattleScript_RedCardActivates::
|
BattleScript_RedCardActivates::
|
||||||
playanimation BS_SCRIPTING, B_ANIM_HELD_ITEM_EFFECT, NULL
|
playanimation BS_SCRIPTING, B_ANIM_HELD_ITEM_EFFECT, NULL
|
||||||
printstring STRINGID_REDCARDACTIVATE
|
printstring STRINGID_REDCARDACTIVATE
|
||||||
waitmessage 0x40
|
waitmessage B_WAIT_TIME_LONG
|
||||||
swapattackerwithtarget
|
swapattackerwithtarget
|
||||||
jumpifstatus3 BS_EFFECT_BATTLER, STATUS3_ROOTED, BattleScript_RedCardIngrain
|
jumpifstatus3 BS_EFFECT_BATTLER, STATUS3_ROOTED, BattleScript_RedCardIngrain
|
||||||
jumpifability BS_EFFECT_BATTLER, ABILITY_SUCTION_CUPS, BattleScript_RedCardSuctionCups
|
jumpifability BS_EFFECT_BATTLER, ABILITY_SUCTION_CUPS, BattleScript_RedCardSuctionCups
|
||||||
@ -9045,13 +9160,13 @@ BattleScript_RedCardEnd:
|
|||||||
return
|
return
|
||||||
BattleScript_RedCardIngrain:
|
BattleScript_RedCardIngrain:
|
||||||
printstring STRINGID_PKMNANCHOREDITSELF
|
printstring STRINGID_PKMNANCHOREDITSELF
|
||||||
waitmessage 0x40
|
waitmessage B_WAIT_TIME_LONG
|
||||||
removeitem BS_SCRIPTING
|
removeitem BS_SCRIPTING
|
||||||
swapattackerwithtarget
|
swapattackerwithtarget
|
||||||
return
|
return
|
||||||
BattleScript_RedCardSuctionCups:
|
BattleScript_RedCardSuctionCups:
|
||||||
printstring STRINGID_PKMNANCHORSITSELFWITH
|
printstring STRINGID_PKMNANCHORSITSELFWITH
|
||||||
waitmessage 0x40
|
waitmessage B_WAIT_TIME_LONG
|
||||||
removeitem BS_SCRIPTING
|
removeitem BS_SCRIPTING
|
||||||
swapattackerwithtarget
|
swapattackerwithtarget
|
||||||
return
|
return
|
||||||
@ -9060,7 +9175,7 @@ BattleScript_EjectButtonActivates::
|
|||||||
makevisible BS_ATTACKER
|
makevisible BS_ATTACKER
|
||||||
playanimation BS_SCRIPTING, B_ANIM_HELD_ITEM_EFFECT, NULL
|
playanimation BS_SCRIPTING, B_ANIM_HELD_ITEM_EFFECT, NULL
|
||||||
printstring STRINGID_EJECTBUTTONACTIVATE
|
printstring STRINGID_EJECTBUTTONACTIVATE
|
||||||
waitmessage 0x40
|
waitmessage B_WAIT_TIME_LONG
|
||||||
removeitem BS_SCRIPTING
|
removeitem BS_SCRIPTING
|
||||||
makeinvisible BS_SCRIPTING
|
makeinvisible BS_SCRIPTING
|
||||||
openpartyscreen BS_SCRIPTING, BattleScript_EjectButtonEnd
|
openpartyscreen BS_SCRIPTING, BattleScript_EjectButtonEnd
|
||||||
|
@ -1,19 +0,0 @@
|
|||||||
JASC-PAL
|
|
||||||
0100
|
|
||||||
16
|
|
||||||
0 0 0
|
|
||||||
255 214 0
|
|
||||||
255 197 0
|
|
||||||
255 173 0
|
|
||||||
255 165 0
|
|
||||||
148 90 222
|
|
||||||
255 107 0
|
|
||||||
255 132 0
|
|
||||||
255 148 0
|
|
||||||
255 156 41
|
|
||||||
0 0 0
|
|
||||||
0 90 0
|
|
||||||
0 0 0
|
|
||||||
0 0 0
|
|
||||||
0 0 0
|
|
||||||
0 0 0
|
|
19
graphics/battle_anims/backgrounds/new/giga_impact.pal
Normal file
19
graphics/battle_anims/backgrounds/new/giga_impact.pal
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
JASC-PAL
|
||||||
|
0100
|
||||||
|
16
|
||||||
|
0 0 0
|
||||||
|
240 136 184
|
||||||
|
232 104 168
|
||||||
|
136 8 40
|
||||||
|
248 24 104
|
||||||
|
216 32 96
|
||||||
|
224 72 136
|
||||||
|
160 0 48
|
||||||
|
216 0 64
|
||||||
|
200 40 88
|
||||||
|
192 0 56
|
||||||
|
176 32 128
|
||||||
|
176 24 72
|
||||||
|
152 16 56
|
||||||
|
200 48 80
|
||||||
|
216 56 160
|
BIN
graphics/battle_anims/backgrounds/new/giga_impact.png
Normal file
BIN
graphics/battle_anims/backgrounds/new/giga_impact.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 2.3 KiB |
@ -0,0 +1,3 @@
|
|||||||
|
<EFBFBD>$<24>$<24>$<24>$<24>$<24>$<24>$<24>$<24>$<24> <20> <20> <20> <20> <20> <20> <20> <20> <20> <20> <20> <20> <20> <20> <20> D!E!F!G!H!I!@!<21>$<24>$<24>$<24>$<24>$<24>$<24>$<24>$<24>$<24> <20> <20> <20> <20> <20> <20> <20> <20> <20> <20> <20> <20> <20> <20> <20> њ ћ ќ § ў џ ђ Ј$Ї$І$Ѕ$Є$Ѓ$Ђ$Ё$ $ Ё Ђ Ѓ Є Ѕ І Ї Ј Љ Њ Ћ Ќ Ў Џ
|
||||||
|
!!!
!!!!И$З$Ж$Е$Д$Г$В$Б$А$А Б В Г Д Е Ж З И Й К Л М Н О П !!!!!!!Ш$Ч$Ц$Х$Ф$У$Т$С$Р$Р С Т У Ф Х Ц Ч Ш Щ Ъ Ы Ь Э Ю Я *!+!,!-!.!/!"!и$з$ж$е$д$г$в$б$а$а б в г д е ж з и й к л м н о п :!;!<!=!>!?!2!ш$ч$ц$х$ф$у$т$с$р$р с т у ф х ц ч ш щ ъ ы ь э ю я J!K!L!M!N!O!B!ш,ч,ц,х,ф,у,т,с,р,р(с(т(у(ф(х(ц(ч(ш(щ(ъ(ы(ь(э(ю(я(J)K)L)M)N)O)B)и,з,ж,е,д,г,в,б,а,а(б(в(г(д(е(ж(з(и(й(к(л(м(н(о(п(:);)<)=)>)?)2)Ш,Ч,Ц,Х,Ф,У,Т,С,Р,Р(С(Т(У(Ф(Х(Ц(Ч(Ш(Щ(Ъ(Ы(Ь(Э(Ю(Я(*)+),)-).)/)")И,З,Ж,Е,Д,Г,В,Б,А,А(Б(В(Г(Д(Е(Ж(З(И(Й(К(Л(М(Н(О(П()))))))Ј,Ї,І,Ѕ,Є,Ѓ,Ђ,Ё, , (Ё(Ђ(Ѓ(Є(Ѕ(І(Ї(Ј(Љ(Њ(Ћ(Ќ((Ў(Џ(
|
||||||
|
)))
))))<29>,<2C>,<2C>,<2C>,<2C>,<2C>,<2C>,<2C>,<2C>,<2C>(<28>(<28>(<28>(<28>(<28>(<28>(<28>(<28>(<28>(<28>(<28>(<28>(<28>(<28>(<28>(њ(ћ(ќ(§(ў(џ(ђ(<28>,<2C>,<2C>,<2C>,<2C>,<2C>,<2C>,<2C>,<2C>,<2C>(<28>(<28>(<28>(<28>(<28>(<28>(<28>(<28>(<28>(<28>(<28>(<28>(<28>(<28>(<28>(D)E)F)G)H)I)@)
|
Binary file not shown.
@ -1,19 +0,0 @@
|
|||||||
JASC-PAL
|
|
||||||
0100
|
|
||||||
16
|
|
||||||
41 49 49
|
|
||||||
106 139 189
|
|
||||||
246 131 180
|
|
||||||
255 0 255
|
|
||||||
255 16 98
|
|
||||||
238 98 164
|
|
||||||
230 65 131
|
|
||||||
222 0 57
|
|
||||||
222 24 90
|
|
||||||
205 41 74
|
|
||||||
205 32 82
|
|
||||||
189 0 49
|
|
||||||
172 16 65
|
|
||||||
156 0 41
|
|
||||||
148 16 49
|
|
||||||
131 8 32
|
|
Binary file not shown.
Before Width: | Height: | Size: 3.0 KiB |
Binary file not shown.
@ -1,19 +0,0 @@
|
|||||||
JASC-PAL
|
|
||||||
0100
|
|
||||||
16
|
|
||||||
0 0 0
|
|
||||||
255 255 255
|
|
||||||
255 0 255
|
|
||||||
255 16 98
|
|
||||||
246 131 180
|
|
||||||
238 98 164
|
|
||||||
230 65 131
|
|
||||||
222 0 57
|
|
||||||
222 24 90
|
|
||||||
205 32 82
|
|
||||||
205 41 74
|
|
||||||
189 0 49
|
|
||||||
172 16 65
|
|
||||||
156 0 41
|
|
||||||
148 16 49
|
|
||||||
131 8 32
|
|
Binary file not shown.
Before Width: | Height: | Size: 3.0 KiB |
@ -1,3 +0,0 @@
|
|||||||
@%I%H%G%F%E%D%<25>$<24>$<24>$<24>$<24>$<24>$<24>$<24>$<24>$<24>$<24>$<24>$<24>$<24>$<24>$<24>$<24> <20> <20> <20> <20> <20> <20> <20> <20> ђ$џ$ў$§$ќ$ћ$њ$<24>$<24>$<24>$<24>$<24>$<24>$<24>$<24>$<24>$<24>$<24>$<24>$<24>$<24>$<24>$<24>$<24> <20> <20> <20> <20> <20> <20> <20> <20> %%%
%%%
|
|
||||||
%Џ$Ў$$Ќ$Ћ$Њ$Љ$Ј$Ї$І$Ѕ$Є$Ѓ$Ђ$Ё$ $ Ё Ђ Ѓ Є Ѕ І Ї Ј %%%%%%%П$О$Н$М$Л$К$Й$И$З$Ж$Е$Д$Г$В$Б$А$А Б В Г Д Е Ж З И "%/%.%-%,%+%*%Я$Ю$Э$Ь$Ы$Ъ$Щ$Ш$Ч$Ц$Х$Ф$У$Т$С$Р$Р С Т У Ф Х Ц Ч Ш 2%?%>%=%<%;%:%п$о$н$м$л$к$й$и$з$ж$е$д$г$в$б$а$а б в г д е ж з и B%O%N%M%L%K%J%я$ю$э$ь$ы$ъ$щ$ш$ч$ц$х$ф$у$т$с$р$р с т у ф х ц ч ш B-O-N-M-L-K-J-я,ю,э,ь,ы,ъ,щ,ш,ч,ц,х,ф,у,т,с,р,р(с(т(у(ф(х(ц(ч(ш(2-?->-=-<-;-:-п,о,н,м,л,к,й,и,з,ж,е,д,г,в,б,а,а(б(в(г(д(е(ж(з(и("-/-.---,-+-*-Я,Ю,Э,Ь,Ы,Ъ,Щ,Ш,Ч,Ц,Х,Ф,У,Т,С,Р,Р(С(Т(У(Ф(Х(Ц(Ч(Ш(-------П,О,Н,М,Л,К,Й,И,З,Ж,Е,Д,Г,В,Б,А,А(Б(В(Г(Д(Е(Ж(З(И(---
---
|
|
||||||
-Џ,Ў,,Ќ,Ћ,Њ,Љ,Ј,Ї,І,Ѕ,Є,Ѓ,Ђ,Ё, , (Ё(Ђ(Ѓ(Є(Ѕ(І(Ї(Ј(ђ,џ,ў,§,ќ,ћ,њ,<2C>,<2C>,<2C>,<2C>,<2C>,<2C>,<2C>,<2C>,<2C>,<2C>,<2C>,<2C>,<2C>,<2C>,<2C>,<2C>,<2C>(<28>(<28>(<28>(<28>(<28>(<28>(<28>(<28>(@-I-H-G-F-E-D-<2D>,<2C>,<2C>,<2C>,<2C>,<2C>,<2C>,<2C>,<2C>,<2C>,<2C>,<2C>,<2C>,<2C>,<2C>,<2C>,<2C>(<28>(<28>(<28>(<28>(<28>(<28>(<28>(<28>(
|
|
Binary file not shown.
@ -113,6 +113,9 @@ struct DisableStruct
|
|||||||
u8 throatChopTimer;
|
u8 throatChopTimer;
|
||||||
u8 usedMoves:4;
|
u8 usedMoves:4;
|
||||||
u8 wrapTurns;
|
u8 wrapTurns;
|
||||||
|
u8 noRetreat:1;
|
||||||
|
u8 tarShot:1;
|
||||||
|
u8 octolock:1;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct ProtectStruct
|
struct ProtectStruct
|
||||||
@ -225,10 +228,7 @@ struct FieldTimer
|
|||||||
u8 wonderRoomTimer;
|
u8 wonderRoomTimer;
|
||||||
u8 magicRoomTimer;
|
u8 magicRoomTimer;
|
||||||
u8 trickRoomTimer;
|
u8 trickRoomTimer;
|
||||||
u8 grassyTerrainTimer;
|
u8 terrainTimer;
|
||||||
u8 mistyTerrainTimer;
|
|
||||||
u8 electricTerrainTimer;
|
|
||||||
u8 psychicTerrainTimer;
|
|
||||||
u8 gravityTimer;
|
u8 gravityTimer;
|
||||||
u8 fairyLockTimer;
|
u8 fairyLockTimer;
|
||||||
};
|
};
|
||||||
|
@ -35,7 +35,8 @@ u16 AI_GetHoldEffect(u32 battlerId);
|
|||||||
u32 AI_GetMoveAccuracy(u8 battlerAtk, u8 battlerDef, u16 atkAbility, u16 defAbility, u8 atkHoldEffect, u8 defHoldEffect, u16 move);
|
u32 AI_GetMoveAccuracy(u8 battlerAtk, u8 battlerDef, u16 atkAbility, u16 defAbility, u8 atkHoldEffect, u8 defHoldEffect, u16 move);
|
||||||
bool32 DoesBattlerIgnoreAbilityChecks(u16 atkAbility, u16 move);
|
bool32 DoesBattlerIgnoreAbilityChecks(u16 atkAbility, u16 move);
|
||||||
bool32 AI_WeatherHasEffect(void);
|
bool32 AI_WeatherHasEffect(void);
|
||||||
bool32 CanAttackerFaintTarget(u8 battlerAtk, u8 battlerDef, u8 index, u8 numHits);
|
bool32 CanAIFaintTarget(u8 battlerAtk, u8 battlerDef, u8 numHits);
|
||||||
|
bool32 CanIndexMoveFaintTarget(u8 battlerAtk, u8 battlerDef, u8 index, u8 numHits);
|
||||||
bool32 AI_IsTerrainAffected(u8 battlerId, u32 flags);
|
bool32 AI_IsTerrainAffected(u8 battlerId, u32 flags);
|
||||||
bool32 AI_IsBattlerGrounded(u8 battlerId);
|
bool32 AI_IsBattlerGrounded(u8 battlerId);
|
||||||
bool32 HasDamagingMove(u8 battlerId);
|
bool32 HasDamagingMove(u8 battlerId);
|
||||||
|
@ -36,6 +36,7 @@ u32 IsAbilityStatusProtected(u32 battler);
|
|||||||
bool32 TryResetBattlerStatChanges(u8 battler);
|
bool32 TryResetBattlerStatChanges(u8 battler);
|
||||||
bool32 CanCamouflage(u8 battlerId);
|
bool32 CanCamouflage(u8 battlerId);
|
||||||
u16 GetNaturePowerMove(void);
|
u16 GetNaturePowerMove(void);
|
||||||
|
u16 GetSecretPowerMoveEffect(void);
|
||||||
void StealTargetItem(u8 battlerStealer, u8 battlerItem);
|
void StealTargetItem(u8 battlerStealer, u8 battlerItem);
|
||||||
u8 GetCatchingBattler(void);
|
u8 GetCatchingBattler(void);
|
||||||
|
|
||||||
|
@ -412,6 +412,8 @@ extern const u8 BattleScript_MimicryActivatesEnd3[];
|
|||||||
extern const u8 BattleScript_ApplyMimicry[];
|
extern const u8 BattleScript_ApplyMimicry[];
|
||||||
extern const u8 BattleScript_AttackerFormChangeEnd3NoPopup[];
|
extern const u8 BattleScript_AttackerFormChangeEnd3NoPopup[];
|
||||||
extern const u8 BattleScript_AttackerFormChangeMoveEffect[];
|
extern const u8 BattleScript_AttackerFormChangeMoveEffect[];
|
||||||
|
extern const u8 BattleScript_BothCanNoLongerEscape[];
|
||||||
|
extern const u8 BattleScript_OctolockEndTurn[];
|
||||||
extern const u8 BattleScript_NeutralizingGasExits[];
|
extern const u8 BattleScript_NeutralizingGasExits[];
|
||||||
|
|
||||||
#endif // GUARD_BATTLE_SCRIPTS_H
|
#endif // GUARD_BATTLE_SCRIPTS_H
|
||||||
|
@ -104,6 +104,7 @@ u32 IsAbilityOnOpposingSide(u32 battlerId, u32 ability);
|
|||||||
u32 IsAbilityOnField(u32 ability);
|
u32 IsAbilityOnField(u32 ability);
|
||||||
u32 IsAbilityOnFieldExcept(u32 battlerId, u32 ability);
|
u32 IsAbilityOnFieldExcept(u32 battlerId, u32 ability);
|
||||||
u32 IsAbilityPreventingEscape(u32 battlerId);
|
u32 IsAbilityPreventingEscape(u32 battlerId);
|
||||||
|
bool32 IsBattlerProtected(u8 battlerId, u16 move);
|
||||||
bool32 CanBattlerEscape(u32 battlerId); // no ability check
|
bool32 CanBattlerEscape(u32 battlerId); // no ability check
|
||||||
void BattleScriptExecute(const u8* BS_ptr);
|
void BattleScriptExecute(const u8* BS_ptr);
|
||||||
void BattleScriptPushCursorAndCallback(const u8* BS_ptr);
|
void BattleScriptPushCursorAndCallback(const u8* BS_ptr);
|
||||||
|
@ -358,22 +358,38 @@
|
|||||||
#define MOVE_EFFECT_BUG_BITE 0x45
|
#define MOVE_EFFECT_BUG_BITE 0x45
|
||||||
#define MOVE_EFFECT_RECOIL_HP_25 0x46
|
#define MOVE_EFFECT_RECOIL_HP_25 0x46
|
||||||
#define MOVE_EFFECT_RELIC_SONG 0x47
|
#define MOVE_EFFECT_RELIC_SONG 0x47
|
||||||
#define NUM_MOVE_EFFECTS 0x48
|
#define MOVE_EFFECT_TRAP_BOTH 0x48
|
||||||
|
#define NUM_MOVE_EFFECTS 0x49
|
||||||
|
|
||||||
#define MOVE_EFFECT_AFFECTS_USER 0x4000
|
#define MOVE_EFFECT_AFFECTS_USER 0x4000
|
||||||
#define MOVE_EFFECT_CERTAIN 0x8000
|
#define MOVE_EFFECT_CERTAIN 0x8000
|
||||||
|
|
||||||
// Battle terrain defines for gBattleTerrain.
|
// Battle terrain defines for gBattleTerrain.
|
||||||
#define BATTLE_TERRAIN_GRASS 0
|
#define BATTLE_TERRAIN_GRASS 0
|
||||||
#define BATTLE_TERRAIN_LONG_GRASS 1
|
#define BATTLE_TERRAIN_LONG_GRASS 1
|
||||||
#define BATTLE_TERRAIN_SAND 2
|
#define BATTLE_TERRAIN_SAND 2
|
||||||
#define BATTLE_TERRAIN_UNDERWATER 3
|
#define BATTLE_TERRAIN_UNDERWATER 3
|
||||||
#define BATTLE_TERRAIN_WATER 4
|
#define BATTLE_TERRAIN_WATER 4
|
||||||
#define BATTLE_TERRAIN_POND 5
|
#define BATTLE_TERRAIN_POND 5
|
||||||
#define BATTLE_TERRAIN_MOUNTAIN 6
|
#define BATTLE_TERRAIN_MOUNTAIN 6
|
||||||
#define BATTLE_TERRAIN_CAVE 7
|
#define BATTLE_TERRAIN_CAVE 7
|
||||||
#define BATTLE_TERRAIN_BUILDING 8
|
#define BATTLE_TERRAIN_BUILDING 8
|
||||||
#define BATTLE_TERRAIN_PLAIN 9
|
#define BATTLE_TERRAIN_PLAIN 9
|
||||||
|
// New battle terrains are used for Secret Power but not fully implemented.
|
||||||
|
#define BATTLE_TERRAIN_SOARING 10
|
||||||
|
#define BATTLE_TERRAIN_SKY_PILLAR 11
|
||||||
|
#define BATTLE_TERRAIN_BURIAL_GROUND 12
|
||||||
|
#define BATTLE_TERRAIN_PUDDLE 13
|
||||||
|
#define BATTLE_TERRAIN_MARSH 14
|
||||||
|
#define BATTLE_TERRAIN_SWAMP 15
|
||||||
|
#define BATTLE_TERRAIN_SNOW 16
|
||||||
|
#define BATTLE_TERRAIN_ICE 17
|
||||||
|
#define BATTLE_TERRAIN_VOLCANO 18
|
||||||
|
#define BATTLE_TERRAIN_DISTORTION_WORLD 19
|
||||||
|
#define BATTLE_TERRAIN_SPACE 20
|
||||||
|
#define BATTLE_TERRAIN_ULTRA_SPACE 21
|
||||||
|
|
||||||
|
#define BATTLE_TERRAIN_COUNT 22
|
||||||
|
|
||||||
#define B_WAIT_TIME_LONG 64
|
#define B_WAIT_TIME_LONG 64
|
||||||
#define B_WAIT_TIME_MED 48
|
#define B_WAIT_TIME_MED 48
|
||||||
|
@ -95,7 +95,6 @@
|
|||||||
#define B_CRIT_CHANCE GEN_7 // Chances of a critical hit landing. See CalcCritChanceStage.
|
#define B_CRIT_CHANCE GEN_7 // Chances of a critical hit landing. See CalcCritChanceStage.
|
||||||
#define B_CRIT_MULTIPLIER GEN_7 // In Gen6+, critical hits multiply damage by 1.5 instead of 2.
|
#define B_CRIT_MULTIPLIER GEN_7 // In Gen6+, critical hits multiply damage by 1.5 instead of 2.
|
||||||
#define B_PARALYSIS_SPEED GEN_7 // In Gen7+, Speed is decreased by 50% instead of 75%.
|
#define B_PARALYSIS_SPEED GEN_7 // In Gen7+, Speed is decreased by 50% instead of 75%.
|
||||||
#define B_TERRAIN_TYPE_BOOST GEN_8 // In Gen8, damage is boosted by 30% instead of 50%.
|
|
||||||
#define B_CONFUSION_SELF_DMG_CHANCE GEN_7 // In Gen7+, confusion has a 33.3% of self-damage, instead of 50%.
|
#define B_CONFUSION_SELF_DMG_CHANCE GEN_7 // In Gen7+, confusion has a 33.3% of self-damage, instead of 50%.
|
||||||
#define B_MULTI_HIT_CHANCE GEN_7 // In Gen5+, multi-hit moves have different %. See Cmd_setmultihitcounter for values.
|
#define B_MULTI_HIT_CHANCE GEN_7 // In Gen5+, multi-hit moves have different %. See Cmd_setmultihitcounter for values.
|
||||||
|
|
||||||
@ -153,6 +152,8 @@
|
|||||||
#define B_MEMENTO_FAIL GEN_7 // In Gen4+, Memento fails if there is no target or if the target is protected or behind substitute. But not if Atk/Sp. Atk are at -6.
|
#define B_MEMENTO_FAIL GEN_7 // In Gen4+, Memento fails if there is no target or if the target is protected or behind substitute. But not if Atk/Sp. Atk are at -6.
|
||||||
#define B_GLARE_GHOST GEN_7 // In Gen4+, Glare can hit Ghost-type Pokémon normally.
|
#define B_GLARE_GHOST GEN_7 // In Gen4+, Glare can hit Ghost-type Pokémon normally.
|
||||||
#define B_SKILL_SWAP GEN_7 // In Gen4+, Skill Swap triggers switch-in abilities after use.
|
#define B_SKILL_SWAP GEN_7 // In Gen4+, Skill Swap triggers switch-in abilities after use.
|
||||||
|
#define B_BRICK_BREAK GEN_7 // In Gen4+, you can destroy your own side's screens. In Gen 5+, screens are not removed if the target is immune.
|
||||||
|
#define B_WISH_HP_SOURCE GEN_7 // In Gen5+, Wish heals half of the user's max HP instead of the target's.
|
||||||
|
|
||||||
// Ability settings
|
// Ability settings
|
||||||
#define B_ABILITY_WEATHER GEN_7 // In Gen6+, ability-induced weather lasts 5 turns. Before, it lasted until the battle ended or until it was changed by a move or a different weather-affecting ability.
|
#define B_ABILITY_WEATHER GEN_7 // In Gen6+, ability-induced weather lasts 5 turns. Before, it lasted until the battle ended or until it was changed by a move or a different weather-affecting ability.
|
||||||
@ -172,6 +173,17 @@
|
|||||||
#define B_MENTAL_HERB GEN_5 // In Gen5+, the Mental Herb cures Infatuation, Taunt, Encore, Torment, Heal Block, and Disable
|
#define B_MENTAL_HERB GEN_5 // In Gen5+, the Mental Herb cures Infatuation, Taunt, Encore, Torment, Heal Block, and Disable
|
||||||
#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_SOUL_DEW_BOOST GEN_7 // 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_7 // 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_7 // In Gen7+, Net Ball's catch multiplier is x5 instead of x3.
|
||||||
|
#define B_DIVE_BALL_MODIFIER GEN_7 // In Gen4+, Dive Ball's effectiveness increases by when Surfing or Fishing.
|
||||||
|
#define B_NEST_BALL_MODIFIER GEN_7 // Nest Ball's formula varies depending on the Gen. See Cmd_handleballthrow.
|
||||||
|
#define B_REPEAT_BALL_MODIFIER GEN_7 // In Gen7+, Repeat Ball's catch multiplier is x3.5 instead of x3.
|
||||||
|
#define B_TIMER_BALL_MODIFIER GEN_7 // In Gen5+, Timer Ball's effectiveness increases by x0.3 per turn instead of x0.1
|
||||||
|
#define B_DUSK_BALL_MODIFIER GEN_7 // In Gen7+, Dusk Ball's catch multiplier is x3 instead of x3.5.
|
||||||
|
#define B_QUICK_BALL_MODIFIER GEN_7 // In Gen5+, Quick Ball's catch multiplier is x5 instead of x4.
|
||||||
|
#define B_LURE_BALL_MODIFIER GEN_7 // In Gen7+, Lure Ball's catch multiplier is x5 instead of x3.
|
||||||
|
#define B_HEAVY_BALL_MODIFIER GEN_7 // In Gen7+, Heavy Ball's ranges change. See Cmd_handleballthrow.
|
||||||
|
#define B_DREAM_BALL_MODIFIER GEN_8 // In Gen8, Dream Ball's catch multiplier is x4 when the target is asleep or has the ability Comatose.
|
||||||
|
#define B_SERENE_GRACE_BOOST GEN_7 // In Gen5+, Serene Grace boosts the added flinch chance of King's Rock and Razor Fang.
|
||||||
|
|
||||||
// Flag settings
|
// Flag settings
|
||||||
// To use the following features in scripting, replace the 0s with the flag ID you're assigning it to.
|
// To use the following features in scripting, replace the 0s with the flag ID you're assigning it to.
|
||||||
@ -184,26 +196,31 @@
|
|||||||
// Eg: Replace with VAR_UNUSED_0x40F7 so you can use VAR_TERRAIN for that feature.
|
// Eg: Replace with VAR_UNUSED_0x40F7 so you can use VAR_TERRAIN for that feature.
|
||||||
#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
|
||||||
|
|
||||||
|
// 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_THUNDERSTORM_TERRAIN TRUE // If TRUE, overworld Thunderstorm generates Rain and Electric Terrain as in Gen 8.
|
||||||
|
#define B_TERRAIN_TYPE_BOOST GEN_8 // In Gen8, damage is boosted by 30% instead of 50%.
|
||||||
|
#define B_SECRET_POWER_EFFECT GEN_7 // Secret Power's effects change depending on terrain and generation. See GetSecretPowerMoveEffect.
|
||||||
|
#define B_SECRET_POWER_ANIMATION GEN_7 // Secret Power's animations change depending on terrain and generation.
|
||||||
|
#define B_NATURE_POWER_MOVES GEN_8 // Nature Power calls different moves depending on terrain and generation. See sNaturePowerMoves.
|
||||||
|
#define B_CAMOUFLAGE_TYPES GEN_7 // Camouflage changes the user to different types depending on terrain and generation. See sTerrainToType.
|
||||||
|
|
||||||
// Interface settings
|
// Interface settings
|
||||||
#define B_ABILITY_POP_UP TRUE // In Gen5+, the Pokémon abilities are displayed in a pop-up, when they activate in battle.
|
#define B_ABILITY_POP_UP TRUE // In Gen5+, the Pokémon abilities are displayed in a pop-up, when they activate in battle.
|
||||||
#define B_FAST_INTRO TRUE // If set to TRUE, battle intro texts print at the same time as animation of a Pokémon, as opposing to waiting for the animation to end.
|
#define B_FAST_INTRO TRUE // If set to TRUE, battle intro texts print at the same time as animation of a Pokémon, as opposing to waiting for the animation to end.
|
||||||
#define B_SHOW_TARGETS TRUE // If set to TRUE, all available targets, for moves hitting 2 or 3 Pokémon, will be shown before selecting a move.
|
#define B_SHOW_TARGETS TRUE // If set to TRUE, all available targets, for moves hitting 2 or 3 Pokémon, will be shown before selecting a move.
|
||||||
#define B_SHOW_SPLIT_ICON TRUE // If set to TRUE, it will show an icon in the summary showing the move's category split.
|
#define B_SHOW_SPLIT_ICON TRUE // If set to TRUE, it will show an icon in the summary showing the move's category split.
|
||||||
#define B_HIDE_HEALTHBOX_IN_ANIMS TRUE // If set to TRUE, hides healthboxes during move animations.
|
#define B_HIDE_HEALTHBOX_IN_ANIMS TRUE // If set to TRUE, hides healthboxes during move animations.
|
||||||
#define B_TERRAIN_BG_CHANGE TRUE // If set to TRUE, terrain moves permanently change the default battle background until the effect fades.
|
|
||||||
|
|
||||||
// Critical Capture
|
// Catching settings
|
||||||
#define B_CRITICAL_CAPTURE TRUE // If set to TRUE, Critical Capture will be enabled.
|
#define B_SEMI_INVULNERABLE_CATCH GEN_7 // In Gen4+, you cannot throw a ball against a Pokemon that is in a semi-invulnerable state (dig/fly/etc)
|
||||||
#define B_CATCHING_CHARM_BOOST 20 // % boost in Critical Capture odds if player has the Catching Charm.
|
#define B_CATCHING_CHARM_BOOST 20 // % boost in Critical Capture odds if player has the Catching Charm.
|
||||||
|
#define B_CRITICAL_CAPTURE TRUE // If set to TRUE, Critical Capture will be enabled.
|
||||||
// Last Used Ball
|
#define B_LAST_USED_BALL TRUE // If TRUE, the "last used ball" feature from Gen 7 will be implemented
|
||||||
#define B_LAST_USED_BALL TRUE // If TRUE, the "last used ball" feature from Gen 7 will be implemented
|
#define B_LAST_USED_BALL_BUTTON R_BUTTON // If last used ball is implemented, this button (or button combo) will trigger throwing the last used ball.
|
||||||
#define B_LAST_USED_BALL_BUTTON R_BUTTON // If last used ball is implemented, this button (or button combo) will trigger throwing the last used ball.
|
|
||||||
|
|
||||||
// Other
|
// Other
|
||||||
#define B_DOUBLE_WILD_CHANCE 0 // % chance of encountering two Pokémon in a Wild Encounter.
|
#define B_DOUBLE_WILD_CHANCE 0 // % chance of encountering two Pokémon in a Wild Encounter.
|
||||||
#define B_THUNDERSTORM_TERRAIN TRUE // If TRUE, overworld Thunderstorm generates Rain and Electric Terrain as in Gen 8.
|
|
||||||
#define B_SEMI_INVULNERABLE_CATCH GEN_7 // In Gen4+, you cannot throw a ball against a Pokemon that is in a semi-invulnerable state (dig/fly/etc)
|
|
||||||
|
|
||||||
// Animation Settings
|
// Animation Settings
|
||||||
#define B_NEW_SWORD_PARTICLE FALSE // If set to TRUE, it updates Swords Dance's particle.
|
#define B_NEW_SWORD_PARTICLE FALSE // If set to TRUE, it updates Swords Dance's particle.
|
||||||
|
@ -378,7 +378,15 @@
|
|||||||
#define EFFECT_AURA_WHEEL 372
|
#define EFFECT_AURA_WHEEL 372
|
||||||
#define EFFECT_PHOTON_GEYSER 373
|
#define EFFECT_PHOTON_GEYSER 373
|
||||||
#define EFFECT_SHELL_SIDE_ARM 374
|
#define EFFECT_SHELL_SIDE_ARM 374
|
||||||
|
#define EFFECT_TERRAIN_PULSE 375
|
||||||
|
#define EFFECT_JAW_LOCK 376
|
||||||
|
#define EFFECT_NO_RETREAT 377
|
||||||
|
#define EFFECT_TAR_SHOT 378
|
||||||
|
#define EFFECT_POLTERGEIST 379
|
||||||
|
#define EFFECT_OCTOLOCK 380
|
||||||
|
#define EFFECT_CLANGOROUS_SOUL 381
|
||||||
|
#define EFFECT_BOLT_BEAK 382
|
||||||
|
|
||||||
#define NUM_BATTLE_MOVE_EFFECTS 375
|
#define NUM_BATTLE_MOVE_EFFECTS 383
|
||||||
|
|
||||||
#endif // GUARD_CONSTANTS_BATTLE_MOVE_EFFECTS_H
|
#endif // GUARD_CONSTANTS_BATTLE_MOVE_EFFECTS_H
|
||||||
|
@ -201,7 +201,13 @@
|
|||||||
#define VARIOUS_TRY_TO_APPLY_MIMICRY 128
|
#define VARIOUS_TRY_TO_APPLY_MIMICRY 128
|
||||||
#define VARIOUS_PHOTON_GEYSER_CHECK 129
|
#define VARIOUS_PHOTON_GEYSER_CHECK 129
|
||||||
#define VARIOUS_SHELL_SIDE_ARM_CHECK 130
|
#define VARIOUS_SHELL_SIDE_ARM_CHECK 130
|
||||||
#define VARIOUS_TRY_END_NEUTRALIZING_GAS 131
|
#define VARIOUS_TRY_NO_RETREAT 131
|
||||||
|
#define VARIOUS_TRY_TAR_SHOT 132
|
||||||
|
#define VARIOUS_CAN_TAR_SHOT_WORK 133
|
||||||
|
#define VARIOUS_CHECK_POLTERGEIST 134
|
||||||
|
#define VARIOUS_SET_OCTOLOCK 135
|
||||||
|
#define VARIOUS_CUT_1_3_HP_RAISE_STATS 136
|
||||||
|
#define VARIOUS_TRY_END_NEUTRALIZING_GAS 137
|
||||||
|
|
||||||
// Cmd_manipulatedamage
|
// Cmd_manipulatedamage
|
||||||
#define DMG_CHANGE_SIGN 0
|
#define DMG_CHANGE_SIGN 0
|
||||||
@ -220,6 +226,7 @@
|
|||||||
// Cmd_statbuffchange
|
// Cmd_statbuffchange
|
||||||
#define STAT_BUFF_ALLOW_PTR (1 << 0) // If set, allow use of jumpptr. Set in every use of statbuffchange
|
#define STAT_BUFF_ALLOW_PTR (1 << 0) // If set, allow use of jumpptr. Set in every use of statbuffchange
|
||||||
#define STAT_BUFF_NOT_PROTECT_AFFECTED (1 << 5)
|
#define STAT_BUFF_NOT_PROTECT_AFFECTED (1 << 5)
|
||||||
|
#define STAT_BUFF_UPDATE_MOVE_EFFECT (1 << 6)
|
||||||
|
|
||||||
// stat change flags for Cmd_playstatchangeanimation
|
// stat change flags for Cmd_playstatchangeanimation
|
||||||
#define STAT_CHANGE_NEGATIVE (1 << 0)
|
#define STAT_CHANGE_NEGATIVE (1 << 0)
|
||||||
|
@ -420,7 +420,7 @@
|
|||||||
#define STRINGID_HURLEDINTOTHEAIR 416
|
#define STRINGID_HURLEDINTOTHEAIR 416
|
||||||
#define STRINGID_HELDITEMSLOSEEFFECTS 417
|
#define STRINGID_HELDITEMSLOSEEFFECTS 417
|
||||||
#define STRINGID_FELLSTRAIGHTDOWN 418
|
#define STRINGID_FELLSTRAIGHTDOWN 418
|
||||||
#define STRINGID_TRANSFORMEDINTOWATERTYPE 419
|
#define STRINGID_TARGETCHANGEDTYPE 419
|
||||||
#define STRINGID_PKMNACQUIREDSIMPLE 420
|
#define STRINGID_PKMNACQUIREDSIMPLE 420
|
||||||
#define STRINGID_EMPTYSTRING5 421
|
#define STRINGID_EMPTYSTRING5 421
|
||||||
#define STRINGID_KINDOFFER 422
|
#define STRINGID_KINDOFFER 422
|
||||||
@ -602,10 +602,15 @@
|
|||||||
#define STRINGID_PASTELVEILPROTECTED 599
|
#define STRINGID_PASTELVEILPROTECTED 599
|
||||||
#define STRINGID_PASTELVEILENTERS 600
|
#define STRINGID_PASTELVEILENTERS 600
|
||||||
#define STRINGID_BATTLERTYPECHANGEDTO 601
|
#define STRINGID_BATTLERTYPECHANGEDTO 601
|
||||||
#define STRINGID_NEUTRALIZINGGASENTERS 602
|
#define STRINGID_BOTHCANNOLONGERESCAPE 602
|
||||||
#define STRINGID_NEUTRALIZINGGASOVER 603
|
#define STRINGID_CANTESCAPEDUETOUSEDMOVE 603
|
||||||
|
#define STRINGID_PKMNBECAMEWEAKERTOFIRE 604
|
||||||
|
#define STRINGID_ABOUTTOUSEPOLTERGEIST 605
|
||||||
|
#define STRINGID_CANTESCAPEBECAUSEOFCURRENTMOVE 606
|
||||||
|
#define STRINGID_NEUTRALIZINGGASENTERS 607
|
||||||
|
#define STRINGID_NEUTRALIZINGGASOVER 608
|
||||||
|
|
||||||
#define BATTLESTRINGS_COUNT 604
|
#define BATTLESTRINGS_COUNT 609
|
||||||
|
|
||||||
// The below IDs are all indexes into battle message tables,
|
// The below IDs are all indexes into battle message tables,
|
||||||
// used to determine which of a set of messages to print.
|
// used to determine which of a set of messages to print.
|
||||||
|
@ -4937,10 +4937,13 @@ extern const u32 gBattleAnimBgImage_Hurricane[];
|
|||||||
extern const u32 gBattleAnimBgPalette_Hurricane[];
|
extern const u32 gBattleAnimBgPalette_Hurricane[];
|
||||||
extern const u32 gBattleAnimBgTilemap_Hurricane[];
|
extern const u32 gBattleAnimBgTilemap_Hurricane[];
|
||||||
extern const u32 gBattleAnimBgPalette_RockWrecker[];
|
extern const u32 gBattleAnimBgPalette_RockWrecker[];
|
||||||
|
extern const u32 gBattleAnimBgTilemap_GigaImpactPlayer[];
|
||||||
|
extern const u32 gBattleAnimBgTilemap_GigaImpactOpponent[];
|
||||||
|
extern const u32 gBattleAnimBgTilemap_GigaImpactContest[];
|
||||||
|
extern const u32 gBattleAnimBgImage_GigaImpact[];
|
||||||
|
extern const u32 gBattleAnimBgPalette_GigaImpact[];
|
||||||
extern const u32 gBattleAnimBgImage_SpacialRend[];
|
extern const u32 gBattleAnimBgImage_SpacialRend[];
|
||||||
extern const u32 gBattleAnimBgPalette_SpacialRend[];
|
extern const u32 gBattleAnimBgPalette_SpacialRend[];
|
||||||
extern const u32 gBattleAnimBgTilemap_SpacialRendOpponent[];
|
|
||||||
extern const u32 gBattleAnimBgTilemap_SpacialRendPlayer[];
|
|
||||||
extern const u32 gBattleAnimBgPalette_DarkVoid[];
|
extern const u32 gBattleAnimBgPalette_DarkVoid[];
|
||||||
extern const u32 gBattleAnimBgTilemap_DarkVoid[];
|
extern const u32 gBattleAnimBgTilemap_DarkVoid[];
|
||||||
extern const u32 gBattleAnimBgPalette_Dark[];
|
extern const u32 gBattleAnimBgPalette_Dark[];
|
||||||
@ -4960,7 +4963,6 @@ extern const u32 gBattleAnimBgPalette_Fissure[];
|
|||||||
extern const u32 gBattleAnimBgPalette_Bug[];
|
extern const u32 gBattleAnimBgPalette_Bug[];
|
||||||
extern const u32 gBattleAnimBgPalette_Solarbeam[];
|
extern const u32 gBattleAnimBgPalette_Solarbeam[];
|
||||||
extern const u32 gBattleAnimBgPalette_MagmaStorm[];
|
extern const u32 gBattleAnimBgPalette_MagmaStorm[];
|
||||||
extern const u32 gBattleAnimBgPalette_GigaImpact[];
|
|
||||||
extern const u32 gBattleAnimBgPalette_TrickRoom[];
|
extern const u32 gBattleAnimBgPalette_TrickRoom[];
|
||||||
extern const u32 gBattleAnimBgTilemap_Dark[];
|
extern const u32 gBattleAnimBgTilemap_Dark[];
|
||||||
extern const u32 gBattleAnimBgTilemap_Ghost[];
|
extern const u32 gBattleAnimBgTilemap_Ghost[];
|
||||||
|
@ -30,6 +30,8 @@ struct WildPokemonHeader
|
|||||||
};
|
};
|
||||||
|
|
||||||
extern const struct WildPokemonHeader gWildMonHeaders[];
|
extern const struct WildPokemonHeader gWildMonHeaders[];
|
||||||
|
extern bool8 gIsFishingEncounter;
|
||||||
|
extern bool8 gIsSurfingEncounter;
|
||||||
|
|
||||||
void DisableWildEncounters(bool8 disabled);
|
void DisableWildEncounters(bool8 disabled);
|
||||||
bool8 StandardWildEncounter(u16 currMetaTileBehavior, u16 previousMetaTileBehavior);
|
bool8 StandardWildEncounter(u16 currMetaTileBehavior, u16 previousMetaTileBehavior);
|
||||||
|
@ -1473,7 +1473,7 @@ static s16 AI_CheckBadMove(u8 battlerAtk, u8 battlerDef, u16 move, s16 score)
|
|||||||
else if (move == MOVE_FAKE_OUT) // filter out first impression
|
else if (move == MOVE_FAKE_OUT) // filter out first impression
|
||||||
{
|
{
|
||||||
if ((AI_DATA->atkHoldEffect == HOLD_EFFECT_CHOICE_BAND || AI_DATA->atkAbility == ABILITY_GORILLA_TACTICS)
|
if ((AI_DATA->atkHoldEffect == HOLD_EFFECT_CHOICE_BAND || AI_DATA->atkAbility == ABILITY_GORILLA_TACTICS)
|
||||||
&& (CountUsablePartyMons(battlerDef) > 0 || !CanAttackerFaintTarget(battlerAtk, battlerDef, AI_THINKING_STRUCT->movesetIndex, 0)))
|
&& (CountUsablePartyMons(battlerDef) > 0 || !CanIndexMoveFaintTarget(battlerAtk, battlerDef, AI_THINKING_STRUCT->movesetIndex, 0)))
|
||||||
{
|
{
|
||||||
if (CountUsablePartyMons(battlerAtk) == 0)
|
if (CountUsablePartyMons(battlerAtk) == 0)
|
||||||
score -= 10; // Don't lock the attacker into Fake Out if they can't switch out afterwards.
|
score -= 10; // Don't lock the attacker into Fake Out if they can't switch out afterwards.
|
||||||
@ -1714,7 +1714,7 @@ static s16 AI_CheckBadMove(u8 battlerAtk, u8 battlerDef, u16 move, s16 score)
|
|||||||
if (AI_DATA->defAbility == ABILITY_WONDER_GUARD && effectiveness < AI_EFFECTIVENESS_x2)
|
if (AI_DATA->defAbility == ABILITY_WONDER_GUARD && effectiveness < AI_EFFECTIVENESS_x2)
|
||||||
score -= 10;
|
score -= 10;
|
||||||
else if (AI_DATA->atkAbility != ABILITY_TRUANT
|
else if (AI_DATA->atkAbility != ABILITY_TRUANT
|
||||||
&& !CanAttackerFaintTarget(battlerAtk, battlerDef, AI_THINKING_STRUCT->movesetIndex, 0))
|
&& !CanIndexMoveFaintTarget(battlerAtk, battlerDef, AI_THINKING_STRUCT->movesetIndex, 0))
|
||||||
score -= 2;
|
score -= 2;
|
||||||
break;
|
break;
|
||||||
case EFFECT_SPITE:
|
case EFFECT_SPITE:
|
||||||
@ -2465,7 +2465,7 @@ static s16 AI_TryToFaint(u8 battlerAtk, u8 battlerDef, u16 move, s16 score)
|
|||||||
if (gBattleMoves[move].power == 0)
|
if (gBattleMoves[move].power == 0)
|
||||||
return score; // can't make anything faint with no power
|
return score; // can't make anything faint with no power
|
||||||
|
|
||||||
if (CanAttackerFaintTarget(battlerAtk, battlerDef, AI_THINKING_STRUCT->movesetIndex, 0) && gBattleMoves[move].effect != EFFECT_EXPLOSION)
|
if (CanIndexMoveFaintTarget(battlerAtk, battlerDef, AI_THINKING_STRUCT->movesetIndex, 0) && gBattleMoves[move].effect != EFFECT_EXPLOSION)
|
||||||
{
|
{
|
||||||
// this move can faint the target
|
// this move can faint the target
|
||||||
if (GetWhoStrikesFirst(battlerAtk, battlerDef, TRUE) == 0 || GetMovePriority(battlerAtk, move) > 0)
|
if (GetWhoStrikesFirst(battlerAtk, battlerDef, TRUE) == 0 || GetMovePriority(battlerAtk, move) > 0)
|
||||||
@ -2707,7 +2707,7 @@ static s16 AI_DoubleBattle(u8 battlerAtk, u8 battlerDef, u16 move, s16 score)
|
|||||||
&& !IS_MOVE_STATUS(move)
|
&& !IS_MOVE_STATUS(move)
|
||||||
&& HasMoveWithSplit(battlerAtkPartner, SPLIT_PHYSICAL)
|
&& HasMoveWithSplit(battlerAtkPartner, SPLIT_PHYSICAL)
|
||||||
&& BattlerStatCanRise(battlerAtkPartner, atkPartnerAbility, STAT_ATK)
|
&& BattlerStatCanRise(battlerAtkPartner, atkPartnerAbility, STAT_ATK)
|
||||||
&& !CanAttackerFaintTarget(battlerAtk, battlerAtkPartner, AI_THINKING_STRUCT->movesetIndex, 1))
|
&& !CanIndexMoveFaintTarget(battlerAtk, battlerAtkPartner, AI_THINKING_STRUCT->movesetIndex, 1))
|
||||||
{
|
{
|
||||||
RETURN_SCORE_PLUS(1);
|
RETURN_SCORE_PLUS(1);
|
||||||
}
|
}
|
||||||
@ -2716,7 +2716,7 @@ static s16 AI_DoubleBattle(u8 battlerAtk, u8 battlerDef, u16 move, s16 score)
|
|||||||
if (!IS_MOVE_STATUS(move)
|
if (!IS_MOVE_STATUS(move)
|
||||||
&& (moveType == TYPE_DARK || moveType == TYPE_GHOST || moveType == TYPE_BUG)
|
&& (moveType == TYPE_DARK || moveType == TYPE_GHOST || moveType == TYPE_BUG)
|
||||||
&& BattlerStatCanRise(battlerAtkPartner, atkPartnerAbility, STAT_SPEED)
|
&& BattlerStatCanRise(battlerAtkPartner, atkPartnerAbility, STAT_SPEED)
|
||||||
&& !CanAttackerFaintTarget(battlerAtk, battlerAtkPartner, AI_THINKING_STRUCT->movesetIndex, 1))
|
&& !CanIndexMoveFaintTarget(battlerAtk, battlerAtkPartner, AI_THINKING_STRUCT->movesetIndex, 1))
|
||||||
{
|
{
|
||||||
RETURN_SCORE_PLUS(1);
|
RETURN_SCORE_PLUS(1);
|
||||||
}
|
}
|
||||||
@ -2782,7 +2782,7 @@ static s16 AI_DoubleBattle(u8 battlerAtk, u8 battlerDef, u16 move, s16 score)
|
|||||||
&& !IS_MOVE_STATUS(move)
|
&& !IS_MOVE_STATUS(move)
|
||||||
&& HasMoveWithSplit(battlerAtkPartner, SPLIT_PHYSICAL)
|
&& HasMoveWithSplit(battlerAtkPartner, SPLIT_PHYSICAL)
|
||||||
&& BattlerStatCanRise(battlerAtkPartner, atkPartnerAbility, STAT_ATK)
|
&& BattlerStatCanRise(battlerAtkPartner, atkPartnerAbility, STAT_ATK)
|
||||||
&& !CanAttackerFaintTarget(battlerAtk, battlerAtkPartner, AI_THINKING_STRUCT->movesetIndex, 0))
|
&& !CanIndexMoveFaintTarget(battlerAtk, battlerAtkPartner, AI_THINKING_STRUCT->movesetIndex, 0))
|
||||||
{
|
{
|
||||||
RETURN_SCORE_PLUS(1);
|
RETURN_SCORE_PLUS(1);
|
||||||
}
|
}
|
||||||
@ -2971,7 +2971,7 @@ static s16 AI_CheckViability(u8 battlerAtk, u8 battlerDef, u16 move, s16 score)
|
|||||||
case ABILITY_BEAST_BOOST:
|
case ABILITY_BEAST_BOOST:
|
||||||
if (GetWhoStrikesFirst(battlerAtk, battlerDef, TRUE) == 0) // attacker should go first
|
if (GetWhoStrikesFirst(battlerAtk, battlerDef, TRUE) == 0) // attacker should go first
|
||||||
{
|
{
|
||||||
if (CanAttackerFaintTarget(battlerAtk, battlerDef, AI_THINKING_STRUCT->movesetIndex, 0))
|
if (CanIndexMoveFaintTarget(battlerAtk, battlerDef, AI_THINKING_STRUCT->movesetIndex, 0))
|
||||||
score += 8; // prioritize killing target for stat boost
|
score += 8; // prioritize killing target for stat boost
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@ -3772,7 +3772,7 @@ static s16 AI_CheckViability(u8 battlerAtk, u8 battlerDef, u16 move, s16 score)
|
|||||||
case EFFECT_FELL_STINGER:
|
case EFFECT_FELL_STINGER:
|
||||||
if (gBattleMons[battlerAtk].statStages[STAT_ATK] < MAX_STAT_STAGE
|
if (gBattleMons[battlerAtk].statStages[STAT_ATK] < MAX_STAT_STAGE
|
||||||
&& AI_DATA->atkAbility != ABILITY_CONTRARY
|
&& AI_DATA->atkAbility != ABILITY_CONTRARY
|
||||||
&& CanAttackerFaintTarget(battlerAtk, battlerDef, AI_THINKING_STRUCT->movesetIndex, 0))
|
&& CanIndexMoveFaintTarget(battlerAtk, battlerDef, AI_THINKING_STRUCT->movesetIndex, 0))
|
||||||
{
|
{
|
||||||
if (GetWhoStrikesFirst(battlerAtk, battlerDef, TRUE) == 0) // Attacker goes first
|
if (GetWhoStrikesFirst(battlerAtk, battlerDef, TRUE) == 0) // Attacker goes first
|
||||||
score += 9;
|
score += 9;
|
||||||
@ -4923,7 +4923,7 @@ static s16 AI_HPAware(u8 battlerAtk, u8 battlerDef, u16 move, s16 score)
|
|||||||
}
|
}
|
||||||
|
|
||||||
// consider target HP
|
// consider target HP
|
||||||
if (CanAttackerFaintTarget(battlerAtk, battlerDef, AI_THINKING_STRUCT->movesetIndex, 0))
|
if (CanIndexMoveFaintTarget(battlerAtk, battlerDef, AI_THINKING_STRUCT->movesetIndex, 0))
|
||||||
{
|
{
|
||||||
score += 2;
|
score += 2;
|
||||||
}
|
}
|
||||||
|
@ -660,9 +660,9 @@ bool32 MovesWithSplitUnusable(u32 attacker, u32 target, u32 split)
|
|||||||
for (i = 0; i < MAX_MON_MOVES; i++)
|
for (i = 0; i < MAX_MON_MOVES; i++)
|
||||||
{
|
{
|
||||||
if (moves[i] != MOVE_NONE
|
if (moves[i] != MOVE_NONE
|
||||||
&& moves[i] != 0xFFFF
|
&& moves[i] != 0xFFFF
|
||||||
&& GetBattleMoveSplit(moves[i]) == split
|
&& GetBattleMoveSplit(moves[i]) == split
|
||||||
&& !(unusable & gBitTable[i]))
|
&& !(unusable & gBitTable[i]))
|
||||||
{
|
{
|
||||||
SetTypeBeforeUsingMove(moves[i], attacker);
|
SetTypeBeforeUsingMove(moves[i], attacker);
|
||||||
GET_MOVE_TYPE(moves[i], moveType);
|
GET_MOVE_TYPE(moves[i], moveType);
|
||||||
@ -1033,7 +1033,7 @@ bool32 IsAiFaster(u8 battler)
|
|||||||
bool32 CanTargetFaintAi(u8 battlerDef, u8 battlerAtk)
|
bool32 CanTargetFaintAi(u8 battlerDef, u8 battlerAtk)
|
||||||
{
|
{
|
||||||
s32 i, dmg;
|
s32 i, dmg;
|
||||||
u32 unusable = CheckMoveLimitations(battlerDef, 0, 0xFF & ~MOVE_LIMITATION_PP);
|
u32 unusable = CheckMoveLimitations(battlerDef, 0, 0xFF);
|
||||||
u16 *moves = gBattleResources->battleHistory->usedMoves[battlerDef];
|
u16 *moves = gBattleResources->battleHistory->usedMoves[battlerDef];
|
||||||
|
|
||||||
for (i = 0; i < MAX_MON_MOVES; i++)
|
for (i = 0; i < MAX_MON_MOVES; i++)
|
||||||
@ -1048,10 +1048,36 @@ bool32 CanTargetFaintAi(u8 battlerDef, u8 battlerAtk)
|
|||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Check if AI mon has the means to faint the target with any of its moves.
|
||||||
|
// If numHits > 1, check if the target will be KO'ed by that number of hits (ignoring healing effects)
|
||||||
|
bool32 CanAIFaintTarget(u8 battlerAtk, u8 battlerDef, u8 numHits)
|
||||||
|
{
|
||||||
|
s32 i, dmg;
|
||||||
|
u32 moveLimitations = CheckMoveLimitations(battlerAtk, 0, 0xFF);
|
||||||
|
u16 *moves = gBattleMons[battlerAtk].moves;
|
||||||
|
|
||||||
|
for (i = 0; i < MAX_MON_MOVES; i++)
|
||||||
|
{
|
||||||
|
if (moves[i] != MOVE_NONE && moves[i] != 0xFFFF && !(moveLimitations & gBitTable[i]))
|
||||||
|
{
|
||||||
|
// Use the pre-calculated value in simulatedDmg instead of re-calculating it
|
||||||
|
dmg = AI_THINKING_STRUCT->simulatedDmg[battlerAtk][battlerDef][i];
|
||||||
|
|
||||||
|
if (numHits)
|
||||||
|
dmg *= numHits;
|
||||||
|
|
||||||
|
if (gBattleMons[battlerDef].hp <= dmg)
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
bool32 CanMoveFaintBattler(u16 move, u8 battlerDef, u8 battlerAtk, u8 nHits)
|
bool32 CanMoveFaintBattler(u16 move, u8 battlerDef, u8 battlerAtk, u8 nHits)
|
||||||
{
|
{
|
||||||
s32 i, dmg;
|
s32 i, dmg;
|
||||||
u32 unusable = CheckMoveLimitations(battlerDef, 0, 0xFF & ~MOVE_LIMITATION_PP);
|
u32 unusable = CheckMoveLimitations(battlerDef, 0, 0xFF);
|
||||||
|
|
||||||
if (move != MOVE_NONE && move != 0xFFFF && !(unusable & gBitTable[i]) && AI_CalcDamage(move, battlerDef, battlerAtk) >= gBattleMons[battlerAtk].hp)
|
if (move != MOVE_NONE && move != 0xFFFF && !(unusable & gBitTable[i]) && AI_CalcDamage(move, battlerDef, battlerAtk) >= gBattleMons[battlerAtk].hp)
|
||||||
return TRUE;
|
return TRUE;
|
||||||
@ -1063,7 +1089,7 @@ bool32 CanMoveFaintBattler(u16 move, u8 battlerDef, u8 battlerAtk, u8 nHits)
|
|||||||
bool32 CanTargetFaintAiWithMod(u8 battlerDef, u8 battlerAtk, s32 hpMod, s32 dmgMod)
|
bool32 CanTargetFaintAiWithMod(u8 battlerDef, u8 battlerAtk, s32 hpMod, s32 dmgMod)
|
||||||
{
|
{
|
||||||
u32 i;
|
u32 i;
|
||||||
u32 unusable = CheckMoveLimitations(battlerDef, 0, 0xFF & ~MOVE_LIMITATION_PP);
|
u32 unusable = CheckMoveLimitations(battlerDef, 0, 0xFF);
|
||||||
u16 *moves = gBattleResources->battleHistory->usedMoves[battlerDef];
|
u16 *moves = gBattleResources->battleHistory->usedMoves[battlerDef];
|
||||||
|
|
||||||
for (i = 0; i < MAX_MON_MOVES; i++)
|
for (i = 0; i < MAX_MON_MOVES; i++)
|
||||||
@ -1683,7 +1709,7 @@ u32 CountNegativeStatStages(u8 battlerId)
|
|||||||
|
|
||||||
bool32 ShouldLowerAttack(u8 battlerAtk, u8 battlerDef, u16 defAbility)
|
bool32 ShouldLowerAttack(u8 battlerAtk, u8 battlerDef, u16 defAbility)
|
||||||
{
|
{
|
||||||
if (IsAiFaster(AI_CHECK_FASTER) && CanAttackerFaintTarget(battlerAtk, battlerDef, AI_THINKING_STRUCT->movesetIndex, 0))
|
if (IsAiFaster(AI_CHECK_FASTER) && CanAIFaintTarget(battlerAtk, battlerDef, 0))
|
||||||
return FALSE; // Don't bother lowering stats if can kill enemy.
|
return FALSE; // Don't bother lowering stats if can kill enemy.
|
||||||
|
|
||||||
if (gBattleMons[battlerDef].statStages[STAT_ATK] > 4
|
if (gBattleMons[battlerDef].statStages[STAT_ATK] > 4
|
||||||
@ -1691,7 +1717,7 @@ bool32 ShouldLowerAttack(u8 battlerAtk, u8 battlerDef, u16 defAbility)
|
|||||||
&& defAbility != ABILITY_CONTRARY
|
&& defAbility != ABILITY_CONTRARY
|
||||||
&& defAbility != ABILITY_CLEAR_BODY
|
&& defAbility != ABILITY_CLEAR_BODY
|
||||||
&& defAbility != ABILITY_WHITE_SMOKE
|
&& defAbility != ABILITY_WHITE_SMOKE
|
||||||
//&& defAbility != ABILITY_FULL_METAL_BODY
|
&& defAbility != ABILITY_FULL_METAL_BODY
|
||||||
&& defAbility != ABILITY_HYPER_CUTTER)
|
&& defAbility != ABILITY_HYPER_CUTTER)
|
||||||
return TRUE;
|
return TRUE;
|
||||||
return FALSE;
|
return FALSE;
|
||||||
@ -1699,7 +1725,7 @@ bool32 ShouldLowerAttack(u8 battlerAtk, u8 battlerDef, u16 defAbility)
|
|||||||
|
|
||||||
bool32 ShouldLowerDefense(u8 battlerAtk, u8 battlerDef, u16 defAbility)
|
bool32 ShouldLowerDefense(u8 battlerAtk, u8 battlerDef, u16 defAbility)
|
||||||
{
|
{
|
||||||
if (IsAiFaster(AI_CHECK_FASTER) && CanAttackerFaintTarget(battlerAtk, battlerDef, AI_THINKING_STRUCT->movesetIndex, 0))
|
if (IsAiFaster(AI_CHECK_FASTER) && CanAIFaintTarget(battlerAtk, battlerDef, 0))
|
||||||
return FALSE; // Don't bother lowering stats if can kill enemy.
|
return FALSE; // Don't bother lowering stats if can kill enemy.
|
||||||
|
|
||||||
if (gBattleMons[battlerDef].statStages[STAT_DEF] > 4
|
if (gBattleMons[battlerDef].statStages[STAT_DEF] > 4
|
||||||
@ -1707,7 +1733,7 @@ bool32 ShouldLowerDefense(u8 battlerAtk, u8 battlerDef, u16 defAbility)
|
|||||||
&& defAbility != ABILITY_CONTRARY
|
&& defAbility != ABILITY_CONTRARY
|
||||||
&& defAbility != ABILITY_CLEAR_BODY
|
&& defAbility != ABILITY_CLEAR_BODY
|
||||||
&& defAbility != ABILITY_WHITE_SMOKE
|
&& defAbility != ABILITY_WHITE_SMOKE
|
||||||
//&& defAbility != ABILITY_FULL_METAL_BODY
|
&& defAbility != ABILITY_FULL_METAL_BODY
|
||||||
&& defAbility != ABILITY_BIG_PECKS)
|
&& defAbility != ABILITY_BIG_PECKS)
|
||||||
return TRUE;
|
return TRUE;
|
||||||
return FALSE;
|
return FALSE;
|
||||||
@ -1715,13 +1741,13 @@ bool32 ShouldLowerDefense(u8 battlerAtk, u8 battlerDef, u16 defAbility)
|
|||||||
|
|
||||||
bool32 ShouldLowerSpeed(u8 battlerAtk, u8 battlerDef, u16 defAbility)
|
bool32 ShouldLowerSpeed(u8 battlerAtk, u8 battlerDef, u16 defAbility)
|
||||||
{
|
{
|
||||||
if (IsAiFaster(AI_CHECK_FASTER) && CanAttackerFaintTarget(battlerAtk, battlerDef, AI_THINKING_STRUCT->movesetIndex, 0))
|
if (IsAiFaster(AI_CHECK_FASTER) && CanAIFaintTarget(battlerAtk, battlerDef, 0))
|
||||||
return FALSE; // Don't bother lowering stats if can kill enemy.
|
return FALSE; // Don't bother lowering stats if can kill enemy.
|
||||||
|
|
||||||
if (IsAiFaster(AI_CHECK_SLOWER)
|
if (IsAiFaster(AI_CHECK_SLOWER)
|
||||||
&& defAbility != ABILITY_CONTRARY
|
&& defAbility != ABILITY_CONTRARY
|
||||||
&& defAbility != ABILITY_CLEAR_BODY
|
&& defAbility != ABILITY_CLEAR_BODY
|
||||||
//&& defAbility != ABILITY_FULL_METAL_BODY
|
&& defAbility != ABILITY_FULL_METAL_BODY
|
||||||
&& defAbility != ABILITY_WHITE_SMOKE)
|
&& defAbility != ABILITY_WHITE_SMOKE)
|
||||||
return TRUE;
|
return TRUE;
|
||||||
return FALSE;
|
return FALSE;
|
||||||
@ -1729,14 +1755,14 @@ bool32 ShouldLowerSpeed(u8 battlerAtk, u8 battlerDef, u16 defAbility)
|
|||||||
|
|
||||||
bool32 ShouldLowerSpAtk(u8 battlerAtk, u8 battlerDef, u16 defAbility)
|
bool32 ShouldLowerSpAtk(u8 battlerAtk, u8 battlerDef, u16 defAbility)
|
||||||
{
|
{
|
||||||
if (IsAiFaster(AI_CHECK_FASTER) && CanAttackerFaintTarget(battlerAtk, battlerDef, AI_THINKING_STRUCT->movesetIndex, 0))
|
if (IsAiFaster(AI_CHECK_FASTER) && CanAIFaintTarget(battlerAtk, battlerDef, 0))
|
||||||
return FALSE; // Don't bother lowering stats if can kill enemy.
|
return FALSE; // Don't bother lowering stats if can kill enemy.
|
||||||
|
|
||||||
if (gBattleMons[battlerDef].statStages[STAT_SPATK] > 4
|
if (gBattleMons[battlerDef].statStages[STAT_SPATK] > 4
|
||||||
&& HasMoveWithSplit(battlerDef, SPLIT_SPECIAL)
|
&& HasMoveWithSplit(battlerDef, SPLIT_SPECIAL)
|
||||||
&& defAbility != ABILITY_CONTRARY
|
&& defAbility != ABILITY_CONTRARY
|
||||||
&& defAbility != ABILITY_CLEAR_BODY
|
&& defAbility != ABILITY_CLEAR_BODY
|
||||||
//&& defAbility != ABILITY_FULL_METAL_BODY
|
&& defAbility != ABILITY_FULL_METAL_BODY
|
||||||
&& defAbility != ABILITY_WHITE_SMOKE)
|
&& defAbility != ABILITY_WHITE_SMOKE)
|
||||||
return TRUE;
|
return TRUE;
|
||||||
return FALSE;
|
return FALSE;
|
||||||
@ -1744,14 +1770,14 @@ bool32 ShouldLowerSpAtk(u8 battlerAtk, u8 battlerDef, u16 defAbility)
|
|||||||
|
|
||||||
bool32 ShouldLowerSpDef(u8 battlerAtk, u8 battlerDef, u16 defAbility)
|
bool32 ShouldLowerSpDef(u8 battlerAtk, u8 battlerDef, u16 defAbility)
|
||||||
{
|
{
|
||||||
if (IsAiFaster(AI_CHECK_FASTER) && CanAttackerFaintTarget(battlerAtk, battlerDef, AI_THINKING_STRUCT->movesetIndex, 0))
|
if (IsAiFaster(AI_CHECK_FASTER) && CanAIFaintTarget(battlerAtk, battlerDef, 0))
|
||||||
return FALSE; // Don't bother lowering stats if can kill enemy.
|
return FALSE; // Don't bother lowering stats if can kill enemy.
|
||||||
|
|
||||||
if (gBattleMons[battlerDef].statStages[STAT_SPDEF] > 4
|
if (gBattleMons[battlerDef].statStages[STAT_SPDEF] > 4
|
||||||
&& HasMoveWithSplit(battlerAtk, SPLIT_SPECIAL)
|
&& HasMoveWithSplit(battlerAtk, SPLIT_SPECIAL)
|
||||||
&& defAbility != ABILITY_CONTRARY
|
&& defAbility != ABILITY_CONTRARY
|
||||||
&& defAbility != ABILITY_CLEAR_BODY
|
&& defAbility != ABILITY_CLEAR_BODY
|
||||||
//&& defAbility != ABILITY_FULL_METAL_BODY
|
&& defAbility != ABILITY_FULL_METAL_BODY
|
||||||
&& defAbility != ABILITY_WHITE_SMOKE)
|
&& defAbility != ABILITY_WHITE_SMOKE)
|
||||||
return TRUE;
|
return TRUE;
|
||||||
return FALSE;
|
return FALSE;
|
||||||
@ -1759,13 +1785,13 @@ bool32 ShouldLowerSpDef(u8 battlerAtk, u8 battlerDef, u16 defAbility)
|
|||||||
|
|
||||||
bool32 ShouldLowerAccuracy(u8 battlerAtk, u8 battlerDef, u16 defAbility)
|
bool32 ShouldLowerAccuracy(u8 battlerAtk, u8 battlerDef, u16 defAbility)
|
||||||
{
|
{
|
||||||
if (IsAiFaster(AI_CHECK_FASTER) && CanAttackerFaintTarget(battlerAtk, battlerDef, AI_THINKING_STRUCT->movesetIndex, 0))
|
if (IsAiFaster(AI_CHECK_FASTER) && CanAIFaintTarget(battlerAtk, battlerDef, 0))
|
||||||
return FALSE; // Don't bother lowering stats if can kill enemy.
|
return FALSE; // Don't bother lowering stats if can kill enemy.
|
||||||
|
|
||||||
if (defAbility != ABILITY_CONTRARY
|
if (defAbility != ABILITY_CONTRARY
|
||||||
&& defAbility != ABILITY_CLEAR_BODY
|
&& defAbility != ABILITY_CLEAR_BODY
|
||||||
&& defAbility != ABILITY_WHITE_SMOKE
|
&& defAbility != ABILITY_WHITE_SMOKE
|
||||||
//&& defAbility != ABILITY_FULL_METAL_BODY
|
&& defAbility != ABILITY_FULL_METAL_BODY
|
||||||
&& defAbility != ABILITY_KEEN_EYE)
|
&& defAbility != ABILITY_KEEN_EYE)
|
||||||
return TRUE;
|
return TRUE;
|
||||||
return FALSE;
|
return FALSE;
|
||||||
@ -1773,19 +1799,19 @@ bool32 ShouldLowerAccuracy(u8 battlerAtk, u8 battlerDef, u16 defAbility)
|
|||||||
|
|
||||||
bool32 ShouldLowerEvasion(u8 battlerAtk, u8 battlerDef, u16 defAbility)
|
bool32 ShouldLowerEvasion(u8 battlerAtk, u8 battlerDef, u16 defAbility)
|
||||||
{
|
{
|
||||||
if (IsAiFaster(AI_CHECK_FASTER) && CanAttackerFaintTarget(battlerAtk, battlerDef, AI_THINKING_STRUCT->movesetIndex, 0))
|
if (IsAiFaster(AI_CHECK_FASTER) && CanAIFaintTarget(battlerAtk, battlerDef, 0))
|
||||||
return FALSE; // Don't bother lowering stats if can kill enemy.
|
return FALSE; // Don't bother lowering stats if can kill enemy.
|
||||||
|
|
||||||
if (gBattleMons[battlerDef].statStages[STAT_EVASION] > DEFAULT_STAT_STAGE
|
if (gBattleMons[battlerDef].statStages[STAT_EVASION] > DEFAULT_STAT_STAGE
|
||||||
&& defAbility != ABILITY_CONTRARY
|
&& defAbility != ABILITY_CONTRARY
|
||||||
&& defAbility != ABILITY_CLEAR_BODY
|
&& defAbility != ABILITY_CLEAR_BODY
|
||||||
//&& defAbility != ABILITY_FULL_METAL_BODY
|
&& defAbility != ABILITY_FULL_METAL_BODY
|
||||||
&& defAbility != ABILITY_WHITE_SMOKE)
|
&& defAbility != ABILITY_WHITE_SMOKE)
|
||||||
return TRUE;
|
return TRUE;
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool32 CanAttackerFaintTarget(u8 battlerAtk, u8 battlerDef, u8 index, u8 numHits)
|
bool32 CanIndexMoveFaintTarget(u8 battlerAtk, u8 battlerDef, u8 index, u8 numHits)
|
||||||
{
|
{
|
||||||
s32 dmg = AI_THINKING_STRUCT->simulatedDmg[battlerAtk][battlerDef][index];
|
s32 dmg = AI_THINKING_STRUCT->simulatedDmg[battlerAtk][battlerDef][index];
|
||||||
|
|
||||||
@ -2439,9 +2465,9 @@ bool32 ShouldPivot(u8 battlerAtk, u8 battlerDef, u16 defAbility, u16 move, u8 mo
|
|||||||
|
|
||||||
if (GetWhoStrikesFirst(battlerAtk, battlerDef, TRUE) == 0) // Attacker goes first
|
if (GetWhoStrikesFirst(battlerAtk, battlerDef, TRUE) == 0) // Attacker goes first
|
||||||
{
|
{
|
||||||
if (!CanAttackerFaintTarget(battlerAtk, battlerDef, moveIndex, 0)) // Can't KO foe otherwise
|
if (!CanAIFaintTarget(battlerAtk, battlerDef, 0)) // Can't KO foe otherwise
|
||||||
{
|
{
|
||||||
if (CanAttackerFaintTarget(battlerAtk, battlerDef, moveIndex, 2))
|
if (CanAIFaintTarget(battlerAtk, battlerDef, 2))
|
||||||
{
|
{
|
||||||
// attacker can kill target in two hits (theoretically)
|
// attacker can kill target in two hits (theoretically)
|
||||||
if (CanTargetFaintAi(battlerDef, battlerAtk))
|
if (CanTargetFaintAi(battlerDef, battlerAtk))
|
||||||
@ -2506,7 +2532,7 @@ bool32 ShouldPivot(u8 battlerAtk, u8 battlerDef, u16 defAbility, u16 move, u8 mo
|
|||||||
}
|
}
|
||||||
else if (CanTargetFaintAiWithMod(battlerDef, battlerAtk, 0, 2)) // Foe can 2HKO AI
|
else if (CanTargetFaintAiWithMod(battlerDef, battlerAtk, 0, 2)) // Foe can 2HKO AI
|
||||||
{
|
{
|
||||||
if (CanAttackerFaintTarget(battlerAtk, battlerDef, moveIndex, 0))
|
if (CanAIFaintTarget(battlerAtk, battlerDef, 0))
|
||||||
{
|
{
|
||||||
if (!BattlerWillFaintFromSecondaryDamage(battlerAtk, AI_DATA->atkAbility))
|
if (!BattlerWillFaintFromSecondaryDamage(battlerAtk, AI_DATA->atkAbility))
|
||||||
return CAN_TRY_PIVOT; // Use this move to KO if you must
|
return CAN_TRY_PIVOT; // Use this move to KO if you must
|
||||||
@ -2518,7 +2544,7 @@ bool32 ShouldPivot(u8 battlerAtk, u8 battlerDef, u16 defAbility, u16 move, u8 mo
|
|||||||
}
|
}
|
||||||
else // Foe can 3HKO+ AI
|
else // Foe can 3HKO+ AI
|
||||||
{
|
{
|
||||||
if (CanAttackerFaintTarget(battlerAtk, battlerDef, moveIndex, 0))
|
if (CanAIFaintTarget(battlerAtk, battlerDef, 0))
|
||||||
{
|
{
|
||||||
if (!BattlerWillFaintFromSecondaryDamage(battlerAtk, AI_DATA->atkAbility) // This is the only move that can KO
|
if (!BattlerWillFaintFromSecondaryDamage(battlerAtk, AI_DATA->atkAbility) // This is the only move that can KO
|
||||||
&& !hasStatBoost) //You're not wasting a valuable stat boost
|
&& !hasStatBoost) //You're not wasting a valuable stat boost
|
||||||
@ -2526,7 +2552,7 @@ bool32 ShouldPivot(u8 battlerAtk, u8 battlerDef, u16 defAbility, u16 move, u8 mo
|
|||||||
return CAN_TRY_PIVOT;
|
return CAN_TRY_PIVOT;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (CanAttackerFaintTarget(battlerAtk, battlerDef, moveIndex, 2))
|
else if (CanAIFaintTarget(battlerAtk, battlerDef, 2))
|
||||||
{
|
{
|
||||||
// can knock out foe in 2 hits
|
// can knock out foe in 2 hits
|
||||||
if (IS_MOVE_STATUS(move) && (shouldSwitch //Damaging move
|
if (IS_MOVE_STATUS(move) && (shouldSwitch //Damaging move
|
||||||
@ -2910,7 +2936,7 @@ bool32 ShouldUseRecoilMove(u8 battlerAtk, u8 battlerDef, u32 recoilDmg, u8 moveI
|
|||||||
if (recoilDmg >= gBattleMons[battlerAtk].hp //Recoil kills attacker
|
if (recoilDmg >= gBattleMons[battlerAtk].hp //Recoil kills attacker
|
||||||
&& CountUsablePartyMons(battlerDef) != 0) //Foe has more than 1 target left
|
&& CountUsablePartyMons(battlerDef) != 0) //Foe has more than 1 target left
|
||||||
{
|
{
|
||||||
if (recoilDmg >= gBattleMons[battlerDef].hp && !CanAttackerFaintTarget(battlerAtk, battlerDef, moveIndex, 0))
|
if (recoilDmg >= gBattleMons[battlerDef].hp && !CanAIFaintTarget(battlerAtk, battlerDef, 0))
|
||||||
return TRUE; //If it's the only KO move then just use it
|
return TRUE; //If it's the only KO move then just use it
|
||||||
else
|
else
|
||||||
return FALSE; //Not as good to use move if you'll faint and not win
|
return FALSE; //Not as good to use move if you'll faint and not win
|
||||||
|
@ -2052,13 +2052,13 @@ const struct BattleAnimBackground gBattleAnimBackgroundTable[] =
|
|||||||
[BG_SOLARBEAM_CONTESTS] = {gBattleAnimBgImage_Impact, gBattleAnimBgPalette_Solarbeam, gBattleAnimBgTilemap_ImpactContests},
|
[BG_SOLARBEAM_CONTESTS] = {gBattleAnimBgImage_Impact, gBattleAnimBgPalette_Solarbeam, gBattleAnimBgTilemap_ImpactContests},
|
||||||
//new bgs
|
//new bgs
|
||||||
[BG_MAGMA_STORM] = {gBattleAnimBgImage_InAir, gBattleAnimBgPalette_MagmaStorm, gBattleAnimBgTilemap_InAir},
|
[BG_MAGMA_STORM] = {gBattleAnimBgImage_InAir, gBattleAnimBgPalette_MagmaStorm, gBattleAnimBgTilemap_InAir},
|
||||||
[BG_GIGA_IMPACT_OPPONENT] = {gBattleAnimBgImage_Impact, gBattleAnimBgPalette_GigaImpact, gBattleAnimBgTilemap_ImpactOpponent},
|
[BG_GIGA_IMPACT_OPPONENT] = {gBattleAnimBgImage_GigaImpact, gBattleAnimBgPalette_GigaImpact, gBattleAnimBgTilemap_GigaImpactOpponent},
|
||||||
[BG_GIGA_IMPACT_PLAYER] = {gBattleAnimBgImage_Impact, gBattleAnimBgPalette_GigaImpact, gBattleAnimBgTilemap_ImpactPlayer},
|
[BG_GIGA_IMPACT_PLAYER] = {gBattleAnimBgImage_GigaImpact, gBattleAnimBgPalette_GigaImpact, gBattleAnimBgTilemap_GigaImpactPlayer},
|
||||||
[BG_GIGA_IMPACT_CONTEST] = {gBattleAnimBgImage_Impact, gBattleAnimBgPalette_GigaImpact, gBattleAnimBgTilemap_ImpactContests},
|
[BG_GIGA_IMPACT_CONTEST] = {gBattleAnimBgImage_GigaImpact, gBattleAnimBgPalette_GigaImpact, gBattleAnimBgTilemap_GigaImpactContest},
|
||||||
[BG_TRICK_ROOM] = {gBattleAnimBgImage_TrickRoom, gBattleAnimBgPalette_TrickRoom, gBattleAnimBgTilemap_TrickRoom},
|
[BG_TRICK_ROOM] = {gBattleAnimBgImage_TrickRoom, gBattleAnimBgPalette_TrickRoom, gBattleAnimBgTilemap_TrickRoom},
|
||||||
[BG_ROCK_WRECKER] = {gBattleAnimBgImage_Hurricane, gBattleAnimBgPalette_RockWrecker, gBattleAnimBgTilemap_Hurricane},
|
[BG_ROCK_WRECKER] = {gBattleAnimBgImage_Hurricane, gBattleAnimBgPalette_RockWrecker, gBattleAnimBgTilemap_Hurricane},
|
||||||
[BG_SPACIAL_REND_ON_OPPONENT] = {gBattleAnimBgImage_SpacialRend, gBattleAnimBgPalette_SpacialRend, gBattleAnimBgTilemap_SpacialRendOpponent},
|
[BG_SPACIAL_REND_ON_OPPONENT] = {gBattleAnimBgImage_SpacialRend, gBattleAnimBgPalette_SpacialRend, gBattleAnimBgTilemap_GigaImpactOpponent},
|
||||||
[BG_SPACIAL_REND_ON_PLAYER] = {gBattleAnimBgImage_SpacialRend, gBattleAnimBgPalette_SpacialRend, gBattleAnimBgTilemap_SpacialRendPlayer},
|
[BG_SPACIAL_REND_ON_PLAYER] = {gBattleAnimBgImage_SpacialRend, gBattleAnimBgPalette_SpacialRend, gBattleAnimBgTilemap_GigaImpactPlayer},
|
||||||
[BG_DARK_VOID] = {gBattleAnimBgImage_Waterfall, gBattleAnimBgPalette_DarkVoid, gBattleAnimBgTilemap_DarkVoid},
|
[BG_DARK_VOID] = {gBattleAnimBgImage_Waterfall, gBattleAnimBgPalette_DarkVoid, gBattleAnimBgTilemap_DarkVoid},
|
||||||
[BG_WATER] = {gBattleAnimBgImage_HydroPump, gBattleAnimBgPalette_HydroPump, gBattleAnimBgTilemap_HydroPump},
|
[BG_WATER] = {gBattleAnimBgImage_HydroPump, gBattleAnimBgPalette_HydroPump, gBattleAnimBgTilemap_HydroPump},
|
||||||
[BG_NIGHTMARE] = {gBattleAnimBgImage_Nightmare, gBattleAnimBgPalette_Nightmare, gBattleAnimBgTilemap_Nightmare},
|
[BG_NIGHTMARE] = {gBattleAnimBgImage_Nightmare, gBattleAnimBgPalette_Nightmare, gBattleAnimBgTilemap_Nightmare},
|
||||||
|
@ -5073,3 +5073,25 @@ void AnimTask_ShellSideArm(u8 taskId)
|
|||||||
gBattleAnimArgs[0] = FALSE;
|
gBattleAnimArgs[0] = FALSE;
|
||||||
DestroyAnimVisualTask(taskId);
|
DestroyAnimVisualTask(taskId);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void AnimTask_TerrainPulse(u8 taskId)
|
||||||
|
{
|
||||||
|
if (IsBattlerTerrainAffected(gBattleAnimAttacker, STATUS_FIELD_TERRAIN_ANY))
|
||||||
|
{
|
||||||
|
if (gFieldStatuses & STATUS_FIELD_ELECTRIC_TERRAIN)
|
||||||
|
gBattleAnimArgs[0] = TYPE_ELECTRIC;
|
||||||
|
else if (gFieldStatuses & STATUS_FIELD_GRASSY_TERRAIN)
|
||||||
|
gBattleAnimArgs[0] = TYPE_GRASS;
|
||||||
|
else if (gFieldStatuses & STATUS_FIELD_MISTY_TERRAIN)
|
||||||
|
gBattleAnimArgs[0] = TYPE_FAIRY;
|
||||||
|
else if (gFieldStatuses & STATUS_FIELD_PSYCHIC_TERRAIN)
|
||||||
|
gBattleAnimArgs[0] = TYPE_PSYCHIC;
|
||||||
|
else //failsafe
|
||||||
|
gBattleAnimArgs[0] = 0;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
gBattleAnimArgs[0] = 0;
|
||||||
|
}
|
||||||
|
DestroyAnimVisualTask(taskId);
|
||||||
|
}
|
||||||
|
@ -136,6 +136,7 @@ void AnimTask_SetCamouflageBlend(u8 taskId)
|
|||||||
gBattleAnimArgs[4] = RGB(31, 31, 31);
|
gBattleAnimArgs[4] = RGB(31, 31, 31);
|
||||||
break;
|
break;
|
||||||
case BATTLE_TERRAIN_PLAIN:
|
case BATTLE_TERRAIN_PLAIN:
|
||||||
|
default:
|
||||||
gBattleAnimArgs[4] = RGB(31, 31, 31);
|
gBattleAnimArgs[4] = RGB(31, 31, 31);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -904,6 +905,12 @@ void AnimTask_GetBattleTerrain(u8 taskId)
|
|||||||
DestroyAnimVisualTask(taskId);
|
DestroyAnimVisualTask(taskId);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void AnimTask_GetFieldTerrain(u8 taskId)
|
||||||
|
{
|
||||||
|
gBattleAnimArgs[0] = gFieldStatuses & STATUS_FIELD_TERRAIN_ANY;
|
||||||
|
DestroyAnimVisualTask(taskId);
|
||||||
|
}
|
||||||
|
|
||||||
void AnimTask_AllocBackupPalBuffer(u8 taskId)
|
void AnimTask_AllocBackupPalBuffer(u8 taskId)
|
||||||
{
|
{
|
||||||
gMonSpritesGfxPtr->buffer = AllocZeroed(0x2000);
|
gMonSpritesGfxPtr->buffer = AllocZeroed(0x2000);
|
||||||
|
@ -49,6 +49,7 @@
|
|||||||
#include "trig.h"
|
#include "trig.h"
|
||||||
#include "tv.h"
|
#include "tv.h"
|
||||||
#include "util.h"
|
#include "util.h"
|
||||||
|
#include "wild_encounter.h"
|
||||||
#include "window.h"
|
#include "window.h"
|
||||||
#include "constants/abilities.h"
|
#include "constants/abilities.h"
|
||||||
#include "constants/battle_config.h"
|
#include "constants/battle_config.h"
|
||||||
@ -5025,6 +5026,8 @@ static void FreeResetData_ReturnToOvOrDoEvolutions(void)
|
|||||||
{
|
{
|
||||||
if (!gPaletteFade.active)
|
if (!gPaletteFade.active)
|
||||||
{
|
{
|
||||||
|
gIsFishingEncounter = FALSE;
|
||||||
|
gIsSurfingEncounter = FALSE;
|
||||||
ResetSpriteData();
|
ResetSpriteData();
|
||||||
if (gLeveledUpInBattle && (gBattleOutcome == B_OUTCOME_WON || gBattleOutcome == B_OUTCOME_CAUGHT))
|
if (gLeveledUpInBattle && (gBattleOutcome == B_OUTCOME_WON || gBattleOutcome == B_OUTCOME_CAUGHT))
|
||||||
{
|
{
|
||||||
@ -5196,6 +5199,22 @@ void SetTypeBeforeUsingMove(u16 move, u8 battlerAtk)
|
|||||||
if (ItemId_GetPocket(gBattleMons[battlerAtk].item) == POCKET_BERRIES)
|
if (ItemId_GetPocket(gBattleMons[battlerAtk].item) == POCKET_BERRIES)
|
||||||
gBattleStruct->dynamicMoveType = gNaturalGiftTable[ITEM_TO_BERRY(gBattleMons[battlerAtk].item)].type;
|
gBattleStruct->dynamicMoveType = gNaturalGiftTable[ITEM_TO_BERRY(gBattleMons[battlerAtk].item)].type;
|
||||||
}
|
}
|
||||||
|
else if (gBattleMoves[move].effect == EFFECT_TERRAIN_PULSE)
|
||||||
|
{
|
||||||
|
if (IsBattlerTerrainAffected(battlerAtk, STATUS_FIELD_TERRAIN_ANY))
|
||||||
|
{
|
||||||
|
if (gFieldStatuses & STATUS_FIELD_ELECTRIC_TERRAIN)
|
||||||
|
gBattleStruct->dynamicMoveType = TYPE_ELECTRIC | 0x80;
|
||||||
|
else if (gFieldStatuses & STATUS_FIELD_GRASSY_TERRAIN)
|
||||||
|
gBattleStruct->dynamicMoveType = TYPE_GRASS | 0x80;
|
||||||
|
else if (gFieldStatuses & STATUS_FIELD_MISTY_TERRAIN)
|
||||||
|
gBattleStruct->dynamicMoveType = TYPE_FAIRY | 0x80;
|
||||||
|
else if (gFieldStatuses & STATUS_FIELD_PSYCHIC_TERRAIN)
|
||||||
|
gBattleStruct->dynamicMoveType = TYPE_PSYCHIC | 0x80;
|
||||||
|
else //failsafe
|
||||||
|
gBattleStruct->dynamicMoveType = TYPE_NORMAL | 0x80;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
attackerAbility = GetBattlerAbility(battlerAtk);
|
attackerAbility = GetBattlerAbility(battlerAtk);
|
||||||
GET_MOVE_TYPE(move, moveType);
|
GET_MOVE_TYPE(move, moveType);
|
||||||
|
@ -549,7 +549,7 @@ static const u8 sText_BecameNimble[] =_("{B_ATK_NAME_WITH_PREFIX} became nimble!
|
|||||||
static const u8 sText_HurledIntoTheAir[] =_("{B_DEF_NAME_WITH_PREFIX} was hurled\ninto the air!");
|
static const u8 sText_HurledIntoTheAir[] =_("{B_DEF_NAME_WITH_PREFIX} was hurled\ninto the air!");
|
||||||
static const u8 sText_HeldItemsLoseEffects[] =_("It created a bizarre area in which\nPokémon's held items lose their effects!");
|
static const u8 sText_HeldItemsLoseEffects[] =_("It created a bizarre area in which\nPokémon's held items lose their effects!");
|
||||||
static const u8 sText_FellStraightDown[] =_("{B_DEF_NAME_WITH_PREFIX} fell\nstraight down!");
|
static const u8 sText_FellStraightDown[] =_("{B_DEF_NAME_WITH_PREFIX} fell\nstraight down!");
|
||||||
static const u8 sText_TransformedIntoWaterType[] =_("{B_DEF_NAME_WITH_PREFIX} transformed\ninto the water type!");
|
static const u8 sText_TargetChangedType[] =_("{B_DEF_NAME_WITH_PREFIX} transformed\ninto the {B_BUFF1} type!");
|
||||||
static const u8 sText_PkmnAcquiredSimple[] =_("{B_DEF_NAME_WITH_PREFIX} acquired\nSimple!");
|
static const u8 sText_PkmnAcquiredSimple[] =_("{B_DEF_NAME_WITH_PREFIX} acquired\nSimple!");
|
||||||
static const u8 sText_KindOffer[] =_("{B_DEF_NAME_WITH_PREFIX}\ntook the kind offer!");
|
static const u8 sText_KindOffer[] =_("{B_DEF_NAME_WITH_PREFIX}\ntook the kind offer!");
|
||||||
static const u8 sText_ResetsTargetsStatLevels[] =_("{B_DEF_NAME_WITH_PREFIX}'s stat changes\nwere removed!");
|
static const u8 sText_ResetsTargetsStatLevels[] =_("{B_DEF_NAME_WITH_PREFIX}'s stat changes\nwere removed!");
|
||||||
@ -629,7 +629,7 @@ static const u8 sText_TerrainBecomesGrassy[] = _("Grass grew to cover\nthe battl
|
|||||||
static const u8 sText_TerrainBecomesElectric[] = _("An electric current runs across\nthe battlefield!");
|
static const u8 sText_TerrainBecomesElectric[] = _("An electric current runs across\nthe battlefield!");
|
||||||
static const u8 sText_TerrainBecomesPsychic[] = _("The battlefield got weird!");
|
static const u8 sText_TerrainBecomesPsychic[] = _("The battlefield got weird!");
|
||||||
static const u8 sText_TargetElectrified[] = _("The {B_DEF_NAME_WITH_PREFIX}'s moves\nhave been electrified!");
|
static const u8 sText_TargetElectrified[] = _("The {B_DEF_NAME_WITH_PREFIX}'s moves\nhave been electrified!");
|
||||||
static const u8 sText_AssaultVestDoesntAllow[] = _("The effects of the {B_LAST_ITEM} prevent status\nmoves from being used!\p");
|
static const u8 sText_AssaultVestDoesntAllow[] = _("{B_LAST_ITEM}'s effects prevent\nstatus moves from being used!\p");
|
||||||
static const u8 sText_GravityPreventsUsage[] = _("{B_ATK_NAME_WITH_PREFIX} can't use {B_CURRENT_MOVE}\nbecause of gravity!\p");
|
static const u8 sText_GravityPreventsUsage[] = _("{B_ATK_NAME_WITH_PREFIX} can't use {B_CURRENT_MOVE}\nbecause of gravity!\p");
|
||||||
static const u8 sText_HealBlockPreventsUsage[] = _("{B_ATK_NAME_WITH_PREFIX} was\nprevented from healing!\p");
|
static const u8 sText_HealBlockPreventsUsage[] = _("{B_ATK_NAME_WITH_PREFIX} was\nprevented from healing!\p");
|
||||||
static const u8 sText_MegaEvoReacting[] = _("{B_ATK_NAME_WITH_PREFIX}'s {B_LAST_ITEM} is \nreacting to {B_ATK_TRAINER_NAME}'s Mega Ring!");
|
static const u8 sText_MegaEvoReacting[] = _("{B_ATK_NAME_WITH_PREFIX}'s {B_LAST_ITEM} is \nreacting to {B_ATK_TRAINER_NAME}'s Mega Ring!");
|
||||||
@ -728,6 +728,11 @@ static const u8 sText_SwappedAbilities[] = _("{B_DEF_NAME_WITH_PREFIX} swapped A
|
|||||||
static const u8 sText_PastelVeilProtected[] = _("{B_DEF_NAME_WITH_PREFIX} is protected\nby a pastel veil!");
|
static const u8 sText_PastelVeilProtected[] = _("{B_DEF_NAME_WITH_PREFIX} is protected\nby a pastel veil!");
|
||||||
static const u8 sText_PastelVeilEnters[] = _("{B_DEF_NAME_WITH_PREFIX} was cured\nof its poisoning!");
|
static const u8 sText_PastelVeilEnters[] = _("{B_DEF_NAME_WITH_PREFIX} was cured\nof its poisoning!");
|
||||||
static const u8 sText_BattlerTypeChangedTo[] = _("{B_BUFF1}'s type\nchanged to {B_BUFF2}!");
|
static const u8 sText_BattlerTypeChangedTo[] = _("{B_BUFF1}'s type\nchanged to {B_BUFF2}!");
|
||||||
|
static const u8 sText_BothCanNoLongerEscape[] = _("Neither POKéMON can run away!");
|
||||||
|
static const u8 sText_CantEscapeDueToUsedMove[] = _("{B_ATK_NAME_WITH_PREFIX} can no longer escape\nbecause it used {B_CURRENT_MOVE}!");
|
||||||
|
static const u8 sText_PkmnBecameWeakerToFire[] = _("{B_DEF_NAME_WITH_PREFIX} became\nweaker to fire!");
|
||||||
|
static const u8 sText_PkmnAboutToBeAttackedByItsItem[] = _("{B_DEF_NAME_WITH_PREFIX} is about\nto be attacked by its {B_BUFF1}!");
|
||||||
|
static const u8 sText_CantEscapeBecauseOfCurrentMove[] = _("{B_DEF_NAME_WITH_PREFIX} can no longer escape\nbecause of {B_CURRENT_MOVE}!");
|
||||||
static const u8 sText_NeutralizingGasEnters[] = _("Neutralizing Gas filled the area!");
|
static const u8 sText_NeutralizingGasEnters[] = _("Neutralizing Gas filled the area!");
|
||||||
static const u8 sText_NeutralizingGasOver[] = _("The effects of Neutralizing\nGas wore off!");
|
static const u8 sText_NeutralizingGasOver[] = _("The effects of Neutralizing\nGas wore off!");
|
||||||
|
|
||||||
@ -1214,7 +1219,7 @@ const u8 *const gBattleStringsTable[BATTLESTRINGS_COUNT] =
|
|||||||
[STRINGID_HURLEDINTOTHEAIR - 12] = sText_HurledIntoTheAir,
|
[STRINGID_HURLEDINTOTHEAIR - 12] = sText_HurledIntoTheAir,
|
||||||
[STRINGID_HELDITEMSLOSEEFFECTS - 12] = sText_HeldItemsLoseEffects,
|
[STRINGID_HELDITEMSLOSEEFFECTS - 12] = sText_HeldItemsLoseEffects,
|
||||||
[STRINGID_FELLSTRAIGHTDOWN - 12] = sText_FellStraightDown,
|
[STRINGID_FELLSTRAIGHTDOWN - 12] = sText_FellStraightDown,
|
||||||
[STRINGID_TRANSFORMEDINTOWATERTYPE - 12] = sText_TransformedIntoWaterType,
|
[STRINGID_TARGETCHANGEDTYPE - 12] = sText_TargetChangedType,
|
||||||
[STRINGID_PKMNACQUIREDSIMPLE - 12] = sText_PkmnAcquiredSimple,
|
[STRINGID_PKMNACQUIREDSIMPLE - 12] = sText_PkmnAcquiredSimple,
|
||||||
[STRINGID_EMPTYSTRING5 - 12] = sText_EmptyString4,
|
[STRINGID_EMPTYSTRING5 - 12] = sText_EmptyString4,
|
||||||
[STRINGID_KINDOFFER - 12] = sText_KindOffer,
|
[STRINGID_KINDOFFER - 12] = sText_KindOffer,
|
||||||
@ -1324,6 +1329,11 @@ const u8 *const gBattleStringsTable[BATTLESTRINGS_COUNT] =
|
|||||||
[STRINGID_AURABREAKENTERS - 12] = sText_AuraBreakActivates,
|
[STRINGID_AURABREAKENTERS - 12] = sText_AuraBreakActivates,
|
||||||
[STRINGID_COMATOSEENTERS - 12] = sText_ComatoseActivates,
|
[STRINGID_COMATOSEENTERS - 12] = sText_ComatoseActivates,
|
||||||
[STRINGID_SCREENCLEANERENTERS - 12] = sText_ScreenCleanerActivates,
|
[STRINGID_SCREENCLEANERENTERS - 12] = sText_ScreenCleanerActivates,
|
||||||
|
[STRINGID_BOTHCANNOLONGERESCAPE - 12] = sText_BothCanNoLongerEscape,
|
||||||
|
[STRINGID_CANTESCAPEDUETOUSEDMOVE - 12] = sText_CantEscapeDueToUsedMove,
|
||||||
|
[STRINGID_PKMNBECAMEWEAKERTOFIRE - 12] = sText_PkmnBecameWeakerToFire,
|
||||||
|
[STRINGID_ABOUTTOUSEPOLTERGEIST - 12] = sText_PkmnAboutToBeAttackedByItsItem,
|
||||||
|
[STRINGID_CANTESCAPEBECAUSEOFCURRENTMOVE - 12] = sText_CantEscapeBecauseOfCurrentMove,
|
||||||
};
|
};
|
||||||
|
|
||||||
const u16 gMentalHerbCureStringIds[] =
|
const u16 gMentalHerbCureStringIds[] =
|
||||||
|
File diff suppressed because it is too large
Load Diff
@ -1762,7 +1762,7 @@ u8 TrySetCantSelectMoveBattleScript(void)
|
|||||||
limitations++;
|
limitations++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (holdEffect == HOLD_EFFECT_ASSAULT_VEST && gBattleMoves[move].power == 0)
|
else if (holdEffect == HOLD_EFFECT_ASSAULT_VEST && gBattleMoves[move].power == 0 && move != MOVE_ME_FIRST)
|
||||||
{
|
{
|
||||||
gCurrentMove = move;
|
gCurrentMove = move;
|
||||||
gLastUsedItem = gBattleMons[gActiveBattler].item;
|
gLastUsedItem = gBattleMons[gActiveBattler].item;
|
||||||
@ -1834,7 +1834,7 @@ u8 CheckMoveLimitations(u8 battlerId, u8 unusableMoves, u8 check)
|
|||||||
unusableMoves |= gBitTable[i];
|
unusableMoves |= gBitTable[i];
|
||||||
else if (HOLD_EFFECT_CHOICE(holdEffect) && *choicedMove != 0 && *choicedMove != 0xFFFF && *choicedMove != gBattleMons[battlerId].moves[i])
|
else if (HOLD_EFFECT_CHOICE(holdEffect) && *choicedMove != 0 && *choicedMove != 0xFFFF && *choicedMove != gBattleMons[battlerId].moves[i])
|
||||||
unusableMoves |= gBitTable[i];
|
unusableMoves |= gBitTable[i];
|
||||||
else if (holdEffect == HOLD_EFFECT_ASSAULT_VEST && gBattleMoves[gBattleMons[battlerId].moves[i]].power == 0)
|
else if (holdEffect == HOLD_EFFECT_ASSAULT_VEST && gBattleMoves[gBattleMons[battlerId].moves[i]].power == 0 && gBattleMons[battlerId].moves[i] != MOVE_ME_FIRST)
|
||||||
unusableMoves |= gBitTable[i];
|
unusableMoves |= gBitTable[i];
|
||||||
else if (IsGravityPreventingMove(gBattleMons[battlerId].moves[i]))
|
else if (IsGravityPreventingMove(gBattleMons[battlerId].moves[i]))
|
||||||
unusableMoves |= gBitTable[i];
|
unusableMoves |= gBitTable[i];
|
||||||
@ -2326,7 +2326,7 @@ u8 DoFieldEndTurnEffects(void)
|
|||||||
break;
|
break;
|
||||||
case ENDTURN_ELECTRIC_TERRAIN:
|
case ENDTURN_ELECTRIC_TERRAIN:
|
||||||
if (gFieldStatuses & STATUS_FIELD_ELECTRIC_TERRAIN
|
if (gFieldStatuses & STATUS_FIELD_ELECTRIC_TERRAIN
|
||||||
&& (!(gFieldStatuses & STATUS_FIELD_TERRAIN_PERMANENT) && --gFieldTimers.electricTerrainTimer == 0))
|
&& (!(gFieldStatuses & STATUS_FIELD_TERRAIN_PERMANENT) && --gFieldTimers.terrainTimer == 0))
|
||||||
{
|
{
|
||||||
gFieldStatuses &= ~(STATUS_FIELD_ELECTRIC_TERRAIN | STATUS_FIELD_TERRAIN_PERMANENT);
|
gFieldStatuses &= ~(STATUS_FIELD_ELECTRIC_TERRAIN | STATUS_FIELD_TERRAIN_PERMANENT);
|
||||||
TryToRevertMimicry();
|
TryToRevertMimicry();
|
||||||
@ -2337,7 +2337,7 @@ u8 DoFieldEndTurnEffects(void)
|
|||||||
break;
|
break;
|
||||||
case ENDTURN_MISTY_TERRAIN:
|
case ENDTURN_MISTY_TERRAIN:
|
||||||
if (gFieldStatuses & STATUS_FIELD_MISTY_TERRAIN
|
if (gFieldStatuses & STATUS_FIELD_MISTY_TERRAIN
|
||||||
&& (!(gFieldStatuses & STATUS_FIELD_TERRAIN_PERMANENT) && --gFieldTimers.mistyTerrainTimer == 0))
|
&& (!(gFieldStatuses & STATUS_FIELD_TERRAIN_PERMANENT) && --gFieldTimers.terrainTimer == 0))
|
||||||
{
|
{
|
||||||
gFieldStatuses &= ~(STATUS_FIELD_MISTY_TERRAIN);
|
gFieldStatuses &= ~(STATUS_FIELD_MISTY_TERRAIN);
|
||||||
TryToRevertMimicry();
|
TryToRevertMimicry();
|
||||||
@ -2350,7 +2350,7 @@ u8 DoFieldEndTurnEffects(void)
|
|||||||
if (gFieldStatuses & STATUS_FIELD_GRASSY_TERRAIN)
|
if (gFieldStatuses & STATUS_FIELD_GRASSY_TERRAIN)
|
||||||
{
|
{
|
||||||
if (!(gFieldStatuses & STATUS_FIELD_TERRAIN_PERMANENT)
|
if (!(gFieldStatuses & STATUS_FIELD_TERRAIN_PERMANENT)
|
||||||
&& (gFieldTimers.grassyTerrainTimer == 0 || --gFieldTimers.grassyTerrainTimer == 0))
|
&& (gFieldTimers.terrainTimer == 0 || --gFieldTimers.terrainTimer == 0))
|
||||||
{
|
{
|
||||||
gFieldStatuses &= ~(STATUS_FIELD_GRASSY_TERRAIN);
|
gFieldStatuses &= ~(STATUS_FIELD_GRASSY_TERRAIN);
|
||||||
TryToRevertMimicry();
|
TryToRevertMimicry();
|
||||||
@ -2362,7 +2362,7 @@ u8 DoFieldEndTurnEffects(void)
|
|||||||
break;
|
break;
|
||||||
case ENDTURN_PSYCHIC_TERRAIN:
|
case ENDTURN_PSYCHIC_TERRAIN:
|
||||||
if (gFieldStatuses & STATUS_FIELD_PSYCHIC_TERRAIN
|
if (gFieldStatuses & STATUS_FIELD_PSYCHIC_TERRAIN
|
||||||
&& (!(gFieldStatuses & STATUS_FIELD_TERRAIN_PERMANENT) && --gFieldTimers.psychicTerrainTimer == 0))
|
&& (!(gFieldStatuses & STATUS_FIELD_TERRAIN_PERMANENT) && --gFieldTimers.terrainTimer == 0))
|
||||||
{
|
{
|
||||||
gFieldStatuses &= ~(STATUS_FIELD_PSYCHIC_TERRAIN);
|
gFieldStatuses &= ~(STATUS_FIELD_PSYCHIC_TERRAIN);
|
||||||
TryToRevertMimicry();
|
TryToRevertMimicry();
|
||||||
@ -2438,6 +2438,7 @@ enum
|
|||||||
ENDTURN_NIGHTMARES,
|
ENDTURN_NIGHTMARES,
|
||||||
ENDTURN_CURSE,
|
ENDTURN_CURSE,
|
||||||
ENDTURN_WRAP,
|
ENDTURN_WRAP,
|
||||||
|
ENDTURN_OCTOLOCK,
|
||||||
ENDTURN_UPROAR,
|
ENDTURN_UPROAR,
|
||||||
ENDTURN_THRASH,
|
ENDTURN_THRASH,
|
||||||
ENDTURN_FLINCH,
|
ENDTURN_FLINCH,
|
||||||
@ -2708,6 +2709,18 @@ u8 DoBattlerEndTurnEffects(void)
|
|||||||
}
|
}
|
||||||
gBattleStruct->turnEffectsTracker++;
|
gBattleStruct->turnEffectsTracker++;
|
||||||
break;
|
break;
|
||||||
|
case ENDTURN_OCTOLOCK:
|
||||||
|
if (gDisableStructs[gActiveBattler].octolock
|
||||||
|
&& !(GetBattlerAbility(gActiveBattler) == ABILITY_CLEAR_BODY
|
||||||
|
|| GetBattlerAbility(gActiveBattler) == ABILITY_FULL_METAL_BODY
|
||||||
|
|| GetBattlerAbility(gActiveBattler) == ABILITY_WHITE_SMOKE))
|
||||||
|
{
|
||||||
|
gBattlerTarget = gActiveBattler;
|
||||||
|
BattleScriptExecute(BattleScript_OctolockEndTurn);
|
||||||
|
effect++;
|
||||||
|
}
|
||||||
|
gBattleStruct->turnEffectsTracker++;
|
||||||
|
break;
|
||||||
case ENDTURN_UPROAR: // uproar
|
case ENDTURN_UPROAR: // uproar
|
||||||
if (gBattleMons[gActiveBattler].status2 & STATUS2_UPROAR)
|
if (gBattleMons[gActiveBattler].status2 & STATUS2_UPROAR)
|
||||||
{
|
{
|
||||||
@ -4338,28 +4351,28 @@ u8 AbilityBattleEffects(u8 caseID, u8 battler, u16 ability, u8 special, u16 move
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case ABILITY_ELECTRIC_SURGE:
|
case ABILITY_ELECTRIC_SURGE:
|
||||||
if (TryChangeBattleTerrain(battler, STATUS_FIELD_ELECTRIC_TERRAIN, &gFieldTimers.electricTerrainTimer))
|
if (TryChangeBattleTerrain(battler, STATUS_FIELD_ELECTRIC_TERRAIN, &gFieldTimers.terrainTimer))
|
||||||
{
|
{
|
||||||
BattleScriptPushCursorAndCallback(BattleScript_ElectricSurgeActivates);
|
BattleScriptPushCursorAndCallback(BattleScript_ElectricSurgeActivates);
|
||||||
effect++;
|
effect++;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case ABILITY_GRASSY_SURGE:
|
case ABILITY_GRASSY_SURGE:
|
||||||
if (TryChangeBattleTerrain(battler, STATUS_FIELD_GRASSY_TERRAIN, &gFieldTimers.grassyTerrainTimer))
|
if (TryChangeBattleTerrain(battler, STATUS_FIELD_GRASSY_TERRAIN, &gFieldTimers.terrainTimer))
|
||||||
{
|
{
|
||||||
BattleScriptPushCursorAndCallback(BattleScript_GrassySurgeActivates);
|
BattleScriptPushCursorAndCallback(BattleScript_GrassySurgeActivates);
|
||||||
effect++;
|
effect++;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case ABILITY_MISTY_SURGE:
|
case ABILITY_MISTY_SURGE:
|
||||||
if (TryChangeBattleTerrain(battler, STATUS_FIELD_MISTY_TERRAIN, &gFieldTimers.mistyTerrainTimer))
|
if (TryChangeBattleTerrain(battler, STATUS_FIELD_MISTY_TERRAIN, &gFieldTimers.terrainTimer))
|
||||||
{
|
{
|
||||||
BattleScriptPushCursorAndCallback(BattleScript_MistySurgeActivates);
|
BattleScriptPushCursorAndCallback(BattleScript_MistySurgeActivates);
|
||||||
effect++;
|
effect++;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case ABILITY_PSYCHIC_SURGE:
|
case ABILITY_PSYCHIC_SURGE:
|
||||||
if (TryChangeBattleTerrain(battler, STATUS_FIELD_PSYCHIC_TERRAIN, &gFieldTimers.psychicTerrainTimer))
|
if (TryChangeBattleTerrain(battler, STATUS_FIELD_PSYCHIC_TERRAIN, &gFieldTimers.terrainTimer))
|
||||||
{
|
{
|
||||||
BattleScriptPushCursorAndCallback(BattleScript_PsychicSurgeActivates);
|
BattleScriptPushCursorAndCallback(BattleScript_PsychicSurgeActivates);
|
||||||
effect++;
|
effect++;
|
||||||
@ -6904,6 +6917,10 @@ u8 ItemBattleEffects(u8 caseID, u8 battlerId, bool8 moveTurn)
|
|||||||
switch (atkHoldEffect)
|
switch (atkHoldEffect)
|
||||||
{
|
{
|
||||||
case HOLD_EFFECT_FLINCH:
|
case HOLD_EFFECT_FLINCH:
|
||||||
|
#if B_SERENE_GRACE_BOOST >= GEN_5
|
||||||
|
if (GetBattlerAbility(gBattlerAttacker) == ABILITY_SERENE_GRACE)
|
||||||
|
atkHoldEffectParam *= 2;
|
||||||
|
#endif
|
||||||
if (gBattleMoveDamage != 0 // Need to have done damage
|
if (gBattleMoveDamage != 0 // Need to have done damage
|
||||||
&& !(gMoveResultFlags & MOVE_RESULT_NO_EFFECT)
|
&& !(gMoveResultFlags & MOVE_RESULT_NO_EFFECT)
|
||||||
&& TARGET_TURN_DAMAGED
|
&& TARGET_TURN_DAMAGED
|
||||||
@ -7490,6 +7507,48 @@ bool32 IsMoveMakingContact(u16 move, u8 battlerAtk)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool32 IsBattlerProtected(u8 battlerId, u16 move)
|
||||||
|
{
|
||||||
|
// Decorate bypasses protect and detect, but not crafty shield
|
||||||
|
if (move == MOVE_DECORATE)
|
||||||
|
{
|
||||||
|
if (gSideStatuses[GetBattlerSide(battlerId)] & SIDE_STATUS_CRAFTY_SHIELD)
|
||||||
|
return TRUE;
|
||||||
|
else if (gProtectStructs[battlerId].protected)
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!(gBattleMoves[move].flags & FLAG_PROTECT_AFFECTED))
|
||||||
|
return FALSE;
|
||||||
|
else if (gBattleMoves[move].effect == MOVE_EFFECT_FEINT)
|
||||||
|
return FALSE;
|
||||||
|
else if (gProtectStructs[battlerId].protected)
|
||||||
|
return TRUE;
|
||||||
|
else if (gSideStatuses[GetBattlerSide(battlerId)] & SIDE_STATUS_WIDE_GUARD
|
||||||
|
&& gBattleMoves[move].target & (MOVE_TARGET_BOTH | MOVE_TARGET_FOES_AND_ALLY))
|
||||||
|
return TRUE;
|
||||||
|
else if (gProtectStructs[battlerId].banefulBunkered)
|
||||||
|
return TRUE;
|
||||||
|
else if (gProtectStructs[battlerId].obstructed && !IS_MOVE_STATUS(move))
|
||||||
|
return TRUE;
|
||||||
|
else if (gProtectStructs[battlerId].spikyShielded)
|
||||||
|
return TRUE;
|
||||||
|
else if (gProtectStructs[battlerId].kingsShielded && gBattleMoves[move].power != 0)
|
||||||
|
return TRUE;
|
||||||
|
else if (gSideStatuses[GetBattlerSide(battlerId)] & SIDE_STATUS_QUICK_GUARD
|
||||||
|
&& GetChosenMovePriority(gBattlerAttacker) > 0)
|
||||||
|
return TRUE;
|
||||||
|
else if (gSideStatuses[GetBattlerSide(battlerId)] & SIDE_STATUS_CRAFTY_SHIELD
|
||||||
|
&& IS_MOVE_STATUS(move))
|
||||||
|
return TRUE;
|
||||||
|
else if (gSideStatuses[GetBattlerSide(battlerId)] & SIDE_STATUS_MAT_BLOCK
|
||||||
|
&& !IS_MOVE_STATUS(move))
|
||||||
|
return TRUE;
|
||||||
|
else
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
bool32 IsBattlerGrounded(u8 battlerId)
|
bool32 IsBattlerGrounded(u8 battlerId)
|
||||||
{
|
{
|
||||||
if (GetBattlerHoldEffect(battlerId, TRUE) == HOLD_EFFECT_IRON_BALL)
|
if (GetBattlerHoldEffect(battlerId, TRUE) == HOLD_EFFECT_IRON_BALL)
|
||||||
@ -7845,7 +7904,7 @@ static u16 CalcMoveBasePower(u16 move, u8 battlerAtk, u8 battlerDef)
|
|||||||
if (weight >= ARRAY_COUNT(sHeatCrashPowerTable))
|
if (weight >= ARRAY_COUNT(sHeatCrashPowerTable))
|
||||||
basePower = sHeatCrashPowerTable[ARRAY_COUNT(sHeatCrashPowerTable) - 1];
|
basePower = sHeatCrashPowerTable[ARRAY_COUNT(sHeatCrashPowerTable) - 1];
|
||||||
else
|
else
|
||||||
basePower = sHeatCrashPowerTable[i];
|
basePower = sHeatCrashPowerTable[weight];
|
||||||
break;
|
break;
|
||||||
case EFFECT_PUNISHMENT:
|
case EFFECT_PUNISHMENT:
|
||||||
basePower = 60 + (CountBattlerStatIncreases(battlerDef, FALSE) * 20);
|
basePower = 60 + (CountBattlerStatIncreases(battlerDef, FALSE) * 20);
|
||||||
@ -7880,6 +7939,10 @@ static u16 CalcMoveBasePower(u16 move, u8 battlerAtk, u8 battlerDef)
|
|||||||
&& (gDisableStructs[battlerDef].isFirstTurn != 2 || B_PAYBACK_SWITCH_BOOST < GEN_5))
|
&& (gDisableStructs[battlerDef].isFirstTurn != 2 || B_PAYBACK_SWITCH_BOOST < GEN_5))
|
||||||
basePower *= 2;
|
basePower *= 2;
|
||||||
break;
|
break;
|
||||||
|
case EFFECT_BOLT_BEAK:
|
||||||
|
if (GetBattlerTurnOrderNum(battlerAtk) < GetBattlerTurnOrderNum(battlerDef))
|
||||||
|
basePower *= 2;
|
||||||
|
break;
|
||||||
case EFFECT_ROUND:
|
case EFFECT_ROUND:
|
||||||
if (gChosenMoveByBattler[BATTLE_PARTNER(battlerAtk)] == MOVE_ROUND && !(gAbsentBattlerFlags & gBitTable[BATTLE_PARTNER(battlerAtk)]))
|
if (gChosenMoveByBattler[BATTLE_PARTNER(battlerAtk)] == MOVE_ROUND && !(gAbsentBattlerFlags & gBitTable[BATTLE_PARTNER(battlerAtk)]))
|
||||||
basePower *= 2;
|
basePower *= 2;
|
||||||
@ -7922,6 +7985,11 @@ static u16 CalcMoveBasePower(u16 move, u8 battlerAtk, u8 battlerDef)
|
|||||||
if (gFieldStatuses & STATUS_FIELD_GRAVITY)
|
if (gFieldStatuses & STATUS_FIELD_GRAVITY)
|
||||||
MulModifier(&basePower, UQ_4_12(1.5));
|
MulModifier(&basePower, UQ_4_12(1.5));
|
||||||
break;
|
break;
|
||||||
|
case EFFECT_TERRAIN_PULSE:
|
||||||
|
if ((gFieldStatuses & STATUS_FIELD_TERRAIN_ANY)
|
||||||
|
&& IsBattlerGrounded(gBattlerAttacker))
|
||||||
|
basePower *= 2;
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
// move-specific base power changes
|
// move-specific base power changes
|
||||||
@ -8148,7 +8216,7 @@ static u32 CalcMoveBasePowerAfterModifiers(u16 move, u8 battlerAtk, u8 battlerDe
|
|||||||
#if B_SOUL_DEW_BOOST >= GEN_7
|
#if B_SOUL_DEW_BOOST >= GEN_7
|
||||||
if ((gBattleMons[battlerAtk].species == SPECIES_LATIAS || gBattleMons[battlerAtk].species == SPECIES_LATIOS) && (moveType == TYPE_PSYCHIC || moveType == TYPE_DRAGON))
|
if ((gBattleMons[battlerAtk].species == SPECIES_LATIAS || gBattleMons[battlerAtk].species == SPECIES_LATIOS) && (moveType == TYPE_PSYCHIC || moveType == TYPE_DRAGON))
|
||||||
#else
|
#else
|
||||||
if ((gBattleMons[battlerAtk].species == SPECIES_LATIAS || gBattleMons[battlerAtk].species == SPECIES_LATIOS) && !(gBattleTypeFlags & BATTLE_TYPE_FRONTIER))
|
if ((gBattleMons[battlerAtk].species == SPECIES_LATIAS || gBattleMons[battlerAtk].species == SPECIES_LATIOS) && !(gBattleTypeFlags & BATTLE_TYPE_FRONTIER) && IS_MOVE_SPECIAL(move))
|
||||||
#endif
|
#endif
|
||||||
MulModifier(&modifier, holdEffectModifier);
|
MulModifier(&modifier, holdEffectModifier);
|
||||||
break;
|
break;
|
||||||
@ -8640,7 +8708,9 @@ static u32 CalcFinalDmg(u32 dmg, u16 move, u8 battlerAtk, u8 battlerDef, u8 move
|
|||||||
if (((gSideStatuses[defSide] & SIDE_STATUS_REFLECT && IS_MOVE_PHYSICAL(move))
|
if (((gSideStatuses[defSide] & SIDE_STATUS_REFLECT && IS_MOVE_PHYSICAL(move))
|
||||||
|| (gSideStatuses[defSide] & SIDE_STATUS_LIGHTSCREEN && IS_MOVE_SPECIAL(move))
|
|| (gSideStatuses[defSide] & SIDE_STATUS_LIGHTSCREEN && IS_MOVE_SPECIAL(move))
|
||||||
|| (gSideStatuses[defSide] & SIDE_STATUS_AURORA_VEIL))
|
|| (gSideStatuses[defSide] & SIDE_STATUS_AURORA_VEIL))
|
||||||
&& abilityAtk != ABILITY_INFILTRATOR)
|
&& abilityAtk != ABILITY_INFILTRATOR
|
||||||
|
&& !(isCrit)
|
||||||
|
&& !gProtectStructs[gBattlerAttacker].confusionSelfDmg)
|
||||||
{
|
{
|
||||||
if (gBattleTypeFlags & BATTLE_TYPE_DOUBLE)
|
if (gBattleTypeFlags & BATTLE_TYPE_DOUBLE)
|
||||||
MulModifier(&finalModifier, UQ_4_12(0.66));
|
MulModifier(&finalModifier, UQ_4_12(0.66));
|
||||||
@ -8809,9 +8879,8 @@ static void MulByTypeEffectiveness(u16 *modifier, u16 move, u8 moveType, u8 batt
|
|||||||
mod = UQ_4_12(2.0);
|
mod = UQ_4_12(2.0);
|
||||||
if (moveType == TYPE_GROUND && defType == TYPE_FLYING && IsBattlerGrounded(battlerDef) && mod == UQ_4_12(0.0))
|
if (moveType == TYPE_GROUND && defType == TYPE_FLYING && IsBattlerGrounded(battlerDef) && mod == UQ_4_12(0.0))
|
||||||
mod = UQ_4_12(1.0);
|
mod = UQ_4_12(1.0);
|
||||||
|
if (moveType == TYPE_FIRE && gDisableStructs[battlerDef].tarShot)
|
||||||
if (gProtectStructs[battlerDef].kingsShielded && gBattleMoves[move].effect != EFFECT_FEINT)
|
mod = UQ_4_12(2.0);
|
||||||
mod = UQ_4_12(1.0);
|
|
||||||
|
|
||||||
// WEATHER_STRONG_WINDS weakens Super Effective moves against Flying-type Pokémon
|
// WEATHER_STRONG_WINDS weakens Super Effective moves against Flying-type Pokémon
|
||||||
if (WEATHER_HAS_EFFECT && gBattleWeather & WEATHER_STRONG_WINDS)
|
if (WEATHER_HAS_EFFECT && gBattleWeather & WEATHER_STRONG_WINDS)
|
||||||
|
@ -10772,7 +10772,7 @@ const struct BattleMove gBattleMoves[MOVES_COUNT] =
|
|||||||
|
|
||||||
[MOVE_JAW_LOCK] =
|
[MOVE_JAW_LOCK] =
|
||||||
{
|
{
|
||||||
.effect = EFFECT_MEAN_LOOK,
|
.effect = EFFECT_JAW_LOCK,
|
||||||
.power = 80,
|
.power = 80,
|
||||||
.type = TYPE_DARK,
|
.type = TYPE_DARK,
|
||||||
.accuracy = 100,
|
.accuracy = 100,
|
||||||
@ -10800,7 +10800,7 @@ const struct BattleMove gBattleMoves[MOVES_COUNT] =
|
|||||||
|
|
||||||
[MOVE_NO_RETREAT] =
|
[MOVE_NO_RETREAT] =
|
||||||
{
|
{
|
||||||
.effect = EFFECT_PLACEHOLDER, //TODO
|
.effect = EFFECT_NO_RETREAT,
|
||||||
.power = 0,
|
.power = 0,
|
||||||
.type = TYPE_FIGHTING,
|
.type = TYPE_FIGHTING,
|
||||||
.accuracy = 0,
|
.accuracy = 0,
|
||||||
@ -10814,7 +10814,7 @@ const struct BattleMove gBattleMoves[MOVES_COUNT] =
|
|||||||
|
|
||||||
[MOVE_TAR_SHOT] =
|
[MOVE_TAR_SHOT] =
|
||||||
{
|
{
|
||||||
.effect = EFFECT_SPEED_DOWN,
|
.effect = EFFECT_TAR_SHOT,
|
||||||
.power = 0,
|
.power = 0,
|
||||||
.type = TYPE_ROCK,
|
.type = TYPE_ROCK,
|
||||||
.accuracy = 100,
|
.accuracy = 100,
|
||||||
@ -10828,7 +10828,7 @@ const struct BattleMove gBattleMoves[MOVES_COUNT] =
|
|||||||
|
|
||||||
[MOVE_MAGIC_POWDER] =
|
[MOVE_MAGIC_POWDER] =
|
||||||
{
|
{
|
||||||
.effect = EFFECT_THIRD_TYPE,
|
.effect = EFFECT_SOAK,
|
||||||
.power = 0,
|
.power = 0,
|
||||||
.type = TYPE_PSYCHIC,
|
.type = TYPE_PSYCHIC,
|
||||||
.accuracy = 100,
|
.accuracy = 100,
|
||||||
@ -10871,7 +10871,7 @@ const struct BattleMove gBattleMoves[MOVES_COUNT] =
|
|||||||
|
|
||||||
[MOVE_OCTOLOCK] =
|
[MOVE_OCTOLOCK] =
|
||||||
{
|
{
|
||||||
.effect = EFFECT_MEAN_LOOK,
|
.effect = EFFECT_OCTOLOCK,
|
||||||
.power = 0,
|
.power = 0,
|
||||||
.type = TYPE_FIGHTING,
|
.type = TYPE_FIGHTING,
|
||||||
.accuracy = 100,
|
.accuracy = 100,
|
||||||
@ -10885,7 +10885,7 @@ const struct BattleMove gBattleMoves[MOVES_COUNT] =
|
|||||||
|
|
||||||
[MOVE_BOLT_BEAK] =
|
[MOVE_BOLT_BEAK] =
|
||||||
{
|
{
|
||||||
.effect = EFFECT_PLACEHOLDER, //TODO
|
.effect = EFFECT_BOLT_BEAK,
|
||||||
.power = 85,
|
.power = 85,
|
||||||
.type = TYPE_ELECTRIC,
|
.type = TYPE_ELECTRIC,
|
||||||
.accuracy = 100,
|
.accuracy = 100,
|
||||||
@ -10899,7 +10899,7 @@ const struct BattleMove gBattleMoves[MOVES_COUNT] =
|
|||||||
|
|
||||||
[MOVE_FISHIOUS_REND] =
|
[MOVE_FISHIOUS_REND] =
|
||||||
{
|
{
|
||||||
.effect = EFFECT_PLACEHOLDER, //TODO. same as bolt beak
|
.effect = EFFECT_BOLT_BEAK,
|
||||||
.power = 85,
|
.power = 85,
|
||||||
.type = TYPE_WATER,
|
.type = TYPE_WATER,
|
||||||
.accuracy = 100,
|
.accuracy = 100,
|
||||||
@ -10927,7 +10927,7 @@ const struct BattleMove gBattleMoves[MOVES_COUNT] =
|
|||||||
|
|
||||||
[MOVE_CLANGOROUS_SOUL] =
|
[MOVE_CLANGOROUS_SOUL] =
|
||||||
{
|
{
|
||||||
.effect = EFFECT_PLACEHOLDER, //TODO
|
.effect = EFFECT_CLANGOROUS_SOUL,
|
||||||
.power = 0,
|
.power = 0,
|
||||||
.type = TYPE_DRAGON,
|
.type = TYPE_DRAGON,
|
||||||
.accuracy = 100,
|
.accuracy = 100,
|
||||||
@ -11347,7 +11347,7 @@ const struct BattleMove gBattleMoves[MOVES_COUNT] =
|
|||||||
|
|
||||||
[MOVE_TERRAIN_PULSE] =
|
[MOVE_TERRAIN_PULSE] =
|
||||||
{
|
{
|
||||||
.effect = EFFECT_PLACEHOLDER, //TODO
|
.effect = EFFECT_TERRAIN_PULSE,
|
||||||
.power = 50,
|
.power = 50,
|
||||||
.type = TYPE_NORMAL,
|
.type = TYPE_NORMAL,
|
||||||
.accuracy = 100,
|
.accuracy = 100,
|
||||||
@ -11403,7 +11403,7 @@ const struct BattleMove gBattleMoves[MOVES_COUNT] =
|
|||||||
|
|
||||||
[MOVE_POLTERGEIST] =
|
[MOVE_POLTERGEIST] =
|
||||||
{
|
{
|
||||||
.effect = EFFECT_PLACEHOLDER, //TODO
|
.effect = EFFECT_POLTERGEIST,
|
||||||
.power = 110,
|
.power = 110,
|
||||||
.type = TYPE_GHOST,
|
.type = TYPE_GHOST,
|
||||||
.accuracy = 90,
|
.accuracy = 90,
|
||||||
|
@ -1395,7 +1395,6 @@ const u32 gBattleAnimBgPalette_Solarbeam[] = INCBIN_U32("graphics/battle_anims/b
|
|||||||
const u32 gBattleAnimBgPalette_MagmaStorm[] = INCBIN_U32("graphics/battle_anims/backgrounds/magma_storm.gbapal.lz");
|
const u32 gBattleAnimBgPalette_MagmaStorm[] = INCBIN_U32("graphics/battle_anims/backgrounds/magma_storm.gbapal.lz");
|
||||||
|
|
||||||
//new battle bgs
|
//new battle bgs
|
||||||
const u32 gBattleAnimBgPalette_GigaImpact[] = INCBIN_U32("graphics/battle_anims/backgrounds/giga_impact.gbapal.lz");
|
|
||||||
|
|
||||||
const u32 gBattleAnimBgImage_Hurricane[] = INCBIN_U32("graphics/battle_anims/backgrounds/new/hurricane.4bpp.lz");
|
const u32 gBattleAnimBgImage_Hurricane[] = INCBIN_U32("graphics/battle_anims/backgrounds/new/hurricane.4bpp.lz");
|
||||||
const u32 gBattleAnimBgPalette_Hurricane[] = INCBIN_U32("graphics/battle_anims/backgrounds/new/hurricane.gbapal.lz");
|
const u32 gBattleAnimBgPalette_Hurricane[] = INCBIN_U32("graphics/battle_anims/backgrounds/new/hurricane.gbapal.lz");
|
||||||
@ -1403,10 +1402,14 @@ const u32 gBattleAnimBgTilemap_Hurricane[] = INCBIN_U32("graphics/battle_anims/b
|
|||||||
|
|
||||||
const u32 gBattleAnimBgPalette_RockWrecker[] = INCBIN_U32("graphics/battle_anims/backgrounds/new/rock_wrecker.gbapal.lz");
|
const u32 gBattleAnimBgPalette_RockWrecker[] = INCBIN_U32("graphics/battle_anims/backgrounds/new/rock_wrecker.gbapal.lz");
|
||||||
|
|
||||||
|
const u32 gBattleAnimBgTilemap_GigaImpactPlayer[] = INCBIN_U32("graphics/battle_anims/backgrounds/new/giga_impact_player.bin.lz");
|
||||||
|
const u32 gBattleAnimBgTilemap_GigaImpactOpponent[] = INCBIN_U32("graphics/battle_anims/backgrounds/new/giga_impact_opponent.bin.lz");
|
||||||
|
const u32 gBattleAnimBgTilemap_GigaImpactContest[] = INCBIN_U32("graphics/battle_anims/backgrounds/new/giga_impact_contest.bin.lz");
|
||||||
|
const u32 gBattleAnimBgImage_GigaImpact[] = INCBIN_U32("graphics/battle_anims/backgrounds/new/giga_impact.4bpp.lz");
|
||||||
|
const u32 gBattleAnimBgPalette_GigaImpact[] = INCBIN_U32("graphics/battle_anims/backgrounds/new/giga_impact.gbapal.lz");
|
||||||
|
|
||||||
const u32 gBattleAnimBgImage_SpacialRend[] = INCBIN_U32("graphics/battle_anims/backgrounds/new/spacial_rend.4bpp.lz");
|
const u32 gBattleAnimBgImage_SpacialRend[] = INCBIN_U32("graphics/battle_anims/backgrounds/new/spacial_rend.4bpp.lz");
|
||||||
const u32 gBattleAnimBgPalette_SpacialRend[] = INCBIN_U32("graphics/battle_anims/backgrounds/new/spacial_rend.gbapal.lz");
|
const u32 gBattleAnimBgPalette_SpacialRend[] = INCBIN_U32("graphics/battle_anims/backgrounds/new/spacial_rend.gbapal.lz");
|
||||||
const u32 gBattleAnimBgTilemap_SpacialRendOpponent[] = INCBIN_U32("graphics/battle_anims/backgrounds/new/spacial_rend_opponent.bin.lz");
|
|
||||||
const u32 gBattleAnimBgTilemap_SpacialRendPlayer[] = INCBIN_U32("graphics/battle_anims/backgrounds/new/spacial_rend_player.bin.lz");
|
|
||||||
|
|
||||||
const u32 gBattleAnimBgPalette_SludgeWave[] = INCBIN_U32("graphics/battle_anims/backgrounds/new/sludge_wave.gbapal.lz");
|
const u32 gBattleAnimBgPalette_SludgeWave[] = INCBIN_U32("graphics/battle_anims/backgrounds/new/sludge_wave.gbapal.lz");
|
||||||
|
|
||||||
@ -1450,14 +1453,6 @@ const u32 gBattleAnimBgTilemap_FocusBlast[] = INCBIN_U32("graphics/battle_anims/
|
|||||||
|
|
||||||
const u32 gBattleAnimBgPalette_GarbageFalls[] = INCBIN_U32("graphics/battle_anims/backgrounds/new/garbage_falls.gbapal.lz");
|
const u32 gBattleAnimBgPalette_GarbageFalls[] = INCBIN_U32("graphics/battle_anims/backgrounds/new/garbage_falls.gbapal.lz");
|
||||||
|
|
||||||
const u32 gBattleAnimBgImage_GigaImpactOpponent[] = INCBIN_U32("graphics/battle_anims/backgrounds/new/giga_impact_opponent.4bpp.lz");
|
|
||||||
const u32 gBattleAnimBgPalette_GigaImpactOpponent[] = INCBIN_U32("graphics/battle_anims/backgrounds/new/giga_impact_opponent.gbapal.lz");
|
|
||||||
const u32 gBattleAnimBgTilemap_GigaImpactOpponent[] = INCBIN_U32("graphics/battle_anims/backgrounds/new/giga_impact_opponent.bin.lz");
|
|
||||||
|
|
||||||
const u32 gBattleAnimBgImage_GigaImpactPlayer[] = INCBIN_U32("graphics/battle_anims/backgrounds/new/giga_impact_player.4bpp.lz");
|
|
||||||
const u32 gBattleAnimBgPalette_GigaImpactPlayer[] = INCBIN_U32("graphics/battle_anims/backgrounds/new/giga_impact_player.gbapal.lz");
|
|
||||||
const u32 gBattleAnimBgTilemap_GigaImpactPlayer[] = INCBIN_U32("graphics/battle_anims/backgrounds/new/giga_impact_player.bin.lz");
|
|
||||||
|
|
||||||
const u32 gBattleAnimBgImage_GrassyTerrain[] = INCBIN_U32("graphics/battle_anims/backgrounds/new/grassy_terrain.4bpp.lz");
|
const u32 gBattleAnimBgImage_GrassyTerrain[] = INCBIN_U32("graphics/battle_anims/backgrounds/new/grassy_terrain.4bpp.lz");
|
||||||
const u32 gBattleAnimBgPalette_GrassyTerrain[] = INCBIN_U32("graphics/battle_anims/backgrounds/new/grassy_terrain.gbapal.lz");
|
const u32 gBattleAnimBgPalette_GrassyTerrain[] = INCBIN_U32("graphics/battle_anims/backgrounds/new/grassy_terrain.gbapal.lz");
|
||||||
const u32 gBattleAnimBgTilemap_GrassyTerrain[] = INCBIN_U32("graphics/battle_anims/backgrounds/new/grassy_terrain.bin.lz");
|
const u32 gBattleAnimBgTilemap_GrassyTerrain[] = INCBIN_U32("graphics/battle_anims/backgrounds/new/grassy_terrain.bin.lz");
|
||||||
|
@ -41,6 +41,8 @@ static bool8 IsAbilityAllowingEncounter(u8 level);
|
|||||||
// EWRAM vars
|
// EWRAM vars
|
||||||
EWRAM_DATA static u8 sWildEncountersDisabled = 0;
|
EWRAM_DATA static u8 sWildEncountersDisabled = 0;
|
||||||
EWRAM_DATA static u32 sFeebasRngValue = 0;
|
EWRAM_DATA static u32 sFeebasRngValue = 0;
|
||||||
|
EWRAM_DATA bool8 gIsFishingEncounter = 0;
|
||||||
|
EWRAM_DATA bool8 gIsSurfingEncounter = 0;
|
||||||
|
|
||||||
#include "data/wild_encounters.h"
|
#include "data/wild_encounters.h"
|
||||||
|
|
||||||
@ -652,6 +654,7 @@ bool8 StandardWildEncounter(u16 currMetaTileBehavior, u16 previousMetaTileBehavi
|
|||||||
{
|
{
|
||||||
if (TryGenerateWildMon(gWildMonHeaders[headerId].waterMonsInfo, WILD_AREA_WATER, WILD_CHECK_REPEL | WILD_CHECK_KEEN_EYE) == TRUE)
|
if (TryGenerateWildMon(gWildMonHeaders[headerId].waterMonsInfo, WILD_AREA_WATER, WILD_CHECK_REPEL | WILD_CHECK_KEEN_EYE) == TRUE)
|
||||||
{
|
{
|
||||||
|
gIsSurfingEncounter = TRUE;
|
||||||
if (TryDoDoubleWildBattle())
|
if (TryDoDoubleWildBattle())
|
||||||
{
|
{
|
||||||
struct Pokemon mon1 = gEnemyParty[0];
|
struct Pokemon mon1 = gEnemyParty[0];
|
||||||
@ -803,6 +806,7 @@ void FishingWildEncounter(u8 rod)
|
|||||||
}
|
}
|
||||||
IncrementGameStat(GAME_STAT_FISHING_CAPTURES);
|
IncrementGameStat(GAME_STAT_FISHING_CAPTURES);
|
||||||
SetPokemonAnglerSpecies(species);
|
SetPokemonAnglerSpecies(species);
|
||||||
|
gIsFishingEncounter = TRUE;
|
||||||
BattleSetup_StartWildBattle();
|
BattleSetup_StartWildBattle();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user