summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/pokemon_summary_screen.c195
1 files changed, 189 insertions, 6 deletions
diff --git a/src/pokemon_summary_screen.c b/src/pokemon_summary_screen.c
index e566fe6fc..fcf850ea7 100644
--- a/src/pokemon_summary_screen.c
+++ b/src/pokemon_summary_screen.c
@@ -18,6 +18,7 @@
#include "constants/party_menu.h"
#include "trade.h"
#include "battle_main.h"
+#include "scanline_effect.h"
extern void sub_8138B8C(struct Pokemon * mon);
void sub_8135C34(void);
@@ -45,8 +46,8 @@ extern void sub_8136F4C(void);
extern void sub_81374E8(void);
extern void sub_8137BD0(void);
extern void sub_8138A38(void);
-extern void sub_8136DA4(const u8 * str);
-extern void sub_8136DF0(const u8 * str);
+void sub_8136DA4(const u8 * str);
+void sub_8136DF0(const u8 * str);
extern void sub_8136E50(const u8 * str);
void sub_81358DC(u8, u8);
extern void sub_813A838(u8 invisible);
@@ -60,15 +61,15 @@ extern void sub_813AEB0(u8 invisible);
extern void sub_813A0E8(u8 invisible);
extern void sub_8139EE4(u8 invisible);
extern void sub_81381AC(void);
-extern void sub_8136BC4(void);
-extern void sub_8136BAC(void);
+void sub_8136BC4(void);
+void sub_8136BAC(void);
u8 sub_8135F20(void);
-extern u8 sub_8136AEC(void);
+u8 sub_8136AEC(void);
extern void sub_81381D0(void);
u8 sub_8136040(void);
extern void sub_8137E28(void);
extern void sub_81381C0(void);
-extern void sub_8136D54(void);
+void sub_8136D54(void);
extern void sub_81360D4(void);
extern void sub_8136350(void);
extern void sub_81367B0(void);
@@ -76,6 +77,18 @@ extern u8 sub_8138C5C(u32 status);
void sub_81367E8(u8);
extern u16 sub_8138BEC(struct Pokemon * mon, u8 i);
extern u16 sub_8138C24(struct Pokemon * mon, u8 i);
+extern void sub_813ADA8(u16, u16);
+extern void sub_813ABAC(u16, u16);
+extern void sub_813AFFC(void);
+extern void sub_8139F64(u16, u16);
+extern void sub_813A254(u16, u16);
+extern void sub_813A45C(u16, u16);
+extern void sub_813A874(u16, u16);
+extern void sub_8139CB0(void);
+extern void sub_8139DBC(void);
+extern void sub_813995C(void);
+extern void sub_81393D4(u8 taskId);
+extern void sub_8137EE8(void);
struct PokemonSummaryScreenData {
u16 unk0[0x800];
@@ -254,6 +267,10 @@ extern const u32 gUnknown_8E9A460[];
extern const u32 gUnknown_84636C0[];
extern const u32 gUnknown_8463700[];
+extern const struct BgTemplate gUnknown_8463EFC[4];
+
+extern const u8 gUnknown_8463FA7[][3];
+
void ShowPokemonSummaryScreen(struct Pokemon * party, u8 cursorPos, u8 lastIdx, MainCallback savedCallback, u8 mode)
{
gMonSummaryScreen = AllocZeroed(sizeof(struct PokemonSummaryScreenData));
@@ -1583,3 +1600,169 @@ void sub_81367E8(u8 i)
ConvertIntToDecimalStringN(gMonSummaryScreen->summary.unk3188[i], gBattleMoves[gMonSummaryScreen->unk325A[i]].accuracy, STR_CONV_MODE_RIGHT_ALIGN, 3);
}
+u8 sub_8136AEC(void)
+{
+ switch (gMonSummaryScreen->unk327C)
+ {
+ case 0:
+ sub_813ADA8(TAG_PSS_UNK_A0, TAG_PSS_UNK_A0);
+ break;
+ case 1:
+ sub_813ABAC(TAG_PSS_UNK_96, TAG_PSS_UNK_96);
+ break;
+ case 2:
+ sub_813AFFC();
+ break;
+ case 3:
+ sub_8139F64(TAG_PSS_UNK_64, TAG_PSS_UNK_64);
+ break;
+ case 4:
+ sub_813A254(TAG_PSS_UNK_6E, TAG_PSS_UNK_6E);
+ break;
+ case 5:
+ sub_813A45C(TAG_PSS_UNK_78, TAG_PSS_UNK_78);
+ break;
+ case 6:
+ sub_813A874(TAG_PSS_UNK_82, TAG_PSS_UNK_82);
+ break;
+ case 7:
+ sub_8139CB0();
+ break;
+ case 8:
+ sub_8139DBC();
+ break;
+ default:
+ sub_813995C();
+ return TRUE;
+ }
+
+ gMonSummaryScreen->unk327C++;
+ return FALSE;
+}
+
+void sub_8136BAC(void)
+{
+ ResetSpriteData();
+ ResetPaletteFade();
+ FreeAllSpritePalettes();
+ ScanlineEffect_Stop();
+}
+
+void sub_8136BC4(void)
+{
+ DmaClearLarge16(3, (void *)VRAM, VRAM_SIZE, 0x1000);
+ DmaClear32(3, (void *)OAM, OAM_SIZE);
+ DmaClear16(3, (void *)PLTT, PLTT_SIZE);
+
+ SetGpuReg(REG_OFFSET_DISPCNT, 0);
+
+ ResetBgsAndClearDma3BusyFlags(0);
+ InitBgsFromTemplates(0, gUnknown_8463EFC, ARRAY_COUNT(gUnknown_8463EFC));
+
+ ChangeBgX(0, 0, 0);
+ ChangeBgY(0, 0, 0);
+ ChangeBgX(1, 0, 0);
+ ChangeBgY(1, 0, 0);
+ ChangeBgX(2, 0, 0);
+ ChangeBgY(2, 0, 0);
+ ChangeBgX(3, 0, 0);
+ ChangeBgY(3, 0, 0);
+
+ DeactivateAllTextPrinters();
+
+ SetGpuReg(REG_OFFSET_DISPCNT, DISPCNT_OBJ_1D_MAP | DISPCNT_OBJ_ON | DISPCNT_WIN1_ON);
+
+ sub_813B750(gMonSummaryScreen->curPageIndex);
+
+ SetGpuReg(REG_OFFSET_WININ, (WININ_WIN0_OBJ | WININ_WIN0_BG0 | WININ_WIN0_BG1 | WININ_WIN0_BG2 | WININ_WIN0_BG3) << 8);
+ SetGpuReg(REG_OFFSET_WINOUT, WINOUT_WIN01_BG0 | WINOUT_WIN01_BG1 | WINOUT_WIN01_BG2 | WINOUT_WIN01_BG3);
+ SetGpuReg(REG_OFFSET_WIN1V, 32 << 8 | 135);
+ SetGpuReg(REG_OFFSET_WIN1H, 2 << 8 | 240);
+
+ SetBgTilemapBuffer(1, gMonSummaryScreen->unk0);
+ SetBgTilemapBuffer(2, gMonSummaryScreen->unk1000);
+ SetBgTilemapBuffer(3, gMonSummaryScreen->unk2000);
+
+ ShowBg(0);
+ ShowBg(1);
+ ShowBg(2);
+ ShowBg(3);
+}
+
+void sub_8136D54(void)
+{
+ if (gMonSummaryScreen->mode == PSS_MODE_SELECT_MOVE || gMonSummaryScreen->mode == PSS_MODE_FORGET_MOVE)
+ gMonSummaryScreen->unk3018 = CreateTask(sub_81393D4, 0);
+ else
+ gMonSummaryScreen->unk3018 = CreateTask(sub_8134840, 0);
+
+ SetMainCallback2(sub_8137EE8);
+}
+
+void sub_8136DA4(const u8 * str)
+{
+ FillWindowPixelBuffer(gMonSummaryScreen->unk3000[0], 0);
+ AddTextPrinterParameterized3(gMonSummaryScreen->unk3000[0], 2, 4, 1, gUnknown_8463FA7[0], 0, str);
+ PutWindowTilemap(gMonSummaryScreen->unk3000[0]);
+}
+
+#ifdef NONMATCHING
+void sub_8136DF0(const u8 * str)
+{
+ u8 v0;
+
+ FillWindowPixelBuffer(gMonSummaryScreen->unk3000[1], 0);
+ v0 = (u8)(0x54 - GetStringWidth(0, str, 0));
+ AddTextPrinterParameterized3(gMonSummaryScreen->unk3000[1], 0, v0, 0, gUnknown_8463FA7[0], 0, str);
+ PutWindowTilemap(gMonSummaryScreen->unk3000[1]);
+}
+#else
+NAKED
+void sub_8136DF0(const u8 * str)
+{
+ asm_unified("\tpush {r4-r6,lr}\n"
+ "\tsub sp, 0xC\n"
+ "\tadds r6, r0, 0\n"
+ "\tldr r5, _08136E44 @ =gMonSummaryScreen\n"
+ "\tldr r0, [r5]\n"
+ "\tldr r4, _08136E48 @ =0x00003001\n"
+ "\tadds r0, r4\n"
+ "\tldrb r0, [r0]\n"
+ "\tmovs r1, 0\n"
+ "\tbl FillWindowPixelBuffer\n"
+ "\tmovs r0, 0\n"
+ "\tadds r1, r6, 0\n"
+ "\tmovs r2, 0\n"
+ "\tbl GetStringWidth\n"
+ "\tldr r1, [r5]\n"
+ "\tadds r1, r4\n"
+ "\tldrb r1, [r1]\n"
+ "\tmovs r2, 0x54\n"
+ "\tsubs r2, r0\n"
+ "\tlsls r2, 24\n"
+ "\tlsrs r2, 24\n"
+ "\tldr r0, _08136E4C @ =gUnknown_8463FA7\n"
+ "\tstr r0, [sp]\n"
+ "\tmovs r0, 0\n"
+ "\tstr r0, [sp, 0x4]\n"
+ "\tstr r6, [sp, 0x8]\n"
+ "\tadds r0, r1, 0\n"
+ "\tmovs r1, 0\n"
+ "\tmovs r3, 0\n"
+ "\tbl AddTextPrinterParameterized3\n"
+ "\tldr r0, [r5]\n"
+ "\tadds r0, r4\n"
+ "\tldrb r0, [r0]\n"
+ "\tbl PutWindowTilemap\n"
+ "\tadd sp, 0xC\n"
+ "\tpop {r4-r6}\n"
+ "\tpop {r0}\n"
+ "\tbx r0\n"
+ "\t.align 2, 0\n"
+ "_08136E44: .4byte gMonSummaryScreen\n"
+ "_08136E48: .4byte 0x00003001\n"
+ "_08136E4C: .4byte gUnknown_8463FA7\n");
+}
+#endif
+
+ \ No newline at end of file