pokeemerald/src/pokenav_menu_handler_2.c

1280 lines
34 KiB
C
Raw Normal View History

2019-05-02 20:27:59 +02:00
#include "global.h"
#include "malloc.h"
2019-05-02 23:50:42 +02:00
#include "decompress.h"
2019-05-02 20:27:59 +02:00
#include "bg.h"
2019-08-05 02:39:36 +02:00
#include "palette.h"
#include "trig.h"
2019-08-05 00:15:02 +02:00
#include "gpu_regs.h"
2019-05-02 22:19:25 +02:00
#include "menu.h"
2019-05-02 20:27:59 +02:00
#include "window.h"
#include "pokenav.h"
2019-05-02 22:19:25 +02:00
#include "graphics.h"
#include "sound.h"
#include "gym_leader_rematch.h"
2019-07-19 23:23:52 +02:00
#include "window.h"
#include "strings.h"
#include "scanline_effect.h"
2019-05-02 22:19:25 +02:00
#include "constants/songs.h"
#include "constants/rgb.h"
2019-05-02 20:27:59 +02:00
struct Pokenav2Struct
{
2020-02-05 08:47:32 +01:00
bool32 (*isTaskActiveCB)(void);
2019-05-02 20:27:59 +02:00
u32 loopedTaskId;
2020-02-01 06:25:50 +01:00
u16 optionDescWindowId;
2019-08-05 15:17:21 +02:00
u8 bg3ScrollTaskId;
u8 cursorPos;
bool8 otherIconsInMotion;
2020-02-05 08:47:32 +01:00
bool8 pokenavAlreadyOpen;
2020-02-01 06:25:50 +01:00
bool32 iconVisible[MAX_POKENAV_MENUITEMS];
2019-08-05 02:39:36 +02:00
struct Sprite * field_028;
2020-02-01 06:25:50 +01:00
struct Sprite * iconSprites[MAX_POKENAV_MENUITEMS][4];
2019-08-05 15:17:21 +02:00
u16 bg1TilemapBuffer[0x400];
2019-05-02 20:27:59 +02:00
};
2020-02-05 08:47:32 +01:00
static struct Pokenav2Struct * OpenPokenavMenu(void);
static bool32 GetCurrentLoopedTaskActive(void);
static u32 LoopedTask_OpenMenu(s32 state);
2020-02-01 06:25:50 +01:00
static u32 LoopedTask_MoveMenuCursor(s32 state);
static u32 LoopedTask_OpenConditionMenu(s32 state);
static u32 LoopedTask_ReturnToMainMenu(s32 state);
static u32 LoopedTask_OpenConditionSearchMenu(s32 state);
static u32 LoopedTask_ReturnToConditionMenu(s32 state);
static u32 LoopedTask_SelectRibbonsNoWinners(s32 state);
static u32 LoopedTask_ReShowDescription(s32 state);
static u32 LoopedTask_OpenPokenavFeature(s32 state);
static void sub_81C9FC4(void);
static void sub_81C9FEC(void);
2020-02-01 06:25:50 +01:00
static void CreateMenuOptionSprites(void);
static void sub_81CA094(void);
static void sub_81CA0C8(void);
static void sub_81CA0EC(const u16 *const * a0, s32 a1, s32 a2);
static void sub_81CA20C(void);
static void sub_81CA278(void);
static void sub_81CA35C(struct Sprite ** sprites, s32 a1, s32 a2, s32 a3);
static void sub_81CA3B4(struct Sprite ** sprites);
static void sub_81CA2DC(void);
2020-02-01 06:25:50 +01:00
static bool32 AreMenuOptionSpritesMoving(void);
static void sub_81CA448(struct Sprite ** sprites, bool32 a1);
static void sub_81CA474(struct Sprite * sprite);
static void sub_81CA4AC(struct Sprite * sprite);
static void sub_81CA580(u8 taskId);
static void sub_81CA640(void);
static void sub_81CA6AC(struct Sprite * sprite);
static void sub_81CA698(void);
2020-02-01 06:25:50 +01:00
static void AddOptionDescriptionWindow(void);
static void PrintCurrentOptionDescription(void);
static void PrintNoRibbonWinners(void);
static bool32 sub_81CA7C4(void);
static void sub_81CA7D4(void);
static void sub_81CA7F4(void);
static void sub_81CA808(u8 taskId);
static void sub_81CA818(void);
static void sub_81CA850(void);
static void sub_81CA864(void);
static bool32 sub_81CA89C(void);
static void sub_81CA8B0(u8 taskId);
2019-08-05 14:46:52 +02:00
static void sub_81CA92C(void);
static void sub_81CA994(void);
static void sub_81CA9C8(void);
static void sub_81CA9D8(void);
static void sub_81CA9EC(u8 taskId);
static void sub_81CAA3C(void);
static const u16 gUnknown_0861FC78[] = INCBIN_U16("graphics/pokenav/bg.gbapal");
static const u32 gUnknown_0861FC98[] = INCBIN_U32("graphics/pokenav/bg.4bpp.lz");
static const u32 gUnknown_0861FCAC[] = INCBIN_U32("graphics/pokenav/bg.bin.lz");
static const u16 gUnknown_0861FD4C[] = INCBIN_U16("graphics/pokenav/outline.gbapal");
static const u32 gUnknown_0861FD6C[] = INCBIN_U32("graphics/pokenav/outline.4bpp.lz");
static const u32 gUnknown_0861FFF4[] = INCBIN_U32("graphics/pokenav/outline_map.bin.lz");
static const u16 gUnknown_08620104[] = INCBIN_U16("graphics/pokenav/blue_light.gbapal");
static const u32 gUnknown_08620124[] = INCBIN_U32("graphics/pokenav/blue_light.4bpp.lz");
static const struct BgTemplate gUnknown_08620194[] = {
2019-05-02 20:27:59 +02:00
{
.bg = 1,
.charBaseIndex = 1,
.mapBaseIndex = 15,
.screenSize = 0,
.paletteMode = 0,
.priority = 1,
.baseTile = 0x000
}, {
.bg = 2,
.charBaseIndex = 2,
.mapBaseIndex = 23,
.screenSize = 0,
.paletteMode = 0,
.priority = 2,
.baseTile = 0x000
}, {
.bg = 3,
.charBaseIndex = 3,
.mapBaseIndex = 31,
.screenSize = 0,
.paletteMode = 0,
.priority = 3,
.baseTile = 0x000
}
};
2020-02-01 06:25:50 +01:00
static const LoopedTask sMenuHandlerLoopTaskFuncs[] = {
[POKENAV_MENU_FUNC_NONE] = NULL,
[POKENAV_MENU_FUNC_MOVE_CURSOR] = LoopedTask_MoveMenuCursor,
[POKENAV_MENU_FUNC_OPEN_CONDITION] = LoopedTask_OpenConditionMenu,
[POKENAV_MENU_FUNC_RETURN_TO_MAIN] = LoopedTask_ReturnToMainMenu,
[POKENAV_MENU_FUNC_OPEN_CONDITION_SEARCH] = LoopedTask_OpenConditionSearchMenu,
[POKENAV_MENU_FUNC_RETURN_TO_CONDITION] = LoopedTask_ReturnToConditionMenu,
[POKENAV_MENU_FUNC_NO_RIBBON_WINNERS] = LoopedTask_SelectRibbonsNoWinners,
[POKENAV_MENU_FUNC_RESHOW_DESCRIPTION] = LoopedTask_ReShowDescription,
[POKENAV_MENU_FUNC_OPEN_FEATURE] = LoopedTask_OpenPokenavFeature
2019-05-02 20:27:59 +02:00
};
static const struct CompressedSpriteSheet gUnknown_086201C4[] =
2019-07-19 23:23:52 +02:00
{
{
.data = gPokenavOptions_Gfx,
.size = 0x3400,
.tag = 0x0003
},
{
.data = gUnknown_08620124,
.size = 0x0100,
.tag = 0x0001
}
2019-05-02 23:50:42 +02:00
};
static const struct SpritePalette gUnknown_086201D4[] =
{
2019-05-02 23:50:42 +02:00
{gPokenavOptions_Pal + 0x00, 4},
{gPokenavOptions_Pal + 0x10, 5},
{gPokenavOptions_Pal + 0x20, 6},
{gPokenavOptions_Pal + 0x30, 7},
{gPokenavOptions_Pal + 0x40, 8},
{gUnknown_08620104, 3},
2019-07-19 23:23:52 +02:00
{}
2019-05-02 23:50:42 +02:00
};
static const u16 gUnknown_0862020C[] = {0, 0};
static const u16 gUnknown_08620210[] = {0x20, 1};
static const u16 gUnknown_08620214[] = {0x40, 4};
static const u16 gUnknown_08620218[] = {0x60, 2};
static const u16 gUnknown_0862021C[] = {0x80, 3};
static const u16 gUnknown_08620220[] = {0xA0, 1};
static const u16 gUnknown_08620224[] = {0xC0, 1};
static const u16 gUnknown_08620228[] = {0xE0, 4};
static const u16 gUnknown_0862022C[] = {0x100, 1};
static const u16 gUnknown_08620230[] = {0x120, 2};
static const u16 gUnknown_08620234[] = {0x140, 0};
static const u16 gUnknown_08620238[] = {0x160, 0};
static const u16 gUnknown_0862023C[] = {0x180, 3};
2019-07-19 23:23:52 +02:00
2019-05-02 23:50:42 +02:00
struct UnkStruct_08620240
{
2019-07-19 23:23:52 +02:00
u16 unk0;
u16 unk2;
2020-02-01 06:25:50 +01:00
const u16 *unk4[MAX_POKENAV_MENUITEMS];
2019-05-02 23:50:42 +02:00
};
2020-02-01 06:25:50 +01:00
// TODO
static const struct UnkStruct_08620240 gUnknown_08620240[POKENAV_MENU_TYPE_COUNT] =
2019-07-19 23:23:52 +02:00
{
2020-02-01 06:25:50 +01:00
[POKENAV_MENU_TYPE_DEFAULT] =
2019-07-19 23:23:52 +02:00
{
0x2A,
2020-02-01 06:25:50 +01:00
0x14,
{gUnknown_0862020C, gUnknown_08620210, gUnknown_0862021C}
2019-07-19 23:23:52 +02:00
},
2020-02-01 06:25:50 +01:00
[POKENAV_MENU_TYPE_UNLOCK_MC] =
2019-07-19 23:23:52 +02:00
{
0x2A,
2020-02-01 06:25:50 +01:00
0x14,
{gUnknown_0862020C, gUnknown_08620210, gUnknown_08620214, gUnknown_0862021C}
2019-07-19 23:23:52 +02:00
},
2020-02-01 06:25:50 +01:00
[POKENAV_MENU_TYPE_UNLOCK_MC_RIBBONS] =
2019-07-19 23:23:52 +02:00
{
0x2A,
2020-02-01 06:25:50 +01:00
0x14,
{gUnknown_0862020C, gUnknown_08620210, gUnknown_08620214, gUnknown_08620218, gUnknown_0862021C}
2019-07-19 23:23:52 +02:00
},
2020-02-01 06:25:50 +01:00
[POKENAV_MENU_TYPE_CONDITION] =
2019-07-19 23:23:52 +02:00
{
0x38,
2020-02-01 06:25:50 +01:00
0x14,
{gUnknown_08620220, gUnknown_08620224, gUnknown_0862023C}
2019-07-19 23:23:52 +02:00
},
2020-02-01 06:25:50 +01:00
[POKENAV_MENU_TYPE_CONDITION_SEARCH] =
2019-07-19 23:23:52 +02:00
{
0x28,
2020-02-01 06:25:50 +01:00
0x10,
{gUnknown_08620228, gUnknown_0862022C, gUnknown_08620230, gUnknown_08620234, gUnknown_08620238, gUnknown_0862023C}
2019-07-19 23:23:52 +02:00
},
};
2020-02-01 06:25:50 +01:00
static const struct WindowTemplate sOptionDescWindowTemplate =
2019-07-19 23:23:52 +02:00
{
.bg = 1,
.tilemapLeft = 3,
.tilemapTop = 17,
.width = 0x18,
.height = 0x2,
.paletteNum = 1,
.baseBlock = 8
};
2020-02-01 06:25:50 +01:00
static const u8 *const sPageDescriptions[] =
{
[POKENAV_MENUITEM_MAP] = gText_CheckMapOfHoenn,
[POKENAV_MENUITEM_CONDITION] = gText_CheckPokemonInDetail,
[POKENAV_MENUITEM_MATCH_CALL] = gText_CallRegisteredTrainer,
[POKENAV_MENUITEM_RIBBONS] = gText_CheckObtainedRibbons,
[POKENAV_MENUITEM_SWITCH_OFF] = gText_PutAwayPokenav,
[POKENAV_MENUITEM_CONDITION_PARTY] = gText_CheckPartyPokemonInDetail,
[POKENAV_MENUITEM_CONDITION_SEARCH] = gText_CheckAllPokemonInDetail,
[POKENAV_MENUITEM_CONDITION_CANCEL] = gText_ReturnToPokenavMenu,
[POKENAV_MENUITEM_CONDITION_SEARCH_COOL] = gText_FindCoolPokemon,
[POKENAV_MENUITEM_CONDITION_SEARCH_BEAUTY] = gText_FindBeautifulPokemon,
[POKENAV_MENUITEM_CONDITION_SEARCH_CUTE] = gText_FindCutePokemon,
[POKENAV_MENUITEM_CONDITION_SEARCH_SMART] = gText_FindSmartPokemon,
[POKENAV_MENUITEM_CONDITION_SEARCH_TOUGH] = gText_FindToughPokemon,
[POKENAV_MENUITEM_CONDITION_SEARCH_CANCEL] = gText_ReturnToConditionMenu
2019-07-19 23:23:52 +02:00
};
2020-02-01 06:25:50 +01:00
static const u8 sOptionDescTextColors[] = {TEXT_COLOR_GREEN, TEXT_COLOR_BLUE, TEXT_COLOR_LIGHT_GREEN};
2019-12-10 19:48:20 +01:00
static const u8 sOptionDescTextColors2[] = {TEXT_COLOR_GREEN, TEXT_COLOR_BLUE, TEXT_COLOR_LIGHT_GREEN};
2019-07-19 23:23:52 +02:00
2020-02-01 06:25:50 +01:00
static const struct OamData sOamData_MenuOption =
2019-07-19 23:23:52 +02:00
{
.y = 0,
.affineMode = ST_OAM_AFFINE_OFF,
.objMode = ST_OAM_OBJ_NORMAL,
.bpp = ST_OAM_4BPP,
2019-07-19 23:23:52 +02:00
.shape = SPRITE_SHAPE(32x16),
.x = 0,
.size = SPRITE_SIZE(32x16),
.tileNum = 0,
.priority = 2,
.paletteNum = 0,
};
static const union AffineAnimCmd gUnknown_0862031C[] =
2019-07-19 23:23:52 +02:00
{
AFFINEANIMCMD_FRAME(0x100, 0x100, 0, 0),
AFFINEANIMCMD_END,
};
static const union AffineAnimCmd gUnknown_0862032C[] =
2019-07-19 23:23:52 +02:00
{
AFFINEANIMCMD_FRAME(0x100, 0x100, 0, 0),
AFFINEANIMCMD_FRAME(0x10, 0x10, 0, 0x12),
AFFINEANIMCMD_END,
};
2020-02-01 06:25:50 +01:00
static const union AffineAnimCmd *const sSpriteAnims_MenuOption[] =
2019-07-19 23:23:52 +02:00
{
gUnknown_0862031C,
2020-02-01 06:25:50 +01:00
gUnknown_0862032C
2019-07-19 23:23:52 +02:00
};
2020-02-01 06:25:50 +01:00
static const struct SpriteTemplate sMenuOptionSpriteTemplate =
2019-07-19 23:23:52 +02:00
{
.tileTag = 3,
.paletteTag = 4,
2020-02-01 06:25:50 +01:00
.oam = &sOamData_MenuOption,
2019-07-19 23:23:52 +02:00
.anims = gDummySpriteAnimTable,
.images = NULL,
2020-02-01 06:25:50 +01:00
.affineAnims = sSpriteAnims_MenuOption,
2019-07-19 23:23:52 +02:00
.callback = SpriteCallbackDummy,
};
static const struct OamData gUnknown_08620364 =
2019-07-19 23:23:52 +02:00
{
.y = 0,
.affineMode = ST_OAM_AFFINE_OFF,
.objMode = ST_OAM_OBJ_NORMAL,
.bpp = ST_OAM_4BPP,
2019-07-19 23:23:52 +02:00
.shape = SPRITE_SHAPE(32x16),
.x = 0,
.size = SPRITE_SIZE(32x16),
.tileNum = 0,
.priority = 2,
.paletteNum = 0,
};
static const struct SpriteTemplate gUnknown_0862036C =
2019-07-19 23:23:52 +02:00
{
.tileTag = 1,
.paletteTag = 3,
.oam = &gUnknown_08620364,
.anims = gDummySpriteAnimTable,
.images = NULL,
.affineAnims = gDummySpriteAffineAnimTable,
.callback = SpriteCallbackDummy,
};
static const struct ScanlineEffectParams gUnknown_08620384 =
2019-07-19 23:23:52 +02:00
{
(void *)REG_ADDR_WIN0H,
((DMA_ENABLE | DMA_START_HBLANK | DMA_REPEAT | DMA_DEST_RELOAD) << 16) | 1,
1,
0
2019-07-19 23:23:52 +02:00
};
2019-05-02 23:50:42 +02:00
static bool32 sub_81C98D4(void)
2019-05-02 20:27:59 +02:00
{
s32 i;
2019-05-26 12:42:01 +02:00
for (i = 0; i < REMATCH_TABLE_ENTRIES; i++)
2019-05-02 20:27:59 +02:00
{
if (sub_81CB0C8(i) == gMapHeader.regionMapSectionId
2019-12-05 21:33:36 +01:00
&& IsRematchEntryRegistered(i)
&& gSaveBlock1Ptr->trainerRematches[i])
2019-05-02 20:27:59 +02:00
return TRUE;
}
return FALSE;
}
2020-02-05 08:47:32 +01:00
bool32 OpenPokenavMenuInitial(void)
2019-05-02 20:27:59 +02:00
{
2020-02-05 08:47:32 +01:00
struct Pokenav2Struct * state = OpenPokenavMenu();
2019-05-02 20:27:59 +02:00
2020-02-05 08:47:32 +01:00
if (state == NULL)
2019-05-02 20:27:59 +02:00
return FALSE;
2020-02-05 08:47:32 +01:00
state->pokenavAlreadyOpen = FALSE;
2019-05-02 20:27:59 +02:00
return TRUE;
}
2020-02-05 08:47:32 +01:00
bool32 OpenPokenavMenuNotInitial(void)
2019-05-02 20:27:59 +02:00
{
2020-02-05 08:47:32 +01:00
struct Pokenav2Struct * state = OpenPokenavMenu();
2019-05-02 20:27:59 +02:00
2020-02-05 08:47:32 +01:00
if (state == NULL)
2019-05-02 20:27:59 +02:00
return FALSE;
2020-02-05 08:47:32 +01:00
state->pokenavAlreadyOpen = TRUE;
2019-05-02 20:27:59 +02:00
return TRUE;
}
2020-02-05 08:47:32 +01:00
static struct Pokenav2Struct * OpenPokenavMenu(void)
2019-05-02 20:27:59 +02:00
{
2020-02-05 08:47:32 +01:00
struct Pokenav2Struct * state = AllocSubstruct(2, sizeof(struct Pokenav2Struct));
2019-05-02 20:27:59 +02:00
2020-02-05 08:47:32 +01:00
if (state != NULL)
2019-05-02 20:27:59 +02:00
{
2020-02-05 08:47:32 +01:00
state->otherIconsInMotion = FALSE;
state->loopedTaskId = CreateLoopedTask(LoopedTask_OpenMenu, 1);
state->isTaskActiveCB = GetCurrentLoopedTaskActive;
2019-05-02 20:27:59 +02:00
}
2020-02-05 08:47:32 +01:00
return state;
2019-05-02 20:27:59 +02:00
}
2020-02-01 06:25:50 +01:00
void CreateMenuHandlerLoopedTask(s32 ltIdx)
2019-05-02 20:27:59 +02:00
{
2020-02-05 08:47:32 +01:00
struct Pokenav2Struct * state = GetSubstructPtr(2);
state->loopedTaskId = CreateLoopedTask(sMenuHandlerLoopTaskFuncs[ltIdx], 1);
state->isTaskActiveCB = GetCurrentLoopedTaskActive;
2019-05-02 20:27:59 +02:00
}
2020-02-05 08:47:32 +01:00
bool32 IsMenuHandlerLoopedTaskActive(void)
2019-05-02 20:27:59 +02:00
{
2020-02-05 08:47:32 +01:00
struct Pokenav2Struct * state = GetSubstructPtr(2);
return state->isTaskActiveCB();
2019-05-02 20:27:59 +02:00
}
2020-02-05 08:47:32 +01:00
void FreeMenuHandlerSubstruct2(void)
2019-05-02 20:27:59 +02:00
{
struct Pokenav2Struct * unk = GetSubstructPtr(2);
sub_81CA7F4();
2020-02-01 06:25:50 +01:00
RemoveWindow(unk->optionDescWindowId);
2019-05-02 20:27:59 +02:00
sub_81C9FEC();
sub_81CA994();
FreePokenavSubstruct(2);
}
2020-02-05 08:47:32 +01:00
static bool32 GetCurrentLoopedTaskActive(void)
2019-05-02 20:27:59 +02:00
{
struct Pokenav2Struct * unk = GetSubstructPtr(2);
return IsLoopedTaskActive(unk->loopedTaskId);
}
2019-05-02 22:19:25 +02:00
2020-02-05 08:47:32 +01:00
static u32 LoopedTask_OpenMenu(s32 state)
2019-05-02 22:19:25 +02:00
{
struct Pokenav2Struct * unk = GetSubstructPtr(2);
switch (state)
{
case 0:
InitBgTemplates(gUnknown_08620194, ARRAY_COUNT(gUnknown_08620194));
2020-05-14 10:37:09 +02:00
DecompressAndCopyTileDataToVram(1, gPokenavMessageBox_Gfx, 0, 0, 0);
2019-08-05 15:17:21 +02:00
SetBgTilemapBuffer(1, unk->bg1TilemapBuffer);
2019-05-02 22:19:25 +02:00
CopyToBgTilemapBuffer(1, gPokenavMessageBox_Tilemap, 0, 0);
CopyBgTilemapBufferToVram(1);
CopyPaletteIntoBufferUnfaded(gPokenavMessageBox_Pal, 0x10, 0x20);
ChangeBgX(1, 0, 0);
ChangeBgY(1, 0, 0);
ChangeBgX(2, 0, 0);
ChangeBgY(2, 0, 0);
ChangeBgX(3, 0, 0);
ChangeBgY(3, 0, 0);
2019-08-05 14:40:03 +02:00
return LT_INC_AND_PAUSE;
2019-05-02 22:19:25 +02:00
case 1:
2020-05-14 10:37:09 +02:00
if (FreeTempTileDataBuffersIfPossible())
2019-08-05 14:40:03 +02:00
return LT_PAUSE;
2020-05-14 10:37:09 +02:00
DecompressAndCopyTileDataToVram(2, gUnknown_0861FD6C, 0, 0, 0);
DecompressAndCopyTileDataToVram(2, gUnknown_0861FFF4, 0, 0, 1);
2019-05-02 22:19:25 +02:00
CopyPaletteIntoBufferUnfaded(gUnknown_0861FD4C, 0x20, 0x20);
2019-08-05 14:40:03 +02:00
return LT_INC_AND_PAUSE;
2019-05-02 22:19:25 +02:00
case 2:
2020-05-14 10:37:09 +02:00
if (FreeTempTileDataBuffersIfPossible())
2019-08-05 14:40:03 +02:00
return LT_PAUSE;
2020-05-14 10:37:09 +02:00
DecompressAndCopyTileDataToVram(3, gUnknown_0861FC98, 0, 0, 0);
DecompressAndCopyTileDataToVram(3, gUnknown_0861FCAC, 0, 0, 1);
2019-05-02 22:19:25 +02:00
CopyPaletteIntoBufferUnfaded(gUnknown_0861FC78, 0x30, 0x20);
2020-02-01 06:25:50 +01:00
if (GetPokenavMenuType() == POKENAV_MENU_TYPE_CONDITION || GetPokenavMenuType() == POKENAV_MENU_TYPE_CONDITION_SEARCH)
2019-05-02 22:19:25 +02:00
sub_81CA850();
2019-08-05 14:40:03 +02:00
return LT_INC_AND_PAUSE;
2019-05-02 22:19:25 +02:00
case 3:
2020-05-14 10:37:09 +02:00
if (FreeTempTileDataBuffersIfPossible())
2019-08-05 14:40:03 +02:00
return LT_PAUSE;
2020-02-01 06:25:50 +01:00
AddOptionDescriptionWindow();
2019-05-02 22:19:25 +02:00
sub_81CA7D4();
2019-08-05 14:40:03 +02:00
return LT_INC_AND_CONTINUE;
2019-05-02 22:19:25 +02:00
case 4:
sub_81C9FC4();
2019-08-05 14:40:03 +02:00
return LT_INC_AND_CONTINUE;
2019-05-02 22:19:25 +02:00
case 5:
2020-02-01 06:25:50 +01:00
PrintCurrentOptionDescription();
CreateMenuOptionSprites();
2019-05-02 22:19:25 +02:00
sub_81CA640();
sub_81CA0C8();
2019-08-05 14:40:03 +02:00
return LT_INC_AND_PAUSE;
2019-05-02 22:19:25 +02:00
case 6:
if (sub_81CA7C4())
2019-08-05 14:40:03 +02:00
return LT_PAUSE;
return LT_INC_AND_CONTINUE;
2019-05-02 22:19:25 +02:00
case 7:
ShowBg(1);
ShowBg(2);
ShowBg(3);
2020-02-05 08:47:32 +01:00
if (unk->pokenavAlreadyOpen)
PokenavFadeScreen(1);
2019-05-02 22:19:25 +02:00
else
{
2020-08-21 00:02:00 +02:00
PlaySE(SE_POKENAV_ON);
2020-02-05 08:47:32 +01:00
PokenavFadeScreen(3);
2019-05-02 22:19:25 +02:00
}
2020-02-01 06:25:50 +01:00
switch (GetPokenavMenuType())
2019-05-02 22:19:25 +02:00
{
2020-02-01 06:25:50 +01:00
case POKENAV_MENU_TYPE_CONDITION_SEARCH:
2019-05-02 22:19:25 +02:00
LoadLeftHeaderGfxForIndex(7);
// fallthrough
2020-02-01 06:25:50 +01:00
case POKENAV_MENU_TYPE_CONDITION:
2019-05-02 22:19:25 +02:00
LoadLeftHeaderGfxForIndex(1);
break;
default:
LoadLeftHeaderGfxForIndex(0);
break;
}
2019-08-05 14:40:03 +02:00
return LT_INC_AND_PAUSE;
2019-05-02 22:19:25 +02:00
case 8:
if (IsPaletteFadeActive())
2019-08-05 14:40:03 +02:00
return LT_PAUSE;
2020-02-01 06:25:50 +01:00
switch (GetPokenavMenuType())
2019-05-02 22:19:25 +02:00
{
2020-02-01 06:25:50 +01:00
case POKENAV_MENU_TYPE_CONDITION_SEARCH:
2019-05-02 22:19:25 +02:00
sub_81C7FA0(7, FALSE, FALSE);
// fallthrough
2020-02-01 06:25:50 +01:00
case POKENAV_MENU_TYPE_CONDITION:
2019-05-02 22:19:25 +02:00
sub_81C7FA0(1, FALSE, FALSE);
break;
default:
sub_81C7FA0(0, FALSE, FALSE);
break;
}
sub_81CA20C();
2019-08-05 14:46:52 +02:00
sub_81CA92C();
2019-08-05 14:40:03 +02:00
return LT_INC_AND_CONTINUE;
2019-05-02 22:19:25 +02:00
case 9:
2020-02-01 06:25:50 +01:00
if (AreMenuOptionSpritesMoving())
2019-08-05 14:40:03 +02:00
return LT_PAUSE;
2019-05-02 22:19:25 +02:00
if (sub_81C8010())
2019-08-05 14:40:03 +02:00
return LT_PAUSE;
2019-05-02 22:19:25 +02:00
break;
}
2019-08-05 14:40:03 +02:00
return LT_FINISH;
2019-05-02 22:19:25 +02:00
}
2019-05-02 22:43:32 +02:00
2020-02-01 06:25:50 +01:00
static u32 LoopedTask_MoveMenuCursor(s32 state)
2019-05-02 22:43:32 +02:00
{
switch (state)
{
case 0:
sub_81CAA3C();
sub_81CA278();
2020-02-01 06:25:50 +01:00
PrintCurrentOptionDescription();
2019-05-02 22:43:32 +02:00
PlaySE(SE_SELECT);
2019-08-05 14:40:03 +02:00
return LT_INC_AND_PAUSE;
2019-05-02 22:43:32 +02:00
case 1:
2020-02-01 06:25:50 +01:00
if (AreMenuOptionSpritesMoving())
2019-08-05 14:40:03 +02:00
return LT_PAUSE;
2019-05-02 22:43:32 +02:00
if (sub_81CA7C4())
2019-08-05 14:40:03 +02:00
return LT_PAUSE;
2019-05-02 22:43:32 +02:00
break;
}
2019-08-05 14:40:03 +02:00
return LT_FINISH;
2019-05-02 22:43:32 +02:00
}
2020-02-01 06:25:50 +01:00
static u32 LoopedTask_OpenConditionMenu(s32 state)
2019-05-02 22:43:32 +02:00
{
switch (state)
{
case 0:
sub_81CA9C8();
sub_81CA2DC();
sub_81C7FC4(0, 0);
PlaySE(SE_SELECT);
2019-08-05 14:40:03 +02:00
return LT_INC_AND_PAUSE;
2019-05-02 22:43:32 +02:00
case 1:
2020-02-01 06:25:50 +01:00
if (AreMenuOptionSpritesMoving())
2019-08-05 14:40:03 +02:00
return LT_PAUSE;
2019-05-02 22:43:32 +02:00
if (sub_81C8010())
2019-08-05 14:40:03 +02:00
return LT_PAUSE;
2019-05-02 22:43:32 +02:00
sub_81CA0C8();
LoadLeftHeaderGfxForIndex(1);
2019-08-05 14:40:03 +02:00
return LT_INC_AND_PAUSE;
2019-05-02 22:43:32 +02:00
case 2:
sub_81CA20C();
sub_81C7FA0(1, FALSE, FALSE);
sub_81CA818();
2020-02-01 06:25:50 +01:00
PrintCurrentOptionDescription();
2019-08-05 14:40:03 +02:00
return LT_INC_AND_PAUSE;
2019-05-02 22:43:32 +02:00
case 3:
2020-02-01 06:25:50 +01:00
if (AreMenuOptionSpritesMoving())
2019-08-05 14:40:03 +02:00
return LT_PAUSE;
2019-05-02 22:43:32 +02:00
if (sub_81C8010())
2019-08-05 14:40:03 +02:00
return LT_PAUSE;
2019-05-02 22:43:32 +02:00
if (sub_81CA89C())
2019-08-05 14:40:03 +02:00
return LT_PAUSE;
2019-05-02 22:43:32 +02:00
if (sub_81CA7C4())
2019-08-05 14:40:03 +02:00
return LT_PAUSE;
2019-05-02 22:43:32 +02:00
sub_81CA9D8();
break;
}
2019-08-05 14:40:03 +02:00
return LT_FINISH;
2019-05-02 22:43:32 +02:00
}
2020-02-01 06:25:50 +01:00
static u32 LoopedTask_ReturnToMainMenu(s32 state)
2019-05-02 22:43:32 +02:00
{
switch (state)
{
case 0:
sub_81CA9C8();
sub_81CA2DC();
sub_81C7FC4(1, 0);
2019-08-05 14:40:03 +02:00
return LT_INC_AND_PAUSE;
2019-05-02 22:43:32 +02:00
case 1:
2020-02-01 06:25:50 +01:00
if (AreMenuOptionSpritesMoving())
2019-08-05 14:40:03 +02:00
return LT_PAUSE;
2019-05-02 22:43:32 +02:00
if (sub_81C8010())
2019-08-05 14:40:03 +02:00
return LT_PAUSE;
2019-05-02 22:43:32 +02:00
sub_81CA0C8();
LoadLeftHeaderGfxForIndex(0);
2019-08-05 14:40:03 +02:00
return LT_INC_AND_PAUSE;
2019-05-02 22:43:32 +02:00
case 2:
sub_81CA20C();
sub_81C7FA0(0, FALSE, FALSE);
sub_81CA864();
2020-02-01 06:25:50 +01:00
PrintCurrentOptionDescription();
2019-08-05 14:40:03 +02:00
return LT_INC_AND_PAUSE;
2019-05-02 22:43:32 +02:00
case 3:
2020-02-01 06:25:50 +01:00
if (AreMenuOptionSpritesMoving())
2019-08-05 14:40:03 +02:00
return LT_PAUSE;
2019-05-02 22:43:32 +02:00
if (sub_81C8010())
2019-08-05 14:40:03 +02:00
return LT_PAUSE;
2019-05-02 22:43:32 +02:00
if (sub_81CA89C())
2019-08-05 14:40:03 +02:00
return LT_PAUSE;
2019-05-02 22:43:32 +02:00
if (sub_81CA7C4())
2019-08-05 14:40:03 +02:00
return LT_PAUSE;
2019-05-02 22:43:32 +02:00
sub_81CA9D8();
break;
}
2019-08-05 14:40:03 +02:00
return LT_FINISH;
2019-05-02 22:43:32 +02:00
}
2020-02-01 06:25:50 +01:00
static u32 LoopedTask_OpenConditionSearchMenu(s32 state)
2019-05-02 22:43:32 +02:00
{
switch (state)
{
case 0:
sub_81CA9C8();
sub_81CA2DC();
PlaySE(SE_SELECT);
2019-08-05 14:40:03 +02:00
return LT_INC_AND_PAUSE;
2019-05-02 22:43:32 +02:00
case 1:
2020-02-01 06:25:50 +01:00
if (AreMenuOptionSpritesMoving())
2019-08-05 14:40:03 +02:00
return LT_PAUSE;
2019-05-02 22:43:32 +02:00
LoadLeftHeaderGfxForIndex(7);
sub_81CA0C8();
2019-08-05 14:40:03 +02:00
return LT_INC_AND_PAUSE;
2019-05-02 22:43:32 +02:00
case 2:
sub_81CA20C();
sub_81C7FA0(7, FALSE, FALSE);
2020-02-01 06:25:50 +01:00
PrintCurrentOptionDescription();
2019-08-05 14:40:03 +02:00
return LT_INC_AND_PAUSE;
2019-05-02 22:43:32 +02:00
case 3:
2020-02-01 06:25:50 +01:00
if (AreMenuOptionSpritesMoving())
2019-08-05 14:40:03 +02:00
return LT_PAUSE;
2019-05-02 22:43:32 +02:00
if (sub_81C8010())
2019-08-05 14:40:03 +02:00
return LT_PAUSE;
2019-05-02 22:43:32 +02:00
if (sub_81CA89C())
2019-08-05 14:40:03 +02:00
return LT_PAUSE;
2019-05-02 22:43:32 +02:00
sub_81CA9D8();
break;
}
2019-08-05 14:40:03 +02:00
return LT_FINISH;
2019-05-02 22:43:32 +02:00
}
2020-02-01 06:25:50 +01:00
static u32 LoopedTask_ReturnToConditionMenu(s32 state)
2019-05-02 22:43:32 +02:00
{
switch (state)
{
case 0:
sub_81CA9C8();
sub_81CA2DC();
sub_81C7FC4(7, 0);
2019-08-05 14:40:03 +02:00
return LT_INC_AND_PAUSE;
2019-05-02 22:43:32 +02:00
case 1:
2020-02-01 06:25:50 +01:00
if (AreMenuOptionSpritesMoving())
2019-08-05 14:40:03 +02:00
return LT_PAUSE;
2019-05-02 22:43:32 +02:00
if (sub_81C8010())
2019-08-05 14:40:03 +02:00
return LT_PAUSE;
2019-05-02 22:43:32 +02:00
sub_81CA0C8();
2019-08-05 14:40:03 +02:00
return LT_INC_AND_PAUSE;
2019-05-02 22:43:32 +02:00
case 2:
sub_81CA20C();
2020-02-01 06:25:50 +01:00
PrintCurrentOptionDescription();
2019-08-05 14:40:03 +02:00
return LT_INC_AND_PAUSE;
2019-05-02 22:43:32 +02:00
case 3:
2020-02-01 06:25:50 +01:00
if (AreMenuOptionSpritesMoving())
2019-08-05 14:40:03 +02:00
return LT_PAUSE;
2019-05-02 22:43:32 +02:00
if (sub_81CA89C())
2019-08-05 14:40:03 +02:00
return LT_PAUSE;
2019-05-02 22:43:32 +02:00
sub_81CA9D8();
break;
}
2019-08-05 14:40:03 +02:00
return LT_FINISH;
2019-05-02 22:43:32 +02:00
}
2020-02-01 06:25:50 +01:00
static u32 LoopedTask_SelectRibbonsNoWinners(s32 state)
2019-05-02 22:43:32 +02:00
{
switch (state)
{
case 0:
2020-08-21 00:02:00 +02:00
PlaySE(SE_FAILURE);
2020-02-01 06:25:50 +01:00
PrintNoRibbonWinners();
2019-08-05 14:40:03 +02:00
return LT_INC_AND_PAUSE;
2019-05-02 22:43:32 +02:00
case 1:
if (IsDma3ManagerBusyWithBgCopy())
2019-08-05 14:40:03 +02:00
return LT_PAUSE;
2019-05-02 22:43:32 +02:00
break;
}
2019-08-05 14:40:03 +02:00
return LT_FINISH;
2019-05-02 22:43:32 +02:00
}
2020-02-01 06:25:50 +01:00
// For redisplaying the Ribbons description to replace the No Ribbon Winners message
static u32 LoopedTask_ReShowDescription(s32 state)
2019-05-02 22:43:32 +02:00
{
switch (state)
{
case 0:
PlaySE(SE_SELECT);
2020-02-01 06:25:50 +01:00
PrintCurrentOptionDescription();
2019-08-05 14:40:03 +02:00
return LT_INC_AND_PAUSE;
2019-05-02 22:43:32 +02:00
case 1:
if (IsDma3ManagerBusyWithBgCopy())
2019-08-05 14:40:03 +02:00
return LT_PAUSE;
2019-05-02 22:43:32 +02:00
break;
}
2019-08-05 14:40:03 +02:00
return LT_FINISH;
2019-05-02 22:43:32 +02:00
}
2020-02-01 06:25:50 +01:00
// For selecting a feature option from a menu, e.g. the Map, Match Call, Beauty search, etc.
static u32 LoopedTask_OpenPokenavFeature(s32 state)
2019-05-02 22:43:32 +02:00
{
switch (state)
{
case 0:
2019-12-07 10:08:21 +01:00
PrintHelpBarText(GetHelpBarTextId());
2019-08-05 14:40:03 +02:00
return LT_INC_AND_PAUSE;
2019-05-02 22:43:32 +02:00
case 1:
2019-12-07 10:08:21 +01:00
if (WaitForHelpBar())
2019-08-05 14:40:03 +02:00
return LT_PAUSE;
2019-05-02 22:43:32 +02:00
sub_81C7880();
sub_81CA9C8();
sub_81CA2DC();
2020-02-01 06:25:50 +01:00
switch (GetPokenavMenuType())
2019-05-02 22:43:32 +02:00
{
2020-02-01 06:25:50 +01:00
case POKENAV_MENU_TYPE_CONDITION_SEARCH:
2019-05-02 22:43:32 +02:00
sub_81C7FC4(7, FALSE);
// fallthrough
2020-02-01 06:25:50 +01:00
case POKENAV_MENU_TYPE_CONDITION:
2019-05-02 22:43:32 +02:00
sub_81C7FC4(1, FALSE);
break;
default:
sub_81C7FC4(0, FALSE);
break;
}
PlaySE(SE_SELECT);
2019-08-05 14:40:03 +02:00
return LT_INC_AND_PAUSE;
2019-05-02 22:43:32 +02:00
case 2:
2020-02-01 06:25:50 +01:00
if (AreMenuOptionSpritesMoving())
2019-08-05 14:40:03 +02:00
return LT_PAUSE;
2019-05-02 22:43:32 +02:00
if (sub_81C8010())
2019-08-05 14:40:03 +02:00
return LT_PAUSE;
2020-02-05 08:47:32 +01:00
PokenavFadeScreen(0);
2019-08-05 14:40:03 +02:00
return LT_INC_AND_PAUSE;
2019-05-02 22:43:32 +02:00
case 3:
if (IsPaletteFadeActive())
2019-08-05 14:40:03 +02:00
return LT_PAUSE;
2019-05-02 22:43:32 +02:00
break;
}
2019-08-05 14:40:03 +02:00
return LT_FINISH;
2019-05-02 22:43:32 +02:00
}
2019-05-02 23:50:42 +02:00
static void sub_81C9FC4(void)
2019-05-02 23:50:42 +02:00
{
2019-08-05 14:46:52 +02:00
s32 i;
2019-05-02 23:50:42 +02:00
2019-08-05 14:46:52 +02:00
for (i = 0; i < NELEMS(gUnknown_086201C4); i++)
2019-05-02 23:50:42 +02:00
LoadCompressedSpriteSheet(&gUnknown_086201C4[i]);
Pokenav_AllocAndLoadPalettes(gUnknown_086201D4);
}
static void sub_81C9FEC(void)
2019-05-02 23:50:42 +02:00
{
FreeSpriteTilesByTag(3);
FreeSpriteTilesByTag(1);
FreeSpritePaletteByTag(4);
FreeSpritePaletteByTag(5);
FreeSpritePaletteByTag(6);
FreeSpritePaletteByTag(7);
FreeSpritePaletteByTag(8);
FreeSpritePaletteByTag(3);
sub_81CA094();
sub_81CA698();
}
2020-02-01 06:25:50 +01:00
static void CreateMenuOptionSprites(void)
2019-05-02 23:50:42 +02:00
{
s32 i, j;
struct Pokenav2Struct * unk = GetSubstructPtr(2);
2020-02-01 06:25:50 +01:00
for (i = 0; i < MAX_POKENAV_MENUITEMS; i++)
2019-05-02 23:50:42 +02:00
{
2020-02-01 06:25:50 +01:00
// Each menu option is 4 subsprites
2019-05-02 23:50:42 +02:00
for (j = 0; j < 4; j++)
{
2020-02-01 06:25:50 +01:00
u8 spriteId = CreateSprite(&sMenuOptionSpriteTemplate, 0x8c, 20 * i + 40, 3);
2019-08-05 15:17:21 +02:00
unk->iconSprites[i][j] = &gSprites[spriteId];
2019-05-02 23:50:42 +02:00
gSprites[spriteId].pos2.x = 32 * j;
}
}
}
static void sub_81CA094(void)
2019-05-02 23:50:42 +02:00
{
s32 i, j;
struct Pokenav2Struct * unk = GetSubstructPtr(2);
2020-02-01 06:25:50 +01:00
for (i = 0; i < MAX_POKENAV_MENUITEMS; i++)
2019-05-02 23:50:42 +02:00
{
for (j = 0; j < 4; j++)
{
2019-08-05 15:17:21 +02:00
FreeSpriteOamMatrix(unk->iconSprites[i][j]);
DestroySprite(unk->iconSprites[i][j]);
2019-05-02 23:50:42 +02:00
}
}
}
static void sub_81CA0C8(void)
2019-05-02 23:50:42 +02:00
{
2020-02-01 06:25:50 +01:00
s32 menuType = GetPokenavMenuType();
sub_81CA0EC(gUnknown_08620240[menuType].unk4, gUnknown_08620240[menuType].unk0, gUnknown_08620240[menuType].unk2);
2019-05-02 23:50:42 +02:00
}
static void sub_81CA0EC(const u16 *const *a0, s32 a1, s32 a2)
2019-05-02 23:50:42 +02:00
{
s32 i, j;
struct Pokenav2Struct * unk = GetSubstructPtr(2);
s32 sp04 = GetSpriteTileStartByTag(3);
2020-02-01 06:25:50 +01:00
for (i = 0; i < MAX_POKENAV_MENUITEMS; i++)
2019-05-02 23:50:42 +02:00
{
if (*a0 != NULL)
{
for (j = 0; j < 4; j++)
{
2019-08-05 15:17:21 +02:00
unk->iconSprites[i][j]->oam.tileNum = (*a0)[0] + sp04 + 8 * j;
unk->iconSprites[i][j]->oam.paletteNum = IndexOfSpritePaletteTag((*a0)[1] + 4);
unk->iconSprites[i][j]->invisible = TRUE;
unk->iconSprites[i][j]->pos1.y = a1;
unk->iconSprites[i][j]->pos1.x = 0x8c;
unk->iconSprites[i][j]->pos2.x = 32 * j;
2019-05-02 23:50:42 +02:00
}
2019-08-05 15:17:21 +02:00
unk->iconVisible[i] = TRUE;
2019-05-02 23:50:42 +02:00
}
else
{
for (j = 0; j < 4; j++)
{
2019-08-05 15:17:21 +02:00
unk->iconSprites[i][j]->invisible = TRUE;
2019-05-02 23:50:42 +02:00
}
2019-08-05 15:17:21 +02:00
unk->iconVisible[i] = FALSE;
2019-05-02 23:50:42 +02:00
}
a0++;
a1 += a2;
}
}
2019-07-31 01:46:56 +02:00
static void sub_81CA20C(void)
2019-07-31 01:46:56 +02:00
{
s32 i;
struct Pokenav2Struct * unk = GetSubstructPtr(2);
2020-02-01 06:25:50 +01:00
s32 r8 = GetPokenavCursorPos();
2019-07-31 01:46:56 +02:00
s32 r7 = 0;
s32 r2;
2020-02-01 06:25:50 +01:00
for (i = 0; i < MAX_POKENAV_MENUITEMS; i++)
2019-07-31 01:46:56 +02:00
{
2019-08-05 15:17:21 +02:00
if (unk->iconVisible[i])
2019-07-31 01:46:56 +02:00
{
if (r7++ == r8)
{
r2 = 0x82;
2019-08-05 15:17:21 +02:00
unk->cursorPos = i;
2019-07-31 01:46:56 +02:00
}
else
r2 = 0x8c;
2019-08-05 15:17:21 +02:00
sub_81CA35C(unk->iconSprites[i], 0x100, r2, 0xC);
sub_81CA448(unk->iconSprites[i], FALSE);
2019-07-31 01:46:56 +02:00
}
else
2019-08-05 15:17:21 +02:00
sub_81CA448(unk->iconSprites[i], TRUE);
2019-07-31 01:46:56 +02:00
}
}
static void sub_81CA278(void)
2019-07-31 01:46:56 +02:00
{
s32 i;
struct Pokenav2Struct * unk = GetSubstructPtr(2);
2020-02-01 06:25:50 +01:00
s32 r3 = GetPokenavCursorPos();
2019-07-31 01:46:56 +02:00
s32 r5;
2020-02-01 06:25:50 +01:00
for (i = 0, r5 = 0; i < MAX_POKENAV_MENUITEMS; i++)
2019-07-31 01:46:56 +02:00
{
2019-08-05 15:17:21 +02:00
if (unk->iconVisible[i])
2019-07-31 01:46:56 +02:00
{
if (r5 == r3)
{
r5 = i;
break;
}
r5++;
}
}
2019-08-05 15:17:21 +02:00
sub_81CA35C(unk->iconSprites[unk->cursorPos], 0x82, 0x8c, 0x4);
sub_81CA35C(unk->iconSprites[r5], 0x8c, 0x82, 0x4);
unk->cursorPos = r5;
2019-07-31 01:46:56 +02:00
}
static void sub_81CA2DC(void)
2019-07-31 01:46:56 +02:00
{
s32 i;
struct Pokenav2Struct * unk = GetSubstructPtr(2);
2020-02-01 06:25:50 +01:00
for (i = 0; i < MAX_POKENAV_MENUITEMS; i++)
2019-07-31 01:46:56 +02:00
{
2019-08-05 15:17:21 +02:00
if (unk->iconVisible[i])
2019-07-31 01:46:56 +02:00
{
2019-08-05 15:17:21 +02:00
if (unk->cursorPos != i)
sub_81CA35C(unk->iconSprites[i], 0x8C, 0x100, 0x8);
2019-07-31 01:46:56 +02:00
else
2019-08-05 15:17:21 +02:00
sub_81CA3B4(unk->iconSprites[i]);
2019-07-31 01:46:56 +02:00
}
}
}
2020-02-01 06:25:50 +01:00
static bool32 AreMenuOptionSpritesMoving(void)
2019-07-31 01:46:56 +02:00
{
s32 i;
struct Pokenav2Struct * unk = GetSubstructPtr(2);
2020-02-01 06:25:50 +01:00
for (i = 0; i < MAX_POKENAV_MENUITEMS; i++)
2019-07-31 01:46:56 +02:00
{
2019-08-05 15:17:21 +02:00
if (unk->iconSprites[i][0]->callback != SpriteCallbackDummy)
2019-07-31 01:46:56 +02:00
return TRUE;
}
2019-08-05 15:17:21 +02:00
if (unk->otherIconsInMotion)
2019-07-31 01:46:56 +02:00
return TRUE;
return FALSE;
}
static void sub_81CA35C(struct Sprite ** sprites, s32 a1, s32 a2, s32 a3)
2019-07-31 01:46:56 +02:00
{
s32 i;
for (i = 0; i < 4; i++)
{
2019-08-05 00:15:02 +02:00
(*sprites)->pos1.x = a1;
(*sprites)->data[0] = a3;
(*sprites)->data[1] = 16 * (a2 - a1) / a3;
(*sprites)->data[2] = 16 * a1;
(*sprites)->data[7] = a2;
(*sprites)->callback = sub_81CA474;
sprites++;
2019-07-31 01:46:56 +02:00
}
}
2019-08-05 00:15:02 +02:00
static void sub_81CA3B4(struct Sprite ** sprites)
2019-08-05 00:15:02 +02:00
{
s32 i;
struct Pokenav2Struct * unk = GetSubstructPtr(2);
u8 taskId;
for (i = 0; i < 4; i++)
{
(*sprites)->oam.objMode = ST_OAM_OBJ_BLEND;
(*sprites)->oam.affineMode = ST_OAM_AFFINE_DOUBLE;
(*sprites)->callback = sub_81CA4AC;
(*sprites)->data[0] = 8;
(*sprites)->data[1] = 0;
(*sprites)->data[7] = i;
InitSpriteAffineAnim(sprites[0]);
StartSpriteAffineAnim(sprites[0], 0);
sprites++;
}
SetGpuReg(REG_OFFSET_BLDALPHA, BLDALPHA_BLEND(0x10, 0x00));
taskId = CreateTask(sub_81CA580, 3);
gTasks[taskId].data[0] = 8;
2019-08-05 15:17:21 +02:00
unk->otherIconsInMotion++;
2019-08-05 00:15:02 +02:00
}
static void sub_81CA448(struct Sprite ** sprites, bool32 a1)
{
2019-08-05 00:15:02 +02:00
s32 i;
for (i = 0; i < 4; i++)
{
(*sprites)->invisible = a1;
sprites++;
}
}
static void sub_81CA474(struct Sprite * sprite)
2019-08-05 00:15:02 +02:00
{
sprite->data[0]--;
if (sprite->data[0] != -1)
{
sprite->data[2] += sprite->data[1];
sprite->pos1.x = sprite->data[2] >> 4;
}
else
{
sprite->pos1.x = sprite->data[7];
sprite->callback = SpriteCallbackDummy;
}
}
2019-08-05 02:39:36 +02:00
static void sub_81CA4AC(struct Sprite * sprite)
2019-08-05 02:39:36 +02:00
{
s32 r0;
s32 r1;
if (sprite->data[0] == 0)
{
if (sprite->data[1] == 0)
{
StartSpriteAffineAnim(sprite, 1);
sprite->data[1]++;
sprite->data[2] = 0x100;
sprite->pos1.x += sprite->pos2.x;
sprite->pos2.x = 0;
}
else
{
sprite->data[2] += 16;
r0 = sprite->data[2];
r1 = r0 >> 3;
r1 = (r1 - 32) / 2;
switch (sprite->data[7])
{
case 0:
sprite->pos2.x = -r1 * 3;
break;
case 1:
sprite->pos2.x = -r1;
break;
case 2:
sprite->pos2.x = r1;
break;
case 3:
sprite->pos2.x = r1 * 3;
break;
}
if (sprite->affineAnimEnded)
{
sprite->invisible = TRUE;
FreeOamMatrix(sprite->oam.matrixNum);
CalcCenterToCornerVec(sprite, sprite->oam.shape, sprite->oam.size, ST_OAM_AFFINE_OFF);
2019-08-05 02:39:36 +02:00
sprite->oam.affineMode = ST_OAM_AFFINE_OFF;
sprite->oam.objMode = ST_OAM_OBJ_NORMAL;
sprite->callback = SpriteCallbackDummy;
}
}
}
else
{
sprite->data[0]--;
}
}
static void sub_81CA580(u8 taskId)
2019-08-05 02:39:36 +02:00
{
s16 * data = gTasks[taskId].data;
if (data[0] == 0)
{
switch (data[1])
{
case 0:
data[2] = 16;
data[3] = 0;
SetGpuReg(REG_OFFSET_BLDCNT, BLDCNT_EFFECT_NONE | BLDCNT_TGT2_ALL);
SetGpuReg(REG_OFFSET_BLDALPHA, BLDALPHA_BLEND(0x10, 0x00));
data[1]++;
break;
case 1:
if (data[4] & 1)
{
data[2] -= 3;
if (data[2] < 0)
data[2] = 0;
}
else
{
data[3] += 3;
if (data[3] > 16)
data[3] = 16;
}
SetGpuReg(REG_OFFSET_BLDALPHA, BLDALPHA_BLEND(data[2], data[3]));
data[4]++;
if (data[4] == 12)
{
2019-08-05 15:17:21 +02:00
((struct Pokenav2Struct *)GetSubstructPtr(2))->otherIconsInMotion--;
2019-08-05 02:39:36 +02:00
SetGpuReg(REG_OFFSET_BLDALPHA, BLDALPHA_BLEND(0x00, 0x10));
DestroyTask(taskId);
}
break;
}
}
else
data[0]--;
}
static void sub_81CA640(void)
2019-08-05 02:39:36 +02:00
{
struct Pokenav2Struct * ptr = GetSubstructPtr(2);
u8 spriteId = CreateSprite(&gUnknown_0862036C, 0x10, 0x60, 4);
ptr->field_028 = &gSprites[spriteId];
if (sub_81C98D4())
ptr->field_028->callback = sub_81CA6AC;
else
ptr->field_028->invisible = TRUE;
}
static void sub_81CA698(void)
2019-08-05 02:39:36 +02:00
{
struct Pokenav2Struct * ptr = GetSubstructPtr(2);
DestroySprite(ptr->field_028);
}
static void sub_81CA6AC(struct Sprite * sprite)
2019-08-05 02:39:36 +02:00
{
sprite->data[0]++;
if (sprite->data[0] > 8)
{
sprite->data[0] = 0;
sprite->invisible ^= 1;
}
}
2020-02-01 06:25:50 +01:00
static void AddOptionDescriptionWindow(void)
2019-08-05 02:39:36 +02:00
{
struct Pokenav2Struct * ptr = GetSubstructPtr(2);
2020-02-01 06:25:50 +01:00
ptr->optionDescWindowId = AddWindow(&sOptionDescWindowTemplate);
PutWindowTilemap(ptr->optionDescWindowId);
FillWindowPixelBuffer(ptr->optionDescWindowId, PIXEL_FILL(6));
CopyWindowToVram(ptr->optionDescWindowId, 3);
2019-08-05 02:39:36 +02:00
}
2020-02-01 06:25:50 +01:00
static void PrintCurrentOptionDescription(void)
2019-08-05 02:39:36 +02:00
{
struct Pokenav2Struct * ptr = GetSubstructPtr(2);
2020-02-01 06:25:50 +01:00
int menuItem = GetCurrentMenuItemId();
const u8 * s = sPageDescriptions[menuItem];
2019-08-05 02:39:36 +02:00
u32 width = GetStringWidth(1, s, -1);
2020-02-01 06:25:50 +01:00
FillWindowPixelBuffer(ptr->optionDescWindowId, PIXEL_FILL(6));
AddTextPrinterParameterized3(ptr->optionDescWindowId, 1, (192 - width) / 2, 1, sOptionDescTextColors, 0, s);
2019-08-05 02:39:36 +02:00
}
2020-02-01 06:25:50 +01:00
// Printed when Ribbons is selected if no PC/party mons have ribbons
// Can occur by obtaining a mon with a ribbon and then releasing all ribbon winners
static void PrintNoRibbonWinners(void)
2019-08-05 02:39:36 +02:00
{
struct Pokenav2Struct * ptr = GetSubstructPtr(2);
const u8 * s = gText_NoRibbonWinners;
u32 width = GetStringWidth(1, s, -1);
2020-02-01 06:25:50 +01:00
FillWindowPixelBuffer(ptr->optionDescWindowId, PIXEL_FILL(6));
AddTextPrinterParameterized3(ptr->optionDescWindowId, 1, (192 - width) / 2, 1, sOptionDescTextColors2, 0, s);
2019-08-05 02:39:36 +02:00
}
static bool32 sub_81CA7C4(void)
2019-08-05 02:39:36 +02:00
{
return IsDma3ManagerBusyWithBgCopy();
}
static void sub_81CA7D4(void)
2019-08-05 02:39:36 +02:00
{
struct Pokenav2Struct * ptr = GetSubstructPtr(2);
2019-08-05 15:17:21 +02:00
ptr->bg3ScrollTaskId = CreateTask(sub_81CA808, 2);
2019-08-05 02:39:36 +02:00
}
static void sub_81CA7F4(void)
2019-08-05 02:39:36 +02:00
{
struct Pokenav2Struct * ptr = GetSubstructPtr(2);
2019-08-05 15:17:21 +02:00
DestroyTask(ptr->bg3ScrollTaskId);
2019-08-05 02:39:36 +02:00
}
static void sub_81CA808(u8 taskId)
2019-08-05 02:39:36 +02:00
{
ChangeBgX(3, 0x80, 1);
}
static void sub_81CA818(void)
2019-08-05 02:39:36 +02:00
{
u8 taskId = CreateTask(sub_81CA8B0, 3);
SetWordTaskArg(taskId, 1, (uintptr_t)(gUnknown_0861FC78 + 1));
SetWordTaskArg(taskId, 3, (uintptr_t)(gUnknown_0861FC78 + 7));
}
static void sub_81CA850(void)
2019-08-05 02:39:36 +02:00
{
CopyPaletteIntoBufferUnfaded(gUnknown_0861FC78 + 7, 0x31, 4);
}
static void sub_81CA864(void)
2019-08-05 02:39:36 +02:00
{
u8 taskId = CreateTask(sub_81CA8B0, 3);
SetWordTaskArg(taskId, 1, (uintptr_t)(gUnknown_0861FC78 + 7));
SetWordTaskArg(taskId, 3, (uintptr_t)(gUnknown_0861FC78 + 1));
}
static bool32 sub_81CA89C(void)
2019-08-05 02:39:36 +02:00
{
return FuncIsActiveTask(sub_81CA8B0);
}
static void sub_81CA8B0(u8 taskId)
2019-08-05 02:39:36 +02:00
{
u16 sp8[2];
s16 * data = gTasks[taskId].data;
const u16 * pal1 = (const u16 *)GetWordTaskArg(taskId, 1);
const u16 * pal2 = (const u16 *)GetWordTaskArg(taskId, 3);
sub_81C79BC(pal1, pal2, 2, 12, ++data[0], sp8);
LoadPalette(sp8, 0x31, 4);
if (data[0] == 12)
DestroyTask(taskId);
}
static void sub_81CA914(void)
2019-08-05 02:39:36 +02:00
{
TransferPlttBuffer();
LoadOam();
ProcessSpriteCopyRequests();
ScanlineEffect_InitHBlankDmaTransfer();
}
2019-08-05 14:46:52 +02:00
static void sub_81CA92C(void)
2019-08-05 02:39:36 +02:00
{
SetGpuReg(REG_OFFSET_BLDCNT, BLDCNT_TGT1_OBJ | BLDCNT_EFFECT_LIGHTEN);
SetGpuReg(REG_OFFSET_BLDY, 0);
SetGpuRegBits(REG_OFFSET_DISPCNT, DISPCNT_WIN0_ON);
SetGpuRegBits(REG_OFFSET_WININ, 0x3F);
SetGpuRegBits(REG_OFFSET_WINOUT, 0x1F);
SetGpuRegBits(REG_OFFSET_WIN0V, 0xA0);
ScanlineEffect_Stop();
sub_81CAA3C();
ScanlineEffect_SetParams(gUnknown_08620384);
SetVBlankCallback_(sub_81CA914);
CreateTask(sub_81CA9EC, 3);
}
static void sub_81CA994(void)
2019-08-05 02:39:36 +02:00
{
SetGpuReg(REG_OFFSET_BLDCNT, 0);
ClearGpuRegBits(REG_OFFSET_DISPCNT, DISPCNT_WIN0_ON);
ScanlineEffect_Stop();
DestroyTask(FindTaskIdByFunc(sub_81CA9EC));
SetPokenavVBlankCallback();
}
static void sub_81CA9C8(void)
2019-08-05 02:39:36 +02:00
{
SetGpuReg(REG_OFFSET_BLDCNT, 0);
}
static void sub_81CA9D8(void)
2019-08-05 02:39:36 +02:00
{
sub_81CAA3C();
SetGpuReg(REG_OFFSET_BLDCNT, BLDCNT_TGT1_OBJ | BLDCNT_EFFECT_LIGHTEN);
}
static void sub_81CA9EC(u8 taskId)
2019-08-05 02:39:36 +02:00
{
s16 * data = gTasks[taskId].data;
data[0]++;
if (data[0] > 0)
{
data[0] = 0;
data[1] += 3;
data[1] &= 0x7F;
SetGpuReg(REG_OFFSET_BLDY, gSineTable[data[1]] >> 5);
}
}
static void sub_81CAA3C(void)
2019-08-05 02:39:36 +02:00
{
2020-02-01 06:25:50 +01:00
int menuType = GetPokenavMenuType();
int cursorPos = GetPokenavCursorPos();
int r4 = gUnknown_08620240[menuType].unk2 * cursorPos + gUnknown_08620240[menuType].unk0 - 8;
2019-08-05 02:39:36 +02:00
CpuFill16(0, gScanlineEffectRegBuffers[0], 0x140);
CpuFill16(0, gScanlineEffectRegBuffers[1], 0x140);
CpuFill16(RGB(16, 23, 28), &gScanlineEffectRegBuffers[0][r4], 0x20);
CpuFill16(RGB(16, 23, 28), &gScanlineEffectRegBuffers[1][r4], 0x20);
2019-08-05 02:39:36 +02:00
}
void sub_81CAADC(void)
{
sub_81CA9C8();
}