diff options
-rw-r--r-- | asm/pokemon_special_anim.s | 1295 | ||||
-rw-r--r-- | data/pokemon_special_anim.s | 7 | ||||
-rw-r--r-- | include/pokemon_special_anim_internal.h | 2 | ||||
-rw-r--r-- | include/strings.h | 2 | ||||
-rw-r--r-- | ld_script.txt | 1 | ||||
-rw-r--r-- | src/pokemon_special_anim_scene.c | 418 | ||||
-rw-r--r-- | sym_bss.txt | 9 |
7 files changed, 420 insertions, 1314 deletions
diff --git a/asm/pokemon_special_anim.s b/asm/pokemon_special_anim.s deleted file mode 100644 index 29241bf2b..000000000 --- a/asm/pokemon_special_anim.s +++ /dev/null @@ -1,1295 +0,0 @@ - .include "asm/macros.inc" - .include "constants/constants.inc" - - .syntax unified - - .text - - thumb_func_start sub_811E06C -sub_811E06C: @ 811E06C - push {r4-r7,lr} - mov r7, r8 - push {r7} - adds r3, r0, 0 - adds r5, r1, 0 - lsls r2, 24 - lsrs r2, 24 - mov r8, r2 - cmp r2, 0x3 - bne _0811E088 - movs r0, 0x78 - strh r0, [r5, 0x20] - ldrh r0, [r3, 0x8] - b _0811E08E -_0811E088: - movs r0, 0x78 - strh r0, [r5, 0x20] - ldrh r0, [r3, 0x6] -_0811E08E: - strh r0, [r5, 0x22] - ldrh r0, [r5, 0x20] - adds r0, 0x4 - strh r0, [r5, 0x20] - ldrh r0, [r5, 0x22] - adds r0, 0x4 - strh r0, [r5, 0x22] - bl sub_811D110 - lsls r0, 16 - lsrs r6, r0, 16 - bl sub_811D120 - adds r7, r0, 0 - bl sub_811D100 - lsls r0, 24 - lsrs r0, 24 - cmp r0, 0x4 - bne _0811E0CC - adds r0, r6, 0 - adds r1, r7, 0 - movs r2, 0 - bl sub_812EA78 - lsls r0, 24 - lsrs r4, r0, 24 - adds r0, r6, 0 - adds r1, r7, 0 - movs r2, 0x1 - b _0811E0E0 -_0811E0CC: - adds r0, r6, 0 - adds r1, r7, 0 - movs r2, 0x3 - bl sub_812EA78 - lsls r0, 24 - lsrs r4, r0, 24 - adds r0, r6, 0 - adds r1, r7, 0 - movs r2, 0x4 -_0811E0E0: - bl sub_812EA78 - lsls r0, 24 - lsrs r0, 24 - cmp r4, 0xFF - bne _0811E0EE - movs r4, 0 -_0811E0EE: - cmp r0, 0xFF - bne _0811E0F4 - movs r0, 0 -_0811E0F4: - strh r4, [r5, 0x3A] - strh r0, [r5, 0x3C] - adds r0, r5, 0 - mov r1, r8 - bl sub_811DB48 - pop {r3} - mov r8, r3 - pop {r4-r7} - pop {r0} - bx r0 - thumb_func_end sub_811E06C - - thumb_func_start sub_811E10C -sub_811E10C: @ 811E10C - push {r4,lr} - bl sub_811D0A8 - adds r4, r0, 0 - ldr r0, [r4, 0xC] - bl sub_811E128 - ldr r0, [r4, 0x10] - bl sub_811E128 - pop {r4} - pop {r0} - bx r0 - thumb_func_end sub_811E10C - - thumb_func_start sub_811E128 -sub_811E128: @ 811E128 - movs r1, 0 - strh r1, [r0, 0x2E] - strh r1, [r0, 0x30] - ldr r1, _0811E134 @ =sub_811E154 - str r1, [r0, 0x1C] - bx lr - .align 2, 0 -_0811E134: .4byte sub_811E154 - thumb_func_end sub_811E128 - - thumb_func_start sub_811E138 -sub_811E138: @ 811E138 - push {lr} - bl sub_811D0A8 - ldr r0, [r0, 0xC] - ldr r1, [r0, 0x1C] - ldr r0, _0811E150 @ =SpriteCallbackDummy - eors r1, r0 - negs r0, r1 - orrs r0, r1 - lsrs r0, 31 - pop {r1} - bx r1 - .align 2, 0 -_0811E150: .4byte SpriteCallbackDummy - thumb_func_end sub_811E138 - - thumb_func_start sub_811E154 -sub_811E154: @ 811E154 - push {lr} - adds r1, r0, 0 - movs r2, 0x2E - ldrsh r0, [r1, r2] - cmp r0, 0 - beq _0811E166 - cmp r0, 0x1 - beq _0811E174 - b _0811E18C -_0811E166: - ldrh r0, [r1, 0x20] - adds r0, 0x3 - strh r0, [r1, 0x20] - ldrh r0, [r1, 0x2E] - adds r0, 0x1 - strh r0, [r1, 0x2E] - b _0811E18C -_0811E174: - ldrh r0, [r1, 0x30] - adds r0, 0x1 - strh r0, [r1, 0x30] - lsls r0, 16 - asrs r0, 16 - cmp r0, 0x1E - ble _0811E18C - ldrh r0, [r1, 0x20] - subs r0, 0x3 - strh r0, [r1, 0x20] - ldr r0, _0811E190 @ =SpriteCallbackDummy - str r0, [r1, 0x1C] -_0811E18C: - pop {r0} - bx r0 - .align 2, 0 -_0811E190: .4byte SpriteCallbackDummy - thumb_func_end sub_811E154 - - thumb_func_start sub_811E194 -sub_811E194: @ 811E194 - push {r4-r6,lr} - lsls r0, 24 - lsrs r6, r0, 24 - bl sub_811D0A8 - adds r5, r0, 0 - ldrb r0, [r5, 0xA] - cmp r6, r0 - beq _0811E1F8 - ldr r0, _0811E1EC @ =sub_811D9BC - movs r1, 0x1 - bl CreateTask - adds r4, r0, 0 - lsls r4, 24 - lsrs r4, 24 - ldr r2, [r5, 0xC] - adds r0, r4, 0 - movs r1, 0x6 - bl SetWordTaskArg - ldr r2, [r5, 0x10] - adds r0, r4, 0 - movs r1, 0x9 - bl SetWordTaskArg - ldr r1, _0811E1F0 @ =gTasks - lsls r0, r4, 2 - adds r0, r4 - lsls r0, 3 - adds r1, r0, r1 - ldrb r0, [r5, 0xA] - strh r0, [r1, 0xA] - strh r6, [r1, 0xC] - movs r2, 0x1 - strh r2, [r1, 0x18] - movs r0, 0x6 - strh r0, [r1, 0x12] - ldrb r5, [r5, 0xA] - cmp r6, r5 - bls _0811E1F4 - strh r2, [r1, 0xE] - b _0811E1F8 - .align 2, 0 -_0811E1EC: .4byte sub_811D9BC -_0811E1F0: .4byte gTasks -_0811E1F4: - ldr r0, _0811E200 @ =0x0000ffff - strh r0, [r1, 0xE] -_0811E1F8: - pop {r4-r6} - pop {r0} - bx r0 - .align 2, 0 -_0811E200: .4byte 0x0000ffff - thumb_func_end sub_811E194 - - thumb_func_start sub_811E204 -sub_811E204: @ 811E204 - push {r4-r7,lr} - mov r7, r10 - mov r6, r9 - mov r5, r8 - push {r5-r7} - sub sp, 0x8 - mov r10, r0 - ldr r0, _0811E2E0 @ =gUnknown_84599B8 - bl LoadCompressedSpriteSheet - ldr r0, _0811E2E4 @ =gUnknown_84599C0 - bl LoadSpritePalette - movs r0, 0 - mov r1, r10 - strh r0, [r1, 0x2] - ldr r0, _0811E2E8 @ =gUnknown_84599B2 - str r0, [sp, 0x4] - movs r1, 0x2 - str r1, [sp] -_0811E22C: - ldr r0, [sp, 0x4] - ldrb r0, [r0] - lsls r0, 24 - asrs r0, 24 - mov r9, r0 - mov r1, r9 - adds r1, 0x78 - ldr r0, [sp, 0x4] - ldrb r0, [r0, 0x1] - lsls r0, 24 - asrs r0, 24 - mov r8, r0 - mov r0, r10 - ldrh r2, [r0, 0x8] - add r2, r8 - lsls r2, 16 - asrs r2, 16 - ldr r0, _0811E2EC @ =gUnknown_8459AEC - movs r3, 0x2 - bl CreateSprite - lsls r0, 24 - lsrs r7, r0, 24 - cmp r7, 0x40 - beq _0811E2C0 - bl sub_811D110 - adds r5, r0, 0 - lsls r5, 16 - lsrs r5, 16 - bl sub_811D120 - adds r6, r0, 0 - ldr r0, _0811E2F0 @ =gSprites - lsls r4, r7, 4 - adds r4, r7 - lsls r4, 2 - adds r4, r0 - mov r1, r9 - lsls r0, r1, 3 - strh r0, [r4, 0x34] - mov r1, r8 - lsls r0, r1, 3 - strh r0, [r4, 0x36] - adds r0, r5, 0 - adds r1, r6, 0 - movs r2, 0 - bl sub_812EAE4 - lsls r0, 24 - asrs r0, 24 - movs r1, 0x3 - bl sub_811DAC0 - ldrh r1, [r4, 0x20] - adds r0, r1 - strh r0, [r4, 0x20] - adds r0, r5, 0 - adds r1, r6, 0 - movs r2, 0x1 - bl sub_812EAE4 - lsls r0, 24 - asrs r0, 24 - movs r1, 0x3 - bl sub_811DAC0 - ldrh r1, [r4, 0x22] - adds r0, r1 - strh r0, [r4, 0x22] - mov r1, r10 - ldrh r0, [r1, 0x2] - adds r0, 0x1 - strh r0, [r1, 0x2] -_0811E2C0: - ldr r0, [sp, 0x4] - adds r0, 0x2 - str r0, [sp, 0x4] - ldr r1, [sp] - subs r1, 0x1 - str r1, [sp] - cmp r1, 0 - bge _0811E22C - add sp, 0x8 - pop {r3-r5} - mov r8, r3 - mov r9, r4 - mov r10, r5 - pop {r4-r7} - pop {r0} - bx r0 - .align 2, 0 -_0811E2E0: .4byte gUnknown_84599B8 -_0811E2E4: .4byte gUnknown_84599C0 -_0811E2E8: .4byte gUnknown_84599B2 -_0811E2EC: .4byte gUnknown_8459AEC -_0811E2F0: .4byte gSprites - thumb_func_end sub_811E204 - - thumb_func_start sub_811E2F4 -sub_811E2F4: @ 811E2F4 - push {lr} - bl sub_811D0A8 - ldrb r0, [r0, 0x2] - pop {r1} - bx r1 - thumb_func_end sub_811E2F4 - - thumb_func_start sub_811E300 -sub_811E300: @ 811E300 - push {r4,lr} - adds r4, r0, 0 - ldrh r0, [r4, 0x2E] - adds r0, 0x1 - strh r0, [r4, 0x2E] - lsls r0, 16 - asrs r0, 16 - cmp r0, 0x9 - bgt _0811E330 - ldrh r0, [r4, 0x34] - ldrh r1, [r4, 0x30] - adds r0, r1 - strh r0, [r4, 0x30] - ldrh r1, [r4, 0x36] - ldrh r2, [r4, 0x32] - adds r1, r2 - strh r1, [r4, 0x32] - lsls r0, 16 - asrs r0, 20 - strh r0, [r4, 0x24] - lsls r1, 16 - asrs r1, 20 - strh r1, [r4, 0x26] - b _0811E340 -_0811E330: - bl sub_811D0A8 - ldrh r1, [r0, 0x2] - subs r1, 0x1 - strh r1, [r0, 0x2] - adds r0, r4, 0 - bl DestroySprite -_0811E340: - pop {r4} - pop {r0} - bx r0 - thumb_func_end sub_811E300 - - thumb_func_start sub_811E348 -sub_811E348: @ 811E348 - push {r4,lr} - bl sub_811E588 - ldr r0, _0811E37C @ =sub_811E3B4 - movs r1, 0x1 - bl CreateTask - adds r4, r0, 0 - lsls r4, 24 - lsrs r4, 24 - ldr r2, _0811E380 @ =0x78865321 - adds r0, r4, 0 - movs r1, 0x3 - bl SetWordTaskArg - ldr r1, _0811E384 @ =gTasks - lsls r0, r4, 2 - adds r0, r4 - lsls r0, 3 - adds r0, r1 - movs r1, 0xE0 - strh r1, [r0, 0x12] - pop {r4} - pop {r0} - bx r0 - .align 2, 0 -_0811E37C: .4byte sub_811E3B4 -_0811E380: .4byte 0x78865321 -_0811E384: .4byte gTasks - thumb_func_end sub_811E348 - - thumb_func_start sub_811E388 -sub_811E388: @ 811E388 - push {lr} - ldr r0, _0811E3AC @ =sub_811E3B4 - bl FindTaskIdByFunc - lsls r0, 24 - lsrs r2, r0, 24 - cmp r2, 0xFF - beq _0811E3A6 - ldr r0, _0811E3B0 @ =gTasks - lsls r1, r2, 2 - adds r1, r2 - lsls r1, 3 - adds r1, r0 - movs r0, 0x1 - strh r0, [r1, 0x8] -_0811E3A6: - pop {r0} - bx r0 - .align 2, 0 -_0811E3AC: .4byte sub_811E3B4 -_0811E3B0: .4byte gTasks - thumb_func_end sub_811E388 - - thumb_func_start sub_811E3B4 -sub_811E3B4: @ 811E3B4 - push {r4-r7,lr} - mov r7, r10 - mov r6, r9 - mov r5, r8 - push {r5-r7} - sub sp, 0x4 - lsls r0, 24 - lsrs r6, r0, 24 - lsls r0, r6, 2 - adds r0, r6 - lsls r0, 3 - ldr r1, _0811E3DC @ =gTasks+0x8 - adds r5, r0, r1 - movs r1, 0 - ldrsh r0, [r5, r1] - cmp r0, 0 - beq _0811E3E0 - cmp r0, 0x1 - beq _0811E4CE - b _0811E4DC - .align 2, 0 -_0811E3DC: .4byte gTasks+0x8 -_0811E3E0: - ldrh r0, [r5, 0x2] - movs r3, 0x2 - ldrsh r2, [r5, r3] - mov r9, r2 - cmp r2, 0 - bne _0811E4C8 - bl sub_811D0A8 - ldr r0, [r0, 0x10] - movs r4, 0x20 - ldrsh r2, [r0, r4] - movs r3, 0x24 - ldrsh r1, [r0, r3] - adds r2, r1 - str r2, [sp] - movs r4, 0x22 - ldrsh r1, [r0, r4] - movs r2, 0x26 - ldrsh r0, [r0, r2] - adds r1, r0 - mov r10, r1 - adds r0, r6, 0 - bl sub_811E4EC - lsls r0, 16 - lsrs r0, 16 - movs r1, 0x15 - bl __umodsi3 - lsls r0, 16 - lsrs r0, 16 - adds r0, 0x46 - ldr r3, _0811E4BC @ =gSineTable - movs r4, 0xA - ldrsh r2, [r5, r4] - adds r1, r2, 0 - adds r1, 0x40 - lsls r1, 1 - adds r1, r3 - movs r4, 0 - ldrsh r1, [r1, r4] - muls r1, r0 - lsrs r1, 8 - ldr r4, [sp] - adds r4, r1 - mov r8, r4 - lsls r2, 1 - adds r2, r3 - movs r3, 0 - ldrsh r1, [r2, r3] - muls r0, r1 - lsrs r0, 8 - mov r4, r10 - adds r7, r4, r0 - ldrh r0, [r5, 0xA] - adds r0, 0x4C - movs r1, 0xFF - ands r0, r1 - strh r0, [r5, 0xA] - ldr r0, _0811E4C0 @ =gUnknown_8459B30 - mov r2, r8 - lsls r1, r2, 16 - asrs r1, 16 - lsls r2, r7, 16 - asrs r2, 16 - movs r3, 0 - bl CreateSprite - lsls r0, 24 - lsrs r1, r0, 24 - cmp r1, 0x40 - beq _0811E4A4 - ldr r0, _0811E4C4 @ =gSprites - lsls r4, r1, 4 - adds r4, r1 - lsls r4, 2 - adds r4, r0 - mov r3, r9 - strh r3, [r4, 0x2E] - adds r0, r6, 0 - bl sub_811E4EC - movs r1, 0x1 - ands r1, r0 - adds r1, 0x6 - strh r1, [r4, 0x30] - mov r0, r8 - strh r0, [r4, 0x32] - strh r7, [r4, 0x34] - mov r1, sp - ldrh r1, [r1] - strh r1, [r4, 0x36] - mov r2, r10 - strh r2, [r4, 0x38] - strh r6, [r4, 0x3A] - ldrh r0, [r5, 0x4] - adds r0, 0x1 - strh r0, [r5, 0x4] -_0811E4A4: - ldrh r0, [r5, 0xC] - adds r0, 0x1 - strh r0, [r5, 0xC] - lsls r0, 16 - asrs r0, 16 - cmp r0, 0x2F - ble _0811E4DC - ldrh r0, [r5] - adds r0, 0x1 - strh r0, [r5] - b _0811E4DC - .align 2, 0 -_0811E4BC: .4byte gSineTable -_0811E4C0: .4byte gUnknown_8459B30 -_0811E4C4: .4byte gSprites -_0811E4C8: - subs r0, 0x1 - strh r0, [r5, 0x2] - b _0811E4DC -_0811E4CE: - movs r3, 0x4 - ldrsh r0, [r5, r3] - cmp r0, 0 - bne _0811E4DC - adds r0, r6, 0 - bl DestroyTask -_0811E4DC: - add sp, 0x4 - pop {r3-r5} - mov r8, r3 - mov r9, r4 - mov r10, r5 - pop {r4-r7} - pop {r0} - bx r0 - thumb_func_end sub_811E3B4 - - thumb_func_start sub_811E4EC -sub_811E4EC: @ 811E4EC - push {r4,r5,lr} - adds r4, r0, 0 - lsls r4, 24 - lsrs r4, 24 - adds r0, r4, 0 - movs r1, 0x3 - bl GetWordTaskArg - adds r5, r0, 0 - ldr r0, _0811E518 @ =0x41c64e6d - muls r0, r5 - ldr r1, _0811E51C @ =0x00006073 - adds r5, r0, r1 - adds r0, r4, 0 - movs r1, 0x3 - adds r2, r5, 0 - bl SetWordTaskArg - lsrs r0, r5, 16 - pop {r4,r5} - pop {r1} - bx r1 - .align 2, 0 -_0811E518: .4byte 0x41c64e6d -_0811E51C: .4byte 0x00006073 - thumb_func_end sub_811E4EC - - thumb_func_start sub_811E520 -sub_811E520: @ 811E520 - push {r4,r5,lr} - adds r4, r0, 0 - ldrh r0, [r4, 0x30] - ldrh r1, [r4, 0x2E] - adds r0, r1 - strh r0, [r4, 0x2E] - lsls r0, 16 - asrs r0, 16 - cmp r0, 0xFF - ble _0811E554 - ldr r2, _0811E550 @ =gTasks - movs r5, 0x3A - ldrsh r1, [r4, r5] - lsls r0, r1, 2 - adds r0, r1 - lsls r0, 3 - adds r0, r2 - ldrh r1, [r0, 0xC] - subs r1, 0x1 - strh r1, [r0, 0xC] - adds r0, r4, 0 - bl DestroySprite - b _0811E582 - .align 2, 0 -_0811E550: .4byte gTasks -_0811E554: - movs r1, 0x36 - ldrsh r0, [r4, r1] - movs r2, 0x32 - ldrsh r1, [r4, r2] - subs r0, r1 - movs r5, 0x2E - ldrsh r3, [r4, r5] - adds r2, r0, 0 - muls r2, r3 - movs r1, 0x38 - ldrsh r0, [r4, r1] - movs r5, 0x34 - ldrsh r1, [r4, r5] - subs r0, r1 - muls r0, r3 - asrs r2, 8 - ldrh r1, [r4, 0x32] - adds r2, r1 - strh r2, [r4, 0x20] - asrs r0, 8 - ldrh r2, [r4, 0x34] - adds r0, r2 - strh r0, [r4, 0x22] -_0811E582: - pop {r4,r5} - pop {r0} - bx r0 - thumb_func_end sub_811E520 - - thumb_func_start sub_811E588 -sub_811E588: @ 811E588 - push {lr} - ldr r0, _0811E59C @ =gUnknown_84599C8 - bl LoadCompressedSpriteSheet - ldr r0, _0811E5A0 @ =gUnknown_84599D0 - bl LoadSpritePalette - pop {r0} - bx r0 - .align 2, 0 -_0811E59C: .4byte gUnknown_84599C8 -_0811E5A0: .4byte gUnknown_84599D0 - thumb_func_end sub_811E588 - - thumb_func_start sub_811E5A4 -sub_811E5A4: @ 811E5A4 - push {lr} - ldr r0, _0811E5B4 @ =sub_811E3B4 - bl FuncIsActiveTask - lsls r0, 24 - lsrs r0, 24 - pop {r1} - bx r1 - .align 2, 0 -_0811E5B4: .4byte sub_811E3B4 - thumb_func_end sub_811E5A4 - - thumb_func_start sub_811E5B8 -sub_811E5B8: @ 811E5B8 - push {r4-r7,lr} - mov r7, r10 - mov r6, r9 - mov r5, r8 - push {r5-r7} - adds r5, r0, 0 - adds r6, r1, 0 - mov r8, r2 - mov r9, r3 - ldr r0, [sp, 0x20] - mov r10, r0 - ldr r0, [sp, 0x24] - lsls r5, 16 - lsrs r5, 16 - lsls r6, 16 - lsrs r6, 16 - mov r1, r8 - lsls r1, 16 - lsrs r1, 16 - mov r8, r1 - mov r1, r9 - lsls r1, 16 - lsrs r1, 16 - mov r9, r1 - mov r1, r10 - lsls r1, 16 - lsrs r1, 16 - mov r10, r1 - lsls r0, 16 - lsrs r7, r0, 16 - ldr r0, _0811E664 @ =gUnknown_3002030 - mov r1, r8 - strh r1, [r0, 0x6] - ldr r1, _0811E668 @ =gUnknown_8459888 - str r1, [r0] - ldr r1, [r1] - lsrs r1, 8 - strh r1, [r0, 0x4] - ldr r4, _0811E66C @ =gUnknown_3002038 - ldr r1, _0811E670 @ =gUnknown_8459868 - str r1, [r4] - mov r1, r9 - strh r1, [r4, 0x4] - bl LoadCompressedSpriteSheet - adds r0, r4, 0 - bl LoadSpritePalette - ldr r0, _0811E674 @ =sub_811E694 - movs r1, 0 - bl CreateTask - lsls r0, 24 - lsrs r0, 24 - ldr r2, _0811E678 @ =gTasks - lsls r1, r0, 2 - adds r1, r0 - lsls r1, 3 - adds r1, r2 - subs r5, 0x20 - strh r5, [r1, 0x10] - adds r6, 0x20 - strh r6, [r1, 0x12] - mov r0, r8 - strh r0, [r1, 0x14] - mov r0, r9 - strh r0, [r1, 0x16] - mov r0, r10 - strh r0, [r1, 0x18] - strh r7, [r1, 0x1A] - movs r1, 0xFC - lsls r1, 6 - movs r0, 0x50 - bl SetGpuReg - ldr r1, _0811E67C @ =0x0000060c - movs r0, 0x52 - bl SetGpuReg - pop {r3-r5} - mov r8, r3 - mov r9, r4 - mov r10, r5 - pop {r4-r7} - pop {r0} - bx r0 - .align 2, 0 -_0811E664: .4byte gUnknown_3002030 -_0811E668: .4byte gUnknown_8459888 -_0811E66C: .4byte gUnknown_3002038 -_0811E670: .4byte gUnknown_8459868 -_0811E674: .4byte sub_811E694 -_0811E678: .4byte gTasks -_0811E67C: .4byte 0x0000060c - thumb_func_end sub_811E5B8 - - thumb_func_start sub_811E680 -sub_811E680: @ 811E680 - push {lr} - ldr r0, _0811E690 @ =sub_811E694 - bl FuncIsActiveTask - lsls r0, 24 - lsrs r0, 24 - pop {r1} - bx r1 - .align 2, 0 -_0811E690: .4byte sub_811E694 - thumb_func_end sub_811E680 - - thumb_func_start sub_811E694 -sub_811E694: @ 811E694 - push {r4,r5,lr} - lsls r0, 24 - lsrs r5, r0, 24 - lsls r0, r5, 2 - adds r0, r5 - lsls r0, 3 - ldr r1, _0811E6B4 @ =gTasks+0x8 - adds r4, r0, r1 - movs r0, 0 - ldrsh r1, [r4, r0] - cmp r1, 0 - beq _0811E6B8 - cmp r1, 0x1 - beq _0811E6EE - b _0811E708 - .align 2, 0 -_0811E6B4: .4byte gTasks+0x8 -_0811E6B8: - ldrh r2, [r4, 0x6] - movs r3, 0x6 - ldrsh r0, [r4, r3] - cmp r0, 0 - bne _0811E6DE - adds r0, r2, 0x1 - strh r0, [r4, 0x6] - adds r0, r5, 0 - adds r1, r4, 0 - bl sub_811E710 - movs r1, 0x4 - ldrsh r0, [r4, r1] - cmp r0, 0x11 - ble _0811E708 - ldrh r0, [r4] - adds r0, 0x1 - strh r0, [r4] - b _0811E708 -_0811E6DE: - adds r0, r2, 0x1 - strh r0, [r4, 0x6] - lsls r0, 16 - asrs r0, 16 - cmp r0, 0x2 - bne _0811E708 - strh r1, [r4, 0x6] - b _0811E708 -_0811E6EE: - movs r3, 0x2 - ldrsh r0, [r4, r3] - cmp r0, 0 - bne _0811E708 - ldrh r0, [r4, 0xC] - bl FreeSpriteTilesByTag - ldrh r0, [r4, 0xE] - bl FreeSpritePaletteByTag - adds r0, r5, 0 - bl DestroyTask -_0811E708: - pop {r4,r5} - pop {r0} - bx r0 - thumb_func_end sub_811E694 - - thumb_func_start sub_811E710 -sub_811E710: @ 811E710 - push {r4-r6,lr} - sub sp, 0x18 - adds r4, r1, 0 - lsls r0, 24 - lsrs r6, r0, 24 - mov r1, sp - ldr r0, _0811E7A4 @ =gUnknown_8459ACC - ldm r0!, {r2,r3,r5} - stm r1!, {r2,r3,r5} - ldm r0!, {r2,r3,r5} - stm r1!, {r2,r3,r5} - mov r1, sp - ldrh r0, [r4, 0xC] - strh r0, [r1] - ldrh r0, [r4, 0xE] - strh r0, [r1, 0x2] - ldrh r0, [r4, 0x4] - adds r0, 0x1 - strh r0, [r4, 0x4] - movs r0, 0x4 - ldrsh r1, [r4, r0] - movs r0, 0xDB - muls r1, r0 - movs r5, 0x3F - ands r1, r5 - ldrh r2, [r4, 0x8] - adds r1, r2 - lsls r1, 16 - asrs r1, 16 - movs r3, 0xA - ldrsh r2, [r4, r3] - ldrb r3, [r4, 0x12] - mov r0, sp - bl CreateSprite - lsls r0, 24 - lsrs r1, r0, 24 - cmp r1, 0x40 - beq _0811E79A - ldr r0, _0811E7A8 @ =gSprites - lsls r2, r1, 4 - adds r2, r1 - lsls r2, 2 - adds r2, r0 - movs r0, 0x3 - ldrb r1, [r4, 0x10] - ands r1, r0 - lsls r1, 2 - ldrb r3, [r2, 0x5] - movs r0, 0xD - negs r0, r0 - ands r0, r3 - orrs r0, r1 - strb r0, [r2, 0x5] - movs r0, 0 - strh r0, [r2, 0x30] - movs r0, 0x4 - ldrsh r1, [r4, r0] - ldr r0, _0811E7AC @ =0x41c64e6d - muls r0, r1 - ldr r1, _0811E7B0 @ =0x00006073 - adds r0, r1 - ands r0, r5 - adds r0, 0x20 - strh r0, [r2, 0x32] - strh r6, [r2, 0x3C] - ldrh r0, [r4, 0x2] - adds r0, 0x1 - strh r0, [r4, 0x2] -_0811E79A: - add sp, 0x18 - pop {r4-r6} - pop {r0} - bx r0 - .align 2, 0 -_0811E7A4: .4byte gUnknown_8459ACC -_0811E7A8: .4byte gSprites -_0811E7AC: .4byte 0x41c64e6d -_0811E7B0: .4byte 0x00006073 - thumb_func_end sub_811E710 - - thumb_func_start sub_811E7B4 -sub_811E7B4: @ 811E7B4 - push {lr} - adds r3, r0, 0 - ldrh r0, [r3, 0x30] - ldrh r1, [r3, 0x32] - subs r0, r1 - strh r0, [r3, 0x30] - lsls r0, 16 - asrs r0, 20 - strh r0, [r3, 0x26] - movs r1, 0x40 - negs r1, r1 - cmp r0, r1 - bge _0811E7E8 - ldr r2, _0811E7EC @ =gTasks - movs r0, 0x3C - ldrsh r1, [r3, r0] - lsls r0, r1, 2 - adds r0, r1 - lsls r0, 3 - adds r0, r2 - ldrh r1, [r0, 0xA] - subs r1, 0x1 - strh r1, [r0, 0xA] - adds r0, r3, 0 - bl DestroySprite -_0811E7E8: - pop {r0} - bx r0 - .align 2, 0 -_0811E7EC: .4byte gTasks - thumb_func_end sub_811E7B4 - - thumb_func_start DrawLevelUpWindowPg1 -DrawLevelUpWindowPg1: @ 811E7F0 - push {r4-r7,lr} - mov r7, r10 - mov r6, r9 - mov r5, r8 - push {r5-r7} - sub sp, 0x30 - mov r8, r0 - adds r6, r1, 0 - adds r5, r2, 0 - adds r4, r3, 0 - ldr r3, [sp, 0x50] - ldr r0, [sp, 0x54] - mov r9, r0 - lsls r4, 24 - lsrs r4, 24 - lsls r3, 24 - lsrs r3, 24 - mov r1, r9 - lsls r1, 24 - lsrs r1, 24 - mov r9, r1 - mov r0, r8 - lsls r0, 24 - lsrs r0, 24 - mov r8, r0 - lsls r1, r4, 4 - orrs r1, r4 - lsls r1, 24 - lsrs r1, 24 - str r3, [sp, 0x2C] - bl FillWindowPixelBuffer - add r2, sp, 0xC - ldrh r0, [r5] - ldrh r1, [r6] - subs r0, r1 - strh r0, [r2] - ldrh r0, [r5, 0x2] - ldrh r1, [r6, 0x2] - subs r0, r1 - strh r0, [r2, 0x2] - ldrh r0, [r5, 0x4] - ldrh r1, [r6, 0x4] - subs r0, r1 - strh r0, [r2, 0x4] - ldrh r0, [r5, 0x8] - ldrh r1, [r6, 0x8] - subs r0, r1 - strh r0, [r2, 0x6] - ldrh r0, [r5, 0xA] - ldrh r1, [r6, 0xA] - subs r0, r1 - strh r0, [r2, 0x8] - ldrh r0, [r5, 0x6] - ldrh r1, [r6, 0x6] - subs r0, r1 - strh r0, [r2, 0xA] - add r0, sp, 0x24 - strb r4, [r0] - ldr r3, [sp, 0x2C] - strb r3, [r0, 0x1] - mov r1, r9 - strb r1, [r0, 0x2] - movs r7, 0 - mov r1, sp - adds r1, 0x19 - str r1, [sp, 0x28] - mov r10, r0 - movs r0, 0x1 - negs r0, r0 - mov r9, r0 - add r6, sp, 0x18 -_0811E880: - lsls r0, r7, 4 - subs r0, r7 - lsls r0, 24 - lsrs r5, r0, 24 - mov r1, r10 - str r1, [sp] - mov r0, r9 - str r0, [sp, 0x4] - ldr r1, _0811E930 @ =gUnknown_8459B48 - lsls r0, r7, 2 - adds r0, r1 - ldr r0, [r0] - str r0, [sp, 0x8] - mov r0, r8 - movs r1, 0x2 - movs r2, 0 - adds r3, r5, 0 - bl AddTextPrinterParameterized3 - lsls r0, r7, 1 - mov r4, sp - adds r4, r0 - adds r4, 0xC - movs r1, 0 - ldrsh r0, [r4, r1] - ldr r1, _0811E934 @ =gUnknown_841B2E5 - cmp r0, 0 - blt _0811E8BA - ldr r1, _0811E938 @ =gUnknown_841B2DC -_0811E8BA: - adds r0, r6, 0 - bl StringCopy - mov r0, r10 - str r0, [sp] - mov r1, r9 - str r1, [sp, 0x4] - str r6, [sp, 0x8] - mov r0, r8 - movs r1, 0x2 - movs r2, 0x38 - adds r3, r5, 0 - bl AddTextPrinterParameterized3 - movs r0, 0 - strb r0, [r6] - movs r0, 0 - ldrsh r1, [r4, r0] - adds r0, r1, 0 - cmp r1, 0 - bge _0811E8E6 - negs r0, r1 -_0811E8E6: - movs r4, 0x6 - cmp r0, 0x9 - bgt _0811E8EE - movs r4, 0xC -_0811E8EE: - cmp r1, 0 - bge _0811E8F4 - negs r1, r1 -_0811E8F4: - ldr r0, [sp, 0x28] - movs r2, 0 - movs r3, 0x2 - bl ConvertIntToDecimalStringN - adds r2, r4, 0 - adds r2, 0x38 - mov r1, r10 - str r1, [sp] - mov r0, r9 - str r0, [sp, 0x4] - str r6, [sp, 0x8] - mov r0, r8 - movs r1, 0x2 - adds r3, r5, 0 - bl AddTextPrinterParameterized3 - adds r0, r7, 0x1 - lsls r0, 16 - lsrs r7, r0, 16 - cmp r7, 0x5 - bls _0811E880 - add sp, 0x30 - pop {r3-r5} - mov r8, r3 - mov r9, r4 - mov r10, r5 - pop {r4-r7} - pop {r0} - bx r0 - .align 2, 0 -_0811E930: .4byte gUnknown_8459B48 -_0811E934: .4byte gUnknown_841B2E5 -_0811E938: .4byte gUnknown_841B2DC - thumb_func_end DrawLevelUpWindowPg1 - - thumb_func_start DrawLevelUpWindowPg2 -DrawLevelUpWindowPg2: @ 811E93C - push {r4-r7,lr} - mov r7, r10 - mov r6, r9 - mov r5, r8 - push {r5-r7} - sub sp, 0x2C - mov r8, r0 - adds r5, r1, 0 - adds r4, r2, 0 - adds r6, r3, 0 - ldr r2, [sp, 0x4C] - lsls r4, 24 - lsrs r4, 24 - lsls r6, 24 - lsrs r6, 24 - lsls r2, 24 - lsrs r2, 24 - lsls r0, 24 - lsrs r0, 24 - mov r8, r0 - lsls r1, r4, 4 - orrs r1, r4 - lsls r1, 24 - lsrs r1, 24 - str r2, [sp, 0x28] - bl FillWindowPixelBuffer - add r1, sp, 0xC - ldrh r0, [r5] - strh r0, [r1] - ldrh r0, [r5, 0x2] - strh r0, [r1, 0x2] - ldrh r0, [r5, 0x4] - strh r0, [r1, 0x4] - ldrh r0, [r5, 0x8] - strh r0, [r1, 0x6] - ldrh r0, [r5, 0xA] - strh r0, [r1, 0x8] - ldrh r0, [r5, 0x6] - strh r0, [r1, 0xA] - add r0, sp, 0x24 - strb r4, [r0] - strb r6, [r0, 0x1] - ldr r2, [sp, 0x28] - strb r2, [r0, 0x2] - movs r6, 0 - add r1, sp, 0x18 - mov r9, r1 - mov r7, r8 - mov r10, r0 - movs r2, 0x1 - negs r2, r2 - mov r8, r2 -_0811E9A6: - lsls r1, r6, 1 - mov r0, sp - adds r0, r1 - adds r0, 0xC - movs r2, 0 - ldrsh r0, [r0, r2] - movs r4, 0x3 - cmp r0, 0x63 - bgt _0811E9C0 - movs r4, 0x1 - cmp r0, 0x9 - ble _0811E9C0 - movs r4, 0x2 -_0811E9C0: - mov r0, sp - adds r0, r1 - adds r0, 0xC - movs r2, 0 - ldrsh r1, [r0, r2] - mov r0, r9 - movs r2, 0 - adds r3, r4, 0 - bl ConvertIntToDecimalStringN - movs r0, 0x4 - subs r0, r4 - lsls r4, r0, 1 - adds r4, r0 - lsls r4, 17 - lsrs r4, 16 - lsls r5, r6, 4 - subs r5, r6 - lsls r5, 24 - lsrs r5, 24 - mov r0, r10 - str r0, [sp] - mov r1, r8 - str r1, [sp, 0x4] - ldr r1, _0811EA40 @ =gUnknown_8459B48 - lsls r0, r6, 2 - adds r0, r1 - ldr r0, [r0] - str r0, [sp, 0x8] - adds r0, r7, 0 - movs r1, 0x2 - movs r2, 0 - adds r3, r5, 0 - bl AddTextPrinterParameterized3 - adds r4, 0x38 - lsls r4, 24 - lsrs r4, 24 - mov r2, r10 - str r2, [sp] - mov r0, r8 - str r0, [sp, 0x4] - mov r1, r9 - str r1, [sp, 0x8] - adds r0, r7, 0 - movs r1, 0x2 - adds r2, r4, 0 - adds r3, r5, 0 - bl AddTextPrinterParameterized3 - adds r0, r6, 0x1 - lsls r0, 16 - lsrs r6, r0, 16 - cmp r6, 0x5 - bls _0811E9A6 - add sp, 0x2C - pop {r3-r5} - mov r8, r3 - mov r9, r4 - mov r10, r5 - pop {r4-r7} - pop {r0} - bx r0 - .align 2, 0 -_0811EA40: .4byte gUnknown_8459B48 - thumb_func_end DrawLevelUpWindowPg2 - - .align 2, 0 @ Don't pad with nop. diff --git a/data/pokemon_special_anim.s b/data/pokemon_special_anim.s deleted file mode 100644 index 7f56c11ad..000000000 --- a/data/pokemon_special_anim.s +++ /dev/null @@ -1,7 +0,0 @@ -#include "constants/region_map_sections.h" -#include "constants/flags.h" -#include "constants/moves.h" - .include "asm/macros.inc" - .include "constants/constants.inc" - .section .rodata - .align 2 diff --git a/include/pokemon_special_anim_internal.h b/include/pokemon_special_anim_internal.h index 0777d492b..3799b24c5 100644 --- a/include/pokemon_special_anim_internal.h +++ b/include/pokemon_special_anim_internal.h @@ -6,7 +6,7 @@ struct PokemonSpecialAnimScene { u16 field_0000; - u8 filler_0002[2]; + u16 field_0002; u16 field_0004; u16 field_0006; u16 field_0008; diff --git a/include/strings.h b/include/strings.h index 3fd24516d..e7f274abd 100644 --- a/include/strings.h +++ b/include/strings.h @@ -1460,5 +1460,7 @@ extern const u8 gUnknown_841B2BE[]; extern const u8 gUnknown_841B2CC[]; extern const u8 gUnknown_841B2D4[]; extern const u8 gUnknown_841B2C6[]; +extern const u8 gUnknown_841B2E5[]; +extern const u8 gUnknown_841B2DC[]; #endif //GUARD_STRINGS_H diff --git a/ld_script.txt b/ld_script.txt index 40547541f..54078ab70 100644 --- a/ld_script.txt +++ b/ld_script.txt @@ -253,7 +253,6 @@ SECTIONS { src/union_room_battle.o(.text); src/pokemon_special_anim.o(.text); src/pokemon_special_anim_scene.o(.text); - asm/pokemon_special_anim.o(.text); src/party_menu.o(.text); src/union_room_chat.o(.text); src/union_room_chat_display.o(.text); diff --git a/src/pokemon_special_anim_scene.c b/src/pokemon_special_anim_scene.c index 7184b5198..1bb3b187e 100644 --- a/src/pokemon_special_anim_scene.c +++ b/src/pokemon_special_anim_scene.c @@ -30,16 +30,22 @@ void sub_811DF14(u8 taskId, s16 *data, struct Sprite * sprite); void sub_811DFC0(struct Sprite * sprite); void sub_811E06C(struct PokemonSpecialAnimScene * scene, struct Sprite * sprite, u8 closeness); void sub_811E10C(void); +void sub_811E128(struct Sprite * sprite); bool8 sub_811E138(void); +void sub_811E154(struct Sprite * sprite); void sub_811E194(u8 a0); void sub_811E204(struct PokemonSpecialAnimScene * scene); bool8 sub_811E2F4(void); void sub_811E300(struct Sprite * sprite); void sub_811E348(struct PokemonSpecialAnimScene * scene); void sub_811E388(void); +void sub_811E3B4(u8 taskId); +u16 sub_811E4EC(u8 taskId); void sub_811E520(struct Sprite * sprite); void sub_811E588(void); bool32 sub_811E5A4(void); +void sub_811E694(u8 taskId); +void sub_811E710(u8 taskId, s16 *data); void sub_811E7B4(struct Sprite * sprite); const u16 gUnknown_845963C[] = INCBIN_U16("graphics/pokemon_special_anim/unk_845963C.gbapal"); @@ -102,8 +108,10 @@ const u16 gUnknown_84599AA[] = { 0x200 }; -const s8 gUnknown_84599B2[] = { - -8, -8, 6, -13, 8, -8 +const s8 gUnknown_84599B2[][2] = { + {-8, -8}, + { 6, -13}, + { 8, -8} }; const struct CompressedSpriteSheet gUnknown_84599B8 = { @@ -998,3 +1006,409 @@ void sub_811E040(void) gTasks[taskId].data[11] = TRUE; } } + +void sub_811E06C(struct PokemonSpecialAnimScene * scene, struct Sprite * sprite, u8 closeness) +{ + u16 species; + u32 personality; + register int r4 asm("r4"); // FIXME + u8 r0; + if (closeness == 3) + { + sprite->pos1.x = 120; + sprite->pos1.y = scene->field_0008; + } + else + { + sprite->pos1.x = 120; + sprite->pos1.y = scene->field_0006; + } + sprite->pos1.x += 4; + sprite->pos1.y += 4; + species = sub_811D110(); + personality = sub_811D120(); + if (sub_811D100() == 4) + { + r4 = sub_812EA78(species, personality, 0); + r0 = sub_812EA78(species, personality, 1); + } + else + { + r4 = sub_812EA78(species, personality, 3); + r0 = sub_812EA78(species, personality, 4); + } + if (r4 == 0xFF) + r4 = 0; + if (r0 == 0xFF) + r0 = 0; + sprite->data[6] = r4; + sprite->data[7] = r0; + sub_811DB48(sprite, closeness); +} + +void sub_811E10C(void) +{ + struct PokemonSpecialAnimScene * scene = sub_811D0A8(); + sub_811E128(scene->field_000c); + sub_811E128(scene->field_0010); +} + +void sub_811E128(struct Sprite * sprite) +{ + sprite->data[0] = 0; + sprite->data[1] = 0; + sprite->callback = sub_811E154; +} + +bool8 sub_811E138(void) +{ + struct PokemonSpecialAnimScene * scene = sub_811D0A8(); + return scene->field_000c->callback != SpriteCallbackDummy; +} + +void sub_811E154(struct Sprite * sprite) +{ + switch (sprite->data[0]) + { + case 0: + sprite->pos1.x += 3; + sprite->data[0]++; + break; + case 1: + sprite->data[1]++; + if (sprite->data[1] > 30) + { + sprite->pos1.x -= 3; + sprite->callback = SpriteCallbackDummy; + } + break; + } +} + +void sub_811E194(u8 a0) +{ + struct PokemonSpecialAnimScene * scene = sub_811D0A8(); + u8 taskId; + if (a0 != scene->field_000a) + { + taskId = CreateTask(sub_811D9BC, 1); + SetWordTaskArg(taskId, 6, (uintptr_t)scene->field_000c); + SetWordTaskArg(taskId, 9, (uintptr_t)scene->field_0010); + gTasks[taskId].data[1] = scene->field_000a; + gTasks[taskId].data[2] = a0; + gTasks[taskId].data[8] = 1; + gTasks[taskId].data[5] = 6; + if (a0 > scene->field_000a) + gTasks[taskId].data[3] = 1; + else + gTasks[taskId].data[3] = -1; + } +} + +void sub_811E204(struct PokemonSpecialAnimScene * scene) +{ + int i; + u8 spriteId; + u16 species; + u32 personality; + LoadCompressedSpriteSheet(&gUnknown_84599B8); + LoadSpritePalette(&gUnknown_84599C0); + scene->field_0002 = 0; + for (i = 0; i < 3; i++) + { + spriteId = CreateSprite(&gUnknown_8459AEC, 120 + gUnknown_84599B2[i][0], scene->field_0008 + gUnknown_84599B2[i][1], 2); + if (spriteId != MAX_SPRITES) + { + species = sub_811D110(); + personality = sub_811D120(); + gSprites[spriteId].data[3] = gUnknown_84599B2[i][0] * 8; + gSprites[spriteId].data[4] = gUnknown_84599B2[i][1] * 8; + gSprites[spriteId].pos1.x += sub_811DAC0(sub_812EAE4(species, personality, 0), 3); + gSprites[spriteId].pos1.y += sub_811DAC0(sub_812EAE4(species, personality, 1), 3); + scene->field_0002++; + } + } +} + +u8 sub_811E2F4(void) +{ + return sub_811D0A8()->field_0002; +} + +void sub_811E300(struct Sprite * sprite) +{ + sprite->data[0]++; + if (sprite->data[0] < 10) + { + sprite->data[1] += sprite->data[3]; + sprite->data[2] += sprite->data[4]; + sprite->pos2.x = sprite->data[1] >> 4; + sprite->pos2.y = sprite->data[2] >> 4; + } + else + { + sub_811D0A8()->field_0002--; + DestroySprite(sprite); + } +} + +void sub_811E348(struct PokemonSpecialAnimScene * scene) +{ + u8 taskId; + sub_811E588(); + taskId = CreateTask(sub_811E3B4, 1); + SetWordTaskArg(taskId, 3, 2022069025); + gTasks[taskId].data[5] = 224; +} + +void sub_811E388(void) +{ + u8 taskId = FindTaskIdByFunc(sub_811E3B4); + if (taskId != 0xFF) + gTasks[taskId].data[0] = 1; +} + +void sub_811E3B4(u8 taskId) +{ + s16 *data = gTasks[taskId].data; + struct Sprite * sprite; + int x; + register int y asm("r10"); // FIXME + int x2; + int y2; + int r0; + u8 spriteId; + switch (data[0]) + { + case 0: + if (data[1] == 0) + { + sprite = sub_811D0A8()->field_0010; + x = sprite->pos1.x + sprite->pos2.x; + y = sprite->pos1.y + sprite->pos2.y; + r0 = (sub_811E4EC(taskId) % 21) + 70; + x2 = x + ((u32)(gSineTable[data[5] + 0x40] * r0) >> 8); + y2 = y + ((u32)(gSineTable[data[5] ] * r0) >> 8); + data[5] += 76; + data[5] &= 0xFF; + spriteId = CreateSprite(&gUnknown_8459B30, x2, y2, 0); + if (spriteId != MAX_SPRITES) + { + gSprites[spriteId].data[0] = 0; + gSprites[spriteId].data[1] = (sub_811E4EC(taskId) & 1) + 6; + gSprites[spriteId].data[2] = x2; + gSprites[spriteId].data[3] = y2; + gSprites[spriteId].data[4] = x; + gSprites[spriteId].data[5] = y; + gSprites[spriteId].data[6] = taskId; + data[2]++; + } + data[6]++; + if (data[6] > 47) + data[0]++; + } + else + data[1]--; + break; + case 1: + if (data[2] == 0) + DestroyTask(taskId); + break; + } +} + +u16 sub_811E4EC(u8 taskId) +{ + u32 state = GetWordTaskArg(taskId, 3); + state = state * 1103515245 + 24691; + SetWordTaskArg(taskId, 3, state); + return state >> 16; +} + +void sub_811E520(struct Sprite * sprite) +{ + int x; + int y; + sprite->data[0] += sprite->data[1]; + if (sprite->data[0] > 255) + { + gTasks[sprite->data[6]].data[2]--; + DestroySprite(sprite); + } + else + { + x = (sprite->data[4] - sprite->data[2]) * sprite->data[0]; + y = (sprite->data[5] - sprite->data[3]) * sprite->data[0]; + sprite->pos1.x = (x >> 8) + sprite->data[2]; + sprite->pos1.y = (y >> 8) + sprite->data[3]; + } +} + +void sub_811E588(void) +{ + LoadCompressedSpriteSheet(&gUnknown_84599C8); + LoadSpritePalette(&gUnknown_84599D0); +} + +bool32 sub_811E5A4(void) +{ + return FuncIsActiveTask(sub_811E3B4); +} + +void sub_811E5B8(u16 a0, u16 a1, u16 a2, u16 a3, u16 a4, u16 a5) +{ + static struct CompressedSpriteSheet gUnknown_3002030; + static struct SpritePalette gUnknown_3002038; + u8 taskId; + gUnknown_3002030.tag = a2; + gUnknown_3002030.data = gUnknown_8459888; + gUnknown_3002030.size = gUnknown_8459888[0] >> 8; + gUnknown_3002038.data = gUnknown_8459868; + gUnknown_3002038.tag = a3; + LoadCompressedSpriteSheet(&gUnknown_3002030); + LoadSpritePalette(&gUnknown_3002038); + taskId = CreateTask(sub_811E694, 0); + gTasks[taskId].data[4] = a0 - 32; + gTasks[taskId].data[5] = a1 + 32; + gTasks[taskId].data[6] = a2; + gTasks[taskId].data[7] = a3; + gTasks[taskId].data[8] = a4; + gTasks[taskId].data[9] = a5; + SetGpuReg(REG_OFFSET_BLDCNT, BLDCNT_EFFECT_NONE | BLDCNT_TGT2_ALL); + SetGpuReg(REG_OFFSET_BLDALPHA, BLDALPHA_BLEND(12, 6)); +} + +bool8 sub_811E680(void) +{ + return FuncIsActiveTask(sub_811E694); +} + +void sub_811E694(u8 taskId) +{ + s16 *data = gTasks[taskId].data; + switch (data[0]) + { + case 0: + if (data[3] == 0) + { + data[3]++; + sub_811E710(taskId, data); + if (data[2] > 17) + data[0]++; + } + else + { + data[3]++; + if (data[3] == 2) + data[3] = 0; + } + break; + case 1: + if (data[1] == 0) + { + FreeSpriteTilesByTag(data[6]); + FreeSpritePaletteByTag(data[7]); + DestroyTask(taskId); + } + break; + } +} + +void sub_811E710(u8 taskId, s16 *data) +{ + u8 spriteId; + struct SpriteTemplate template = gUnknown_8459ACC; + template.tileTag = data[6]; + template.paletteTag = data[7]; + data[2]++; + spriteId = CreateSprite(&template, ((data[2] * 219) & 0x3F) + data[4], data[5], data[9]); + if (spriteId != MAX_SPRITES) + { + gSprites[spriteId].oam.priority = data[8]; + gSprites[spriteId].data[1] = 0; + gSprites[spriteId].data[2] = ((data[2] * 1103515245 + 24691) & 0x3F) + 0x20; + gSprites[spriteId].data[7] = taskId; + data[1]++; + } +} + +void sub_811E7B4(struct Sprite * sprite) +{ + sprite->data[1] -= sprite->data[2]; + sprite->pos2.y = sprite->data[1] >> 4; + if (sprite->pos2.y < -0x40) + { + gTasks[sprite->data[7]].data[1]--; + DestroySprite(sprite); + } +} + +void DrawLevelUpWindowPg1(u16 windowId, u16 *beforeStats, u16 *afterStats, u8 bgColor, u8 fgColor, u8 shadowColor) +{ + s16 diffStats[6]; + u8 textbuf[12]; + u8 textColor[3]; + u16 i; + u8 x; + + FillWindowPixelBuffer(windowId, PIXEL_FILL(bgColor)); + + diffStats[0] = afterStats[0] - beforeStats[0]; + diffStats[1] = afterStats[1] - beforeStats[1]; + diffStats[2] = afterStats[2] - beforeStats[2]; + diffStats[3] = afterStats[4] - beforeStats[4]; + diffStats[4] = afterStats[5] - beforeStats[5]; + diffStats[5] = afterStats[3] - beforeStats[3]; + + textColor[0] = bgColor; + textColor[1] = fgColor; + textColor[2] = shadowColor; + + for (i = 0; i < 6; i++) + { + AddTextPrinterParameterized3(windowId, 2, 0, i * 15, textColor, TEXT_SPEED_FF, gUnknown_8459B48[i]); + StringCopy(textbuf, diffStats[i] >= 0 ? gUnknown_841B2DC : gUnknown_841B2E5); + AddTextPrinterParameterized3(windowId, 2, 56, i * 15, textColor, TEXT_SPEED_FF, textbuf); + textbuf[0] = CHAR_SPACE; + x = abs(diffStats[i]) < 10 ? 12 : 6; + ConvertIntToDecimalStringN(textbuf + 1, abs(diffStats[i]), STR_CONV_MODE_LEFT_ALIGN, 2); + AddTextPrinterParameterized3(windowId, 2, x + 56, i * 15, textColor, TEXT_SPEED_FF, textbuf); + } +} + +void DrawLevelUpWindowPg2(u16 windowId, u16 *currStats, u8 bgColor, u8 fgColor, u8 shadowColor) +{ + s16 statsRearrange[6]; + u8 textbuf[12]; + u8 textColor[3]; + u16 i; + u8 ndigits; + u16 x; + + FillWindowPixelBuffer(windowId, PIXEL_FILL(bgColor)); + + statsRearrange[0] = currStats[0]; + statsRearrange[1] = currStats[1]; + statsRearrange[2] = currStats[2]; + statsRearrange[3] = currStats[4]; + statsRearrange[4] = currStats[5]; + statsRearrange[5] = currStats[3]; + + textColor[0] = bgColor; + textColor[1] = fgColor; + textColor[2] = shadowColor; + + for (i = 0; i < 6; i++) + { + if (statsRearrange[i] >= 100) + ndigits = 3; + else if (statsRearrange[i] >= 10) + ndigits = 2; + else + ndigits = 1; + ConvertIntToDecimalStringN(textbuf, statsRearrange[i], STR_CONV_MODE_LEFT_ALIGN, ndigits); + x = 6 * (4 - ndigits); + AddTextPrinterParameterized3(windowId, 2, 0, i * 15, textColor, TEXT_SPEED_FF, gUnknown_8459B48[i]); + AddTextPrinterParameterized3(windowId, 2, 56 + x, i * 15, textColor, TEXT_SPEED_FF, textbuf); + } +} diff --git a/sym_bss.txt b/sym_bss.txt index 527efb982..321e0a2b8 100644 --- a/sym_bss.txt +++ b/sym_bss.txt @@ -59,15 +59,8 @@ gUnknown_3000E89: @ 3000E89 .include "src/quest_log.o" .align 2 .include "src/union_room.o" - .align 2 - @ .include "src/pokemon_special_anim.o" -gUnknown_3002030: @ 3002030 - .space 0x8 - -gUnknown_3002038: @ 3002038 - .space 0x8 - + .include "src/pokemon_special_anim_scene.o" .align 2 .include "src/wireless_communication_status_screen.o" .align 2 |