IsPlayerTalkingToPikachu: ld a, [wd436] and a ret z ld a, [hSpriteIndexOrTextID] cp $f ret nz call InitializePikachuTextID xor a ld [hSpriteIndexOrTextID], a ld [wd436], a ret InitializePikachuTextID: ld a, $d4 ; display ld [hSpriteIndexOrTextID], a xor a ld [wPlayerMovingDirection], a ld a, $1 ld [wAutoTextBoxDrawingControl], a call DisplayTextID xor a ld [wAutoTextBoxDrawingControl], a ret DoStarterPikachuEmotions: ld e, a ld d, 0 add hl, de add hl, de ld e, [hl] inc hl ld d, [hl] .loop ld a, [de] inc de cp $ff jr z, .done ld c, a ld b, 0 ld hl, StarterPikachuEmotionsJumptable add hl, bc add hl, bc ld a, [hli] ld h, [hl] ld l, a call JumpToAddress jr .loop .done ret StarterPikachuEmotionsJumptable: dw StarterPikachuEmotionCommand_nop ; 0 dw StarterPikachuEmotionCommand_text ; 1 dw StarterPikachuEmotionCommand_pcm ; 2 dw StarterPikachuEmotionCommand_emote ; 3 dw StarterPikachuEmotionCommand_movement ; 4 dw StarterPikachuEmotionCommand_pikapic ; 5 dw StarterPikachuEmotionCommand_subcmd ; 6 dw StarterPikachuEmotionCommand_delay ; 7 dw StarterPikachuEmotionCommand_nop2 ; 8 dw StarterPikachuEmotionCommand_9 ; 9 dw StarterPikachuEmotionCommand_nop3 ; a StarterPikachuEmotionCommand_nop: StarterPikachuEmotionCommand_nop3: ret StarterPikachuEmotionCommand_text: ld a, [de] ld l, a inc de ld a, [de] ld h, a inc de push de call PrintText pop de ret StarterPikachuEmotionCommand_pcm: ld a, [de] inc de push de ld e, a nop call PlayPikachuSoundClip_ pop de ret PlayPikachuSoundClip_: cp $ff ret z callab PlayPikachuSoundClip ret StarterPikachuEmotionCommand_emote: ld a, [wUpdateSpritesEnabled] push af ld a, $ff ld [wUpdateSpritesEnabled], a ld a, [de] inc de push de call ShowPikachuEmoteBubble pop de pop af ld [wUpdateSpritesEnabled], a ret ShowPikachuEmoteBubble: ld [wWhichEmotionBubble], a ld a, $f ; Pikachu ld [wEmotionBubbleSpriteIndex], a predef EmotionBubble ret StarterPikachuEmotionCommand_movement: ld a, [de] inc de ld l, a ld a, [de] inc de ld h, a push de ld b, BANK(DoStarterPikachuEmotions) call ApplyPikachuMovementData_ pop de ret StarterPikachuEmotionCommand_delay: ld a, [de] inc de push de ld c, a call DelayFrames pop de ret StarterPikachuEmotionCommand_subcmd: ld a, [de] inc de push de ld e, a ld d, 0 ld hl, .Subcommands add hl, de add hl, de ld a, [hli] ld h, [hl] ld l, a call JumpToAddress pop de ret .Subcommands: dw LoadPikachuSpriteIntoVRAM dw LoadFontTilePatterns dw Pikachu_LoadCurrentMapViewUpdateSpritesAndDelay3 dw WaitForTextScrollButtonPress dw PikachuPewterPokecenterCheck dw PikachuFanClubCheck dw PikachuBillsHouseCheck StarterPikachuEmotionCommand_nop2: ret StarterPikachuEmotionCommand_9: push de call StarterPikachuEmotionCommand_turnawayfromplayer call UpdateSprites pop de ret StarterPikachuEmotionCommand_turnawayfromplayer: ld a, [wPlayerFacingDirection] xor $4 ld [wPikachuFacingDirection], a ret DeletedFunction_fcffb: ; Inexplicably empty. rept 5 nop endr ret PlaySpecificPikachuEmotion: ld a, e jr load_expression TalkToPikachu: call MapSpecificPikachuExpression jr c, load_expression call GetPikaPicAnimationScriptIndex call DeletedFunction_fcffb load_expression: ld [wExpressionNumber], a ld hl, PikachuEmotionTable call DoStarterPikachuEmotions ret PikachuEmotionTable: pikaemotion_def: MACRO \1_id: dw \1 endm pikaemotion_def PikachuEmotion0 pikaemotion_def PikachuEmotion1 pikaemotion_def PikachuEmotion2 pikaemotion_def PikachuEmotion3 pikaemotion_def PikachuEmotion4 pikaemotion_def PikachuEmotion5 pikaemotion_def PikachuEmotion6 pikaemotion_def PikachuEmotion7 pikaemotion_def PikachuEmotion8 pikaemotion_def PikachuEmotion9 pikaemotion_def PikachuEmotion10 pikaemotion_def PikachuEmotion11 pikaemotion_def PikachuEmotion12 pikaemotion_def PikachuEmotion13 pikaemotion_def PikachuEmotion14 pikaemotion_def PikachuEmotion15 pikaemotion_def PikachuEmotion16 pikaemotion_def PikachuEmotion17 pikaemotion_def PikachuEmotion18 pikaemotion_def PikachuEmotion19 pikaemotion_def PikachuEmotion20 pikaemotion_def PikachuEmotion21 ; used a fishing rod pikaemotion_def PikachuEmotion22 pikaemotion_def PikachuEmotion23 pikaemotion_def PikachuEmotion24 pikaemotion_def PikachuEmotion25 pikaemotion_def PikachuEmotion26 ; wake up pikachu in pewter pokemon center pikaemotion_def PikachuEmotion27 pikaemotion_def PikachuEmotion28 pikaemotion_def PikachuEmotion29 pikaemotion_def PikachuEmotion30 pikaemotion_def PikachuEmotion31 pikaemotion_def PikachuEmotion32 pikaemotion_def PikachuEmotion33 PikachuEmotion33: db $ff MapSpecificPikachuExpression: ld a, [wCurMap] cp POKEMON_FAN_CLUB jr nz, .notFanClub ld hl, wd492 bit 7, [hl] ldpikaemotion a, PikachuEmotion29 jr z, .play_emotion call CheckPikachuFollowingPlayer ldpikaemotion a, PikachuEmotion30 jr nz, .play_emotion jr .check_pikachu_status .notFanClub ld a, [wCurMap] cp PEWTER_POKECENTER jr nz, .notPewterPokecenter call CheckPikachuFollowingPlayer ldpikaemotion a, PikachuEmotion26 jr nz, .play_emotion jr .check_pikachu_status .notPewterPokecenter callab Func_f24ae ld a, e cp $ff jr nz, .play_emotion jr .check_pikachu_status ; useless .check_pikachu_status call IsPlayerPikachuAsleepInParty ldpikaemotion a, PikachuEmotion11 jr c, .play_emotion callab CheckPikachuFaintedOrStatused ; same bank ldpikaemotion a, PikachuEmotion28 jr c, .play_emotion ld a, [wCurMap] cp POKEMONTOWER_1 jr c, .notInLavenderTower cp POKEMONTOWER_7 + 1 ldpikaemotion a, PikachuEmotion22 jr c, .play_emotion .notInLavenderTower ld a, [wd49c] and a jr z, .mood_based_emotion dec a ld c, a ld b, $0 ld hl, .Emotions add hl, bc ld a, [hl] jr .play_emotion .mood_based_emotion and a ret .play_emotion scf ret .Emotions: dpikaemotion PikachuEmotion18 dpikaemotion PikachuEmotion21 dpikaemotion PikachuEmotion23 dpikaemotion PikachuEmotion24 dpikaemotion PikachuEmotion25 IsPlayerPikachuAsleepInParty: xor a ld [wWhichPokemon], a .loop ld a, [wWhichPokemon] ld c, a ld b, 0 ld hl, wPartySpecies add hl, bc ld a, [hl] cp $ff jr z, .done cp PIKACHU jr nz, .curMonNotStarterPikachu callab IsThisPartymonStarterPikachu jr nc, .curMonNotStarterPikachu ld a, [wWhichPokemon] ld hl, wPartyMon1Status ld bc, wPartyMon2 - wPartyMon1 call AddNTimes ld a, [hl] and SLP jr z, .done jr .curMonSleepingPikachu .curMonNotStarterPikachu ld a, [wWhichPokemon] cp PARTY_LENGTH - 1 jr z, .done inc a ld [wWhichPokemon], a jr .loop .curMonSleepingPikachu scf ret .done and a ret INCLUDE "data/pikachu_emotions.asm" PikachuWalksToNurseJoy: ld a, $40 ld [h_0xFFFC], a call LoadPikachuSpriteIntoVRAM call .GetMovementData and a jr z, .skip call ApplyPikachuMovementData .skip xor a ld [h_0xFFFC], a ret .GetMovementData: ld a, [wPikachuMapY] ld e, a ld a, [wPikachuMapX] ld d, a ld a, [wYCoord] add 4 cp e jr z, .pikachu_at_same_y_as_player jr nc, .pikachu_above_player ld hl, .PikaMovementData1 ld a, 1 ret .pikachu_above_player xor a ret .pikachu_at_same_y_as_player ld a, [wXCoord] add 4 cp d jr c, .pikachu_to_right_of_player ld hl, .PikaMovementData2 ld a, 2 ret .pikachu_to_right_of_player ld hl, .PikaMovementData3 ld a, 3 ret .PikaMovementData1: db $00 ; init db $36 ; look up db $2b ; walk up left db $34 ; hop up right db $3f ; ret .PikaMovementData2: db $00 ; init db $36 ; look up db $34 ; hop up right db $3f ; ret .PikaMovementData3: db $00 ; init db $36 ; look up db $33 ; hop up left db $3f ; ret