pokeemerald/src/pokenav_conditions_3.c

715 lines
18 KiB
C
Raw Normal View History

2019-07-20 04:06:42 +02:00
#include "global.h"
#include "pokenav.h"
#include "bg.h"
2019-08-05 19:47:04 +02:00
#include "menu.h"
2019-07-20 04:06:42 +02:00
#include "window.h"
2019-08-05 19:47:04 +02:00
#include "sound.h"
#include "dynamic_placeholder_text_util.h"
#include "strings.h"
#include "string_util.h"
#include "international_string_util.h"
#include "constants/songs.h"
2019-07-20 04:06:42 +02:00
2019-08-05 16:54:56 +02:00
struct PokenavSub7
{
u32 (*unk0)(struct PokenavSub7 *);
u32 loopedTaskId;
u8 fill1[4];
s32 unkC;
s32 unk10;
u32 unk14;
u32 unk18;
u32 unk1C;
struct PokenavSub18 *unkPtr;
};
struct PokenavSub8
{
bool32 (*callback)(void);
u32 ltid;
u16 winid;
bool32 unkC;
2019-08-06 15:26:55 +02:00
u8 buff[BG_SCREEN_SIZE];
}; // size: 0x810
static u32 sub_81CF010(struct PokenavSub7 *structPtr);
static u32 sub_81CF030(struct PokenavSub7 *structPtr);
static u32 sub_81CF0B8(struct PokenavSub7 *structPtr);
static u32 sub_81CF0B0(struct PokenavSub7 *structPtr);
static u32 sub_81CF11C(s32 state);
static u32 sub_81CF134(s32 state);
static u32 sub_81CF1C4(s32 state);
static u32 sub_81CF1D8(s32 state);
static u32 sub_81CF278(s32 state);
static u32 sub_81CF578(s32 state);
static u32 sub_81CF5F0(s32 state);
static u32 sub_81CF668(s32 state);
static u32 sub_81CF6E0(s32 state);
static u32 sub_81CF758(s32 state);
static u32 sub_81CF798(s32 state);
static void sub_81CF2C4(struct PokenavSub7 *structPtr, struct PokenavMonList *item);
static bool32 sub_81CF3E4(void);
static u32 sub_81CF418(s32 state);
static void sub_81CF7C8(struct PokenavSub8 *);
static void sub_81CF7F4(struct PokenavSub8 *);
static void sub_81CF88C(void);
static void sub_81CF8E4(struct PokenavMonList *, u8 *);
static const u32 gUnknown_086233A0[] = {0x16, 0x17, 0x18, 0x21, 0x2F};
static const LoopedTask gUnknown_086233B4[] =
2019-07-20 04:06:42 +02:00
{
sub_81CF134,
sub_81CF1C4,
sub_81CF1D8,
sub_81CF278
};
static const u16 gUnknown_086233C4[] = INCBIN_U16("graphics/pokenav/condition_search2.gbapal");
static const u32 gUnknown_086233E4[] = INCBIN_U32("graphics/pokenav/condition_search2.4bpp.lz");
static const u32 gUnknown_086234AC[] = INCBIN_U32("graphics/pokenav/condition_search2.bin.lz");
static const u16 gUnknown_08623570[] = INCBIN_U16("graphics/pokenav/8623570.gbapal");
2019-07-20 04:06:42 +02:00
static const struct BgTemplate gUnknown_08623590[] =
2019-07-20 04:06:42 +02:00
{
2019-08-05 19:47:04 +02:00
{
.bg = 1,
.charBaseIndex = 1,
.mapBaseIndex = 0x06,
.screenSize = 0,
.paletteMode = 0,
.priority = 2,
.baseTile = 0
}, {
.bg = 2,
.charBaseIndex = 2,
.mapBaseIndex = 0x07,
.screenSize = 0,
.paletteMode = 0,
.priority = 3,
.baseTile = 0
}
2019-07-20 04:06:42 +02:00
};
static const LoopedTask gUnknown_08623598[] =
2019-07-20 04:06:42 +02:00
{
NULL,
sub_81CF578,
sub_81CF5F0,
sub_81CF668,
sub_81CF6E0,
sub_81CF758,
sub_81CF798
};
static const struct WindowTemplate gUnknown_086235B4 =
2019-07-20 04:06:42 +02:00
{
.bg = 1,
.tilemapLeft = 1,
.tilemapTop = 6,
.width = 7,
.height = 2,
.paletteNum = 1,
.baseBlock = 20
};
2020-02-01 06:25:50 +01:00
static const u8 sText_MaleSymbol[] = _("{COLOR_HIGHLIGHT_SHADOW}{LIGHT_RED}{WHITE}{GREEN}♂{COLOR_HIGHLIGHT_SHADOW}{DARK_GREY}{WHITE}{LIGHT_GREY}");
static const u8 sText_FemaleSymbol[] = _("{COLOR_HIGHLIGHT_SHADOW}{LIGHT_GREEN}{WHITE}{BLUE}♀{COLOR_HIGHLIGHT_SHADOW}{DARK_GREY}{WHITE}{LIGHT_GREY}");
static const u8 sText_NoGenderSymbol[] = _("{UNK_SPACER}");
2019-07-25 21:41:02 +02:00
2019-08-06 02:23:56 +02:00
bool32 PokenavCallback_Init_8(void)
2019-07-25 21:41:02 +02:00
{
struct PokenavSub7 *structPtr = AllocSubstruct(7, sizeof(struct PokenavSub7));
if (structPtr == NULL)
return FALSE;
structPtr->unkPtr = AllocSubstruct(18, sizeof(struct PokenavSub18));
if (structPtr->unkPtr == NULL)
return FALSE;
structPtr->unk0 = sub_81CF010;
structPtr->loopedTaskId = CreateLoopedTask(sub_81CF11C, 1);
structPtr->unk18 = 0;
2020-02-01 06:25:50 +01:00
structPtr->unk14 = gUnknown_086233A0[GetSelectedConditionSearch()];
2019-07-25 21:41:02 +02:00
return TRUE;
}
2019-08-06 02:23:56 +02:00
bool32 PokenavCallback_Init_10(void)
2019-07-25 21:41:02 +02:00
{
struct PokenavSub7 *structPtr = AllocSubstruct(7, sizeof(struct PokenavSub7));
if (structPtr == NULL)
return FALSE;
structPtr->unkPtr = GetSubstructPtr(18);
structPtr->unk0 = sub_81CF030;
structPtr->unk18 = 1;
2020-02-01 06:25:50 +01:00
structPtr->unk14 = gUnknown_086233A0[GetSelectedConditionSearch()];
2019-07-25 21:41:02 +02:00
return TRUE;
}
u32 sub_81CEFDC(void)
{
struct PokenavSub7 *structPtr = GetSubstructPtr(7);
return structPtr->unk0(structPtr);
}
void sub_81CEFF0(void)
{
struct PokenavSub7 *structPtr = GetSubstructPtr(7);
if (structPtr->unk1C == 0)
FreePokenavSubstruct(18);
FreePokenavSubstruct(7);
}
static bool32 sub_81CF010(struct PokenavSub7 *structPtr)
2019-07-25 21:41:02 +02:00
{
if (!IsLoopedTaskActive(structPtr->loopedTaskId))
structPtr->unk0 = sub_81CF030;
return FALSE;
}
static u32 sub_81CF030(struct PokenavSub7 *structPtr)
2019-07-25 21:41:02 +02:00
{
if (gMain.newAndRepeatedKeys & DPAD_UP)
return 1;
else if (gMain.newAndRepeatedKeys & DPAD_DOWN)
return 2;
else if (gMain.newKeys & DPAD_LEFT)
return 3;
else if (gMain.newKeys & DPAD_RIGHT)
return 4;
else if (gMain.newKeys & B_BUTTON)
{
structPtr->unk1C = 0;
structPtr->unk0 = sub_81CF0B0;
return 5;
}
else if (gMain.newKeys & A_BUTTON)
{
structPtr->unkPtr->unk2 = GetSelectedMatchCall();
structPtr->unk1C = 1;
structPtr->unk0 = sub_81CF0B8;
return 6;
}
else
return 0;
}
static u32 sub_81CF0B0(struct PokenavSub7 *structPtr)
2019-07-25 21:41:02 +02:00
{
2020-02-05 08:47:32 +01:00
return POKENAV_CONDITION_SEARCH_MENU;
2019-07-25 21:41:02 +02:00
}
static u32 sub_81CF0B8(struct PokenavSub7 *structPtr)
2019-07-25 21:41:02 +02:00
{
2020-02-05 08:47:32 +01:00
return POKENAV_MENU_9;
2019-07-25 21:41:02 +02:00
}
static u32 sub_81CF0C0(void)
2019-07-25 21:41:02 +02:00
{
struct PokenavSub7 *structPtr = GetSubstructPtr(7);
return structPtr->unk18;
}
2019-08-05 16:54:56 +02:00
static struct PokenavMonList * sub_81CF0D0(void)
2019-08-05 16:54:56 +02:00
{
2019-08-05 20:32:30 +02:00
struct PokenavSub7 * ptr = GetSubstructPtr(7);
2019-08-05 16:54:56 +02:00
return ptr->unkPtr->unk4;
}
static u16 sub_81CF0E0(void)
2019-08-05 16:54:56 +02:00
{
2019-08-05 20:32:30 +02:00
struct PokenavSub7 * ptr = GetSubstructPtr(7);
2019-08-05 16:54:56 +02:00
return ptr->unkPtr->unk0;
}
static s32 sub_81CF0F0(void)
2019-08-05 16:54:56 +02:00
{
2019-08-05 20:32:30 +02:00
struct PokenavSub7 * ptr = GetSubstructPtr(7);
2019-08-05 16:54:56 +02:00
s32 i = GetSelectedMatchCall();
2019-12-05 21:33:36 +01:00
return ptr->unkPtr->unk4[i].data;
2019-08-05 16:54:56 +02:00
}
static u16 sub_81CF10C(void)
2019-08-05 16:54:56 +02:00
{
2019-08-05 20:32:30 +02:00
struct PokenavSub7 * ptr = GetSubstructPtr(7);
2019-08-05 16:54:56 +02:00
return ptr->unkPtr->unk2;
}
static u32 sub_81CF11C(s32 state)
2019-08-05 16:54:56 +02:00
{
return gUnknown_086233B4[state](state);
}
static u32 sub_81CF134(s32 state)
2019-08-05 16:54:56 +02:00
{
s32 i;
struct PokenavMonList item;
2019-08-05 20:32:30 +02:00
struct PokenavSub7 * ptr = GetSubstructPtr(7);
2019-08-05 16:54:56 +02:00
ptr->unkPtr->unk0 = 0;
ptr->unkPtr->unk2 = 0;
item.boxId = 14;
for (i = 0; i < PARTY_SIZE; i++)
{
struct Pokemon * pokemon = &gPlayerParty[i];
if (!GetMonData(pokemon, MON_DATA_SANITY_HAS_SPECIES))
return LT_INC_AND_CONTINUE;
if (!GetMonData(pokemon, MON_DATA_SANITY_IS_EGG))
{
item.monId = i;
2019-12-05 21:33:36 +01:00
item.data = GetMonData(pokemon, ptr->unk14);
2019-08-05 16:54:56 +02:00
sub_81CF2C4(ptr, &item);
}
}
return LT_INC_AND_CONTINUE;
}
static u32 sub_81CF1C4(s32 state)
2019-08-05 16:54:56 +02:00
{
2019-08-05 20:32:30 +02:00
struct PokenavSub7 * ptr = GetSubstructPtr(7);
2019-08-05 16:54:56 +02:00
ptr->unk10 = 0;
ptr->unkC = 0;
return LT_INC_AND_CONTINUE;
}
static u32 sub_81CF1D8(s32 state)
2019-08-05 16:54:56 +02:00
{
2019-08-05 20:32:30 +02:00
struct PokenavSub7 * ptr = GetSubstructPtr(7);
2019-08-05 16:54:56 +02:00
s32 boxId = ptr->unkC;
s32 monId = ptr->unk10;
s32 boxCount = 0;
struct PokenavMonList item;
while (boxId < TOTAL_BOXES_COUNT)
{
while (monId < IN_BOX_COUNT)
{
if (CheckBoxMonSanityAt(boxId, monId))
{
item.boxId = boxId;
item.monId = monId;
2019-12-05 21:33:36 +01:00
item.data = GetBoxMonDataAt(boxId, monId, ptr->unk14);
2019-08-05 16:54:56 +02:00
sub_81CF2C4(ptr, &item);
}
boxCount++;
monId++;
if (boxCount > 14)
{
ptr->unkC = boxId;
ptr->unk10 = monId;
return LT_CONTINUE;
}
}
monId = 0;
boxId++;
}
return LT_INC_AND_CONTINUE;
}
static u32 sub_81CF278(s32 state)
2019-08-05 16:54:56 +02:00
{
2019-08-05 20:32:30 +02:00
struct PokenavSub7 * ptr = GetSubstructPtr(7);
2019-08-05 16:54:56 +02:00
s32 r6 = ptr->unkPtr->unk0;
2019-12-05 21:33:36 +01:00
s32 r4 = ptr->unkPtr->unk4[0].data;
2019-08-05 16:54:56 +02:00
s32 i;
2019-12-05 21:33:36 +01:00
ptr->unkPtr->unk4[0].data = 1;
2019-08-05 16:54:56 +02:00
for (i = 1; i < r6; i++)
{
2019-12-05 21:33:36 +01:00
if (ptr->unkPtr->unk4[i].data == r4)
2019-08-05 16:54:56 +02:00
{
2019-12-05 21:33:36 +01:00
ptr->unkPtr->unk4[i].data = ptr->unkPtr->unk4[i - 1].data;
2019-08-05 16:54:56 +02:00
}
else
{
2019-12-05 21:33:36 +01:00
r4 = ptr->unkPtr->unk4[i].data;
ptr->unkPtr->unk4[i].data = i + 1;
2019-08-05 16:54:56 +02:00
}
}
ptr->unk18 = 1;
return LT_FINISH;
}
2019-08-05 18:21:45 +02:00
static void sub_81CF2C4(struct PokenavSub7 *structPtr, struct PokenavMonList *item)
2019-08-05 18:21:45 +02:00
{
u32 left = 0;
u32 right = structPtr->unkPtr->unk0;
u32 insertionIdx = left + (right - left) / 2;
while (right != insertionIdx)
{
2019-12-05 21:33:36 +01:00
if (item->data > structPtr->unkPtr->unk4[insertionIdx].data)
2019-08-05 18:21:45 +02:00
right = insertionIdx;
else
left = insertionIdx + 1;
insertionIdx = left + (right - left) / 2;
}
for (right = structPtr->unkPtr->unk0; right > insertionIdx; right--)
structPtr->unkPtr->unk4[right] = structPtr->unkPtr->unk4[right - 1];
structPtr->unkPtr->unk4[insertionIdx] = *item;
structPtr->unkPtr->unk0++;
}
bool32 sub_81CF330(void)
{
struct PokenavSub8 * unk = AllocSubstruct(8, sizeof(struct PokenavSub8));
if (unk == NULL)
return FALSE;
unk->ltid = CreateLoopedTask(sub_81CF418, 1);
unk->callback = sub_81CF3E4;
unk->unkC = FALSE;
return TRUE;
}
bool32 sub_81CF368(void)
{
struct PokenavSub8 * unk = AllocSubstruct(8, sizeof(struct PokenavSub8));
if (unk == NULL)
return FALSE;
unk->ltid = CreateLoopedTask(sub_81CF418, 1);
unk->callback = sub_81CF3E4;
unk->unkC = TRUE;
return TRUE;
}
void sub_81CF3A0(s32 idx)
{
2019-08-05 20:32:30 +02:00
struct PokenavSub8 * unk = GetSubstructPtr(8);
2019-08-05 18:21:45 +02:00
unk->ltid = CreateLoopedTask(gUnknown_08623598[idx], 1);
unk->callback = sub_81CF3E4;
}
bool32 sub_81CF3D0(void)
{
2019-08-05 20:32:30 +02:00
struct PokenavSub8 * unk = GetSubstructPtr(8);
2019-08-05 18:21:45 +02:00
return unk->callback();
}
2019-08-05 23:17:05 +02:00
bool32 sub_81CF3E4(void)
2019-08-05 18:21:45 +02:00
{
2019-08-05 20:32:30 +02:00
struct PokenavSub8 * unk = GetSubstructPtr(8);
2019-08-05 18:21:45 +02:00
return IsLoopedTaskActive(unk->ltid);
}
void sub_81CF3F8(void)
{
2019-08-05 20:32:30 +02:00
struct PokenavSub8 * unk = GetSubstructPtr(8);
2019-08-05 18:21:45 +02:00
sub_81C8234();
RemoveWindow(unk->winid);
FreePokenavSubstruct(8);
}
2019-08-05 19:47:04 +02:00
static u32 sub_81CF418(s32 state)
2019-08-05 19:47:04 +02:00
{
2019-08-05 20:32:30 +02:00
struct PokenavSub8 * unk = GetSubstructPtr(8);
2019-08-05 19:47:04 +02:00
switch (state)
{
case 0:
InitBgTemplates(gUnknown_08623590, NELEMS(gUnknown_08623590));
2020-05-14 10:37:09 +02:00
DecompressAndCopyTileDataToVram(1, gUnknown_086233E4, 0, 0, 0);
2019-08-05 19:47:04 +02:00
SetBgTilemapBuffer(1, unk->buff);
CopyToBgTilemapBuffer(1, gUnknown_086234AC, 0, 0);
CopyBgTilemapBufferToVram(1);
CopyPaletteIntoBufferUnfaded(gUnknown_086233C4, 0x10, 0x20);
CopyBgTilemapBufferToVram(1);
return LT_INC_AND_PAUSE;
case 1:
2020-05-14 10:37:09 +02:00
if (FreeTempTileDataBuffersIfPossible())
2019-08-05 19:47:04 +02:00
return LT_PAUSE;
if (!sub_81CF0C0())
return LT_PAUSE;
return LT_INC_AND_PAUSE;
case 2:
2020-05-14 10:37:09 +02:00
if (FreeTempTileDataBuffersIfPossible())
2019-08-05 19:47:04 +02:00
return LT_PAUSE;
CopyPaletteIntoBufferUnfaded(gUnknown_08623570, 0x20, 0x20);
sub_81CF88C();
return LT_INC_AND_PAUSE;
case 3:
if (sub_81C8224())
return LT_PAUSE;
sub_81CF7C8(unk);
2019-12-07 10:08:21 +01:00
PrintHelpBarText(HELPBAR_CONDITION_MON_LIST);
2019-08-05 19:47:04 +02:00
return LT_INC_AND_PAUSE;
case 4:
2020-05-14 10:37:09 +02:00
if (FreeTempTileDataBuffersIfPossible())
2019-08-05 19:47:04 +02:00
return LT_PAUSE;
ChangeBgX(1, 0, 0);
ChangeBgY(1, 0, 0);
ShowBg(1);
ShowBg(2);
HideBg(3);
if (!unk->unkC)
{
2020-02-01 06:25:50 +01:00
u8 r4 = GetSelectedConditionSearch() + POKENAV_MENUITEM_CONDITION_SEARCH_COOL;
2019-08-05 19:47:04 +02:00
LoadLeftHeaderGfxForIndex(r4);
sub_81C7FA0(r4, 1, 0);
sub_81C7FA0(1, 1, 0);
}
2020-02-05 08:47:32 +01:00
PokenavFadeScreen(1);
2019-08-05 19:47:04 +02:00
return LT_INC_AND_PAUSE;
case 5:
if (IsPaletteFadeActive())
return LT_PAUSE;
if (sub_81C8010())
return LT_PAUSE;
break;
}
return LT_FINISH;
}
static u32 sub_81CF578(s32 state)
2019-08-05 19:47:04 +02:00
{
2019-08-05 20:32:30 +02:00
struct PokenavSub8 * unk = GetSubstructPtr(8);
2019-08-05 19:47:04 +02:00
switch (state)
{
case 0:
switch (MatchCall_MoveCursorUp())
{
case 0:
return LT_FINISH;
case 1:
PlaySE(SE_SELECT);
return LT_SET_STATE(2);
case 2:
PlaySE(SE_SELECT);
break;
}
return LT_INC_AND_PAUSE;
case 1:
if (sub_81C8630())
return LT_PAUSE;
// fallthrough
case 2:
sub_81CF7F4(unk);
return LT_INC_AND_PAUSE;
case 3:
if (IsDma3ManagerBusyWithBgCopy())
return LT_PAUSE;
break;
}
return LT_FINISH;
}
static u32 sub_81CF5F0(s32 state)
2019-08-05 19:47:04 +02:00
{
2019-08-05 20:32:30 +02:00
struct PokenavSub8 * unk = GetSubstructPtr(8);
2019-08-05 19:47:04 +02:00
switch (state)
{
case 0:
switch (MatchCall_MoveCursorDown())
{
case 0:
return LT_FINISH;
case 1:
PlaySE(SE_SELECT);
return LT_SET_STATE(2);
case 2:
PlaySE(SE_SELECT);
break;
}
return LT_INC_AND_PAUSE;
case 1:
if (sub_81C8630())
return LT_PAUSE;
// fallthrough
case 2:
sub_81CF7F4(unk);
return LT_INC_AND_PAUSE;
case 3:
if (IsDma3ManagerBusyWithBgCopy())
return LT_PAUSE;
break;
}
return LT_FINISH;
}
static u32 sub_81CF668(s32 state)
2019-08-05 19:47:04 +02:00
{
2019-08-05 20:32:30 +02:00
struct PokenavSub8 * unk = GetSubstructPtr(8);
2019-08-05 19:47:04 +02:00
switch (state)
{
case 0:
switch (MatchCall_PageUp())
{
case 0:
return LT_FINISH;
case 1:
PlaySE(SE_SELECT);
return LT_SET_STATE(2);
case 2:
PlaySE(SE_SELECT);
break;
}
return LT_INC_AND_PAUSE;
case 1:
if (sub_81C8630())
return LT_PAUSE;
// fallthrough
case 2:
sub_81CF7F4(unk);
return LT_INC_AND_PAUSE;
case 3:
if (IsDma3ManagerBusyWithBgCopy())
return LT_PAUSE;
break;
}
return LT_FINISH;
}
static u32 sub_81CF6E0(s32 state)
2019-08-05 19:47:04 +02:00
{
2019-08-05 20:32:30 +02:00
struct PokenavSub8 * unk = GetSubstructPtr(8);
2019-08-05 19:47:04 +02:00
switch (state)
{
case 0:
switch (MatchCall_PageDown())
{
case 0:
return LT_FINISH;
case 1:
PlaySE(SE_SELECT);
return LT_SET_STATE(2);
case 2:
PlaySE(SE_SELECT);
break;
}
return LT_INC_AND_PAUSE;
case 1:
if (sub_81C8630())
return LT_PAUSE;
// fallthrough
case 2:
sub_81CF7F4(unk);
return LT_INC_AND_PAUSE;
case 3:
if (IsDma3ManagerBusyWithBgCopy())
return LT_PAUSE;
break;
}
return LT_FINISH;
}
static u32 sub_81CF758(s32 state)
2019-08-05 19:47:04 +02:00
{
switch (state)
{
case 0:
PlaySE(SE_SELECT);
2020-02-05 08:47:32 +01:00
PokenavFadeScreen(0);
2019-08-05 19:47:04 +02:00
sub_81C78A0();
return LT_INC_AND_PAUSE;
case 1:
if (IsPaletteFadeActive())
return LT_PAUSE;
if (MainMenuLoopedTaskIsBusy())
return LT_PAUSE;
sub_81C7FDC();
break;
}
return LT_FINISH;
}
static u32 sub_81CF798(s32 state)
2019-08-05 19:47:04 +02:00
{
switch (state)
{
case 0:
PlaySE(SE_SELECT);
2020-02-05 08:47:32 +01:00
PokenavFadeScreen(0);
2019-08-05 19:47:04 +02:00
return LT_INC_AND_PAUSE;
case 1:
if (IsPaletteFadeActive())
return LT_PAUSE;
break;
}
return LT_FINISH;
}
static void sub_81CF7C8(struct PokenavSub8 * ptr)
2019-08-05 19:47:04 +02:00
{
ptr->winid = AddWindow(&gUnknown_086235B4);
PutWindowTilemap(ptr->winid);
CopyWindowToVram(ptr->winid, 1);
sub_81CF7F4(ptr);
}
static void sub_81CF7F4(struct PokenavSub8 * ptr)
2019-08-05 19:47:04 +02:00
{
s32 r7 = sub_81CF0F0();
DynamicPlaceholderTextUtil_Reset();
DynamicPlaceholderTextUtil_SetPlaceholderPtr(0, gStringVar1);
*gStringVar1 = EOS;
DynamicPlaceholderTextUtil_ExpandPlaceholders(gStringVar2, gText_NumberF700);
AddTextPrinterParameterized(ptr->winid, 1, gStringVar2, 4, 1, 0xFF, NULL);
ConvertIntToDecimalStringN(gStringVar1, r7, STR_CONV_MODE_RIGHT_ALIGN, 3);
AddTextPrinterParameterized(ptr->winid, 1, gStringVar1, 34, 1, 0xFF, NULL);
CopyWindowToVram(ptr->winid, 2);
}
static void sub_81CF88C(void)
2019-08-05 19:47:04 +02:00
{
struct PokenavListTemplate template;
template.list.monList = sub_81CF0D0();
2019-08-05 19:47:04 +02:00
template.unk4 = sub_81CF0E0();
template.unk8 = 4;
template.unk6 = sub_81CF10C();
template.unk9 = 13;
template.unkA = 17;
template.unkB = 1;
template.unkC = 8;
template.unkD = 2;
template.unkE = 1;
template.listFunc.unk10_1 = sub_81CF8E4;
2019-08-05 19:47:04 +02:00
template.unk14 = NULL;
sub_81C81D4(&gUnknown_08623590[1], &template, 0);
}
static void sub_81CF8E4(struct PokenavMonList * item, u8 * dest)
2019-08-05 19:47:04 +02:00
{
u8 gender;
u8 level;
u8 * s;
const u8 * genderStr;
2020-02-01 06:25:50 +01:00
// Mon is in party
if (item->boxId == TOTAL_BOXES_COUNT)
2019-08-05 19:47:04 +02:00
{
struct Pokemon * mon = &gPlayerParty[item->monId];
gender = GetMonGender(mon);
level = GetLevelFromMonExp(mon);
GetMonData(mon, MON_DATA_NICKNAME, gStringVar3);
}
2020-02-01 06:25:50 +01:00
// Mon is in PC
2019-08-05 19:47:04 +02:00
else
{
struct BoxPokemon * mon = GetBoxedMonPtr(item->boxId, item->monId);
gender = GetBoxMonGender(mon);
level = GetLevelFromBoxMonExp(mon);
GetBoxMonData(mon, MON_DATA_NICKNAME, gStringVar3);
}
2020-02-01 06:25:50 +01:00
2019-08-05 19:47:04 +02:00
StringGetEnd10(gStringVar3);
dest = sub_81DB494(dest, 1, gStringVar3, 60);
switch (gender)
{
default:
2020-02-01 06:25:50 +01:00
genderStr = sText_NoGenderSymbol;
2019-08-05 19:47:04 +02:00
break;
case MON_MALE:
2020-02-01 06:25:50 +01:00
genderStr = sText_MaleSymbol;
2019-08-05 19:47:04 +02:00
break;
case MON_FEMALE:
2020-02-01 06:25:50 +01:00
genderStr = sText_FemaleSymbol;
2019-08-05 19:47:04 +02:00
break;
}
s = StringCopy(gStringVar1, genderStr);
*s++ = CHAR_SLASH;
2020-08-11 05:50:49 +02:00
*s++ = CHAR_EXTRA_SYMBOL;
2020-02-01 06:25:50 +01:00
*s++ = CHAR_LV_2;
2019-08-05 19:47:04 +02:00
ConvertIntToDecimalStringN(s, level, STR_CONV_MODE_LEFT_ALIGN, 3);
sub_81DB494(dest, 1, gStringVar1, 40);
}