2019-03-05 12:06:20 +01:00
|
|
|
#include "global.h"
|
2019-09-09 03:07:54 +02:00
|
|
|
#include "malloc.h"
|
2019-03-08 07:56:38 +01:00
|
|
|
#include "battle_main.h"
|
|
|
|
#include "contest_effect.h"
|
2019-04-04 23:53:06 +02:00
|
|
|
#include "data.h"
|
2019-03-31 12:59:01 +02:00
|
|
|
#include "decompress.h"
|
2019-03-07 04:27:30 +01:00
|
|
|
#include "gpu_regs.h"
|
2019-03-31 12:59:01 +02:00
|
|
|
#include "graphics.h"
|
2019-03-08 07:56:38 +01:00
|
|
|
#include "menu.h"
|
2019-03-05 12:06:20 +01:00
|
|
|
#include "international_string_util.h"
|
|
|
|
#include "menu.h"
|
2019-03-08 08:17:01 +01:00
|
|
|
#include "menu_specialized.h"
|
2019-03-08 07:56:38 +01:00
|
|
|
#include "move_relearner.h"
|
|
|
|
#include "palette.h"
|
2019-03-05 12:06:20 +01:00
|
|
|
#include "player_pc.h"
|
2019-03-08 07:56:38 +01:00
|
|
|
#include "pokemon_summary_screen.h"
|
2019-03-31 12:59:01 +02:00
|
|
|
#include "pokemon_storage_system.h"
|
2019-03-07 04:27:30 +01:00
|
|
|
#include "scanline_effect.h"
|
2019-03-05 12:06:20 +01:00
|
|
|
#include "sound.h"
|
|
|
|
#include "strings.h"
|
|
|
|
#include "string_util.h"
|
2019-03-31 12:59:01 +02:00
|
|
|
#include "text.h"
|
2019-03-08 07:56:38 +01:00
|
|
|
#include "text_window.h"
|
2019-03-07 04:27:30 +01:00
|
|
|
#include "trig.h"
|
2019-03-05 12:06:20 +01:00
|
|
|
#include "window.h"
|
2020-08-10 23:05:42 +02:00
|
|
|
#include "constants/berry.h"
|
2019-03-05 12:06:20 +01:00
|
|
|
#include "constants/songs.h"
|
2019-03-07 04:27:30 +01:00
|
|
|
#include "gba/io_reg.h"
|
2019-03-05 12:06:20 +01:00
|
|
|
|
2019-03-31 12:59:01 +02:00
|
|
|
extern const struct CompressedSpriteSheet gMonFrontPicTable[];
|
|
|
|
|
2019-03-06 04:32:28 +01:00
|
|
|
EWRAM_DATA static u8 sUnknown_0203CF48[3] = {0};
|
|
|
|
EWRAM_DATA static struct ListMenuItem *sUnknown_0203CF4C = NULL;
|
2019-03-05 12:06:20 +01:00
|
|
|
|
2019-03-08 08:10:44 +01:00
|
|
|
static void sub_81D1E7C(s32 itemIndex, bool8 onInit, struct ListMenu *list);
|
2020-08-12 17:44:39 +02:00
|
|
|
static void sub_81D24A4(struct ConditionGraph *a0);
|
|
|
|
static void sub_81D2634(struct ConditionGraph *a0);
|
2019-03-08 08:10:44 +01:00
|
|
|
static void MoveRelearnerCursorCallback(s32 itemIndex, bool8 onInit, struct ListMenu *list);
|
|
|
|
static void nullsub_79(void);
|
2020-08-12 17:44:39 +02:00
|
|
|
static void SetNextConditionSparkle(struct Sprite *sprite);
|
2020-08-10 19:48:16 +02:00
|
|
|
static void SpriteCB_ConditionSparkle(struct Sprite *sprite);
|
2020-08-12 17:44:39 +02:00
|
|
|
static void ShowAllConditionSparkles(struct Sprite *sprite);
|
2019-03-05 12:06:20 +01:00
|
|
|
|
2019-03-06 04:32:28 +01:00
|
|
|
static const struct WindowTemplate sUnknown_086253E8[] =
|
2019-03-05 12:06:20 +01:00
|
|
|
{
|
2019-03-08 08:10:44 +01:00
|
|
|
{
|
2019-03-05 12:06:20 +01:00
|
|
|
.bg = 0,
|
|
|
|
.tilemapLeft = 1,
|
|
|
|
.tilemapTop = 1,
|
|
|
|
.width = 8,
|
|
|
|
.height = 2,
|
|
|
|
.paletteNum = 0xF,
|
|
|
|
.baseBlock = 0x8
|
|
|
|
},
|
2019-03-08 08:10:44 +01:00
|
|
|
{
|
2019-03-05 12:06:20 +01:00
|
|
|
.bg = 0,
|
|
|
|
.tilemapLeft = 21,
|
|
|
|
.tilemapTop = 1,
|
|
|
|
.width = 8,
|
|
|
|
.height = 18,
|
|
|
|
.paletteNum = 0xF,
|
|
|
|
.baseBlock = 0x18
|
|
|
|
},
|
2019-03-08 08:10:44 +01:00
|
|
|
{
|
2019-03-05 12:06:20 +01:00
|
|
|
.bg = 0,
|
|
|
|
.tilemapLeft = 1,
|
|
|
|
.tilemapTop = 1,
|
|
|
|
.width = 11,
|
|
|
|
.height = 8,
|
|
|
|
.paletteNum = 0xF,
|
|
|
|
.baseBlock = 0x18
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2019-12-10 19:48:20 +01:00
|
|
|
static const u8 sPlayerNameTextColors[] =
|
2019-03-06 04:32:28 +01:00
|
|
|
{
|
2019-12-10 19:48:20 +01:00
|
|
|
TEXT_COLOR_WHITE, TEXT_COLOR_DARK_GREY, TEXT_COLOR_LIGHT_GREY
|
2019-03-05 12:06:20 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
static const u8 sEmptyItemName[] = _("");
|
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
static const struct ScanlineEffectParams sConditionGraphScanline =
|
2019-03-06 04:32:28 +01:00
|
|
|
{
|
|
|
|
.dmaDest = (void*)REG_ADDR_WIN0H,
|
|
|
|
.dmaControl = SCANLINE_EFFECT_DMACNT_32BIT,
|
|
|
|
.initState = 1,
|
|
|
|
};
|
|
|
|
|
2019-03-07 04:58:05 +01:00
|
|
|
static const u8 sUnknown_08625410[] =
|
2019-03-07 04:27:30 +01:00
|
|
|
{
|
|
|
|
4,
|
|
|
|
5,
|
|
|
|
6,
|
|
|
|
7,
|
|
|
|
8,
|
|
|
|
9, 9,
|
|
|
|
10, 10,
|
|
|
|
0xB, 0xB,
|
|
|
|
0xC, 0xC,
|
|
|
|
0xD, 0xD,
|
|
|
|
0xD, 0xD,
|
|
|
|
0xE, 0xE, 0xE, 0xE,
|
|
|
|
0xF, 0xF, 0xF, 0xF,
|
|
|
|
0x10, 0x10, 0x10, 0x10, 0x10, 0x10,
|
|
|
|
0x11, 0x11, 0x11, 0x11, 0x11, 0x11,
|
|
|
|
0x12, 0x12, 0x12, 0x12, 0x12, 0x12,
|
|
|
|
0x13, 0x13, 0x13, 0x13, 0x13, 0x13, 0x13, 0x13,
|
|
|
|
0x14, 0x14, 0x14, 0x14, 0x14, 0x14, 0x14, 0x14,
|
|
|
|
0x15, 0x15, 0x15, 0x15, 0x15, 0x15, 0x15, 0x15,
|
|
|
|
0x16, 0x16, 0x16, 0x16, 0x16, 0x16, 0x16, 0x16, 0x16, 0x16,
|
|
|
|
0x17, 0x17, 0x17, 0x17, 0x17, 0x17, 0x17, 0x17, 0x17, 0x17,
|
|
|
|
0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18,
|
|
|
|
0x19, 0x19, 0x19, 0x19, 0x19, 0x19, 0x19, 0x19, 0x19, 0x19, 0x19, 0x19,
|
|
|
|
0x1A, 0x1A, 0x1A, 0x1A, 0x1A, 0x1A, 0x1A, 0x1A, 0x1A, 0x1A, 0x1A, 0x1A,
|
|
|
|
0x1B, 0x1B, 0x1B, 0x1B, 0x1B, 0x1B, 0x1B, 0x1B, 0x1B, 0x1B, 0x1B, 0x1B, 0x1B, 0x1B,
|
|
|
|
0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C, 0x1C,
|
|
|
|
0x1D, 0x1D, 0x1D, 0x1D, 0x1D, 0x1D, 0x1D, 0x1D, 0x1D, 0x1D, 0x1D, 0x1D, 0x1D, 0x1D, 0x1D, 0x1D,
|
|
|
|
0x1E, 0x1E, 0x1E, 0x1E, 0x1E, 0x1E, 0x1E, 0x1E, 0x1E, 0x1E, 0x1E, 0x1E, 0x1E, 0x1E, 0x1E, 0x1E,
|
|
|
|
0x1F, 0x1F, 0x1F, 0x1F, 0x1F, 0x1F, 0x1F, 0x1F, 0x1F, 0x1F, 0x1F, 0x1F, 0x1F, 0x1F, 0x1F, 0x1F, 0x1F,
|
|
|
|
0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20,
|
|
|
|
0x21, 0x21, 0x21, 0x21, 0x21, 0x21, 0x21, 0x21, 0x21, 0x21, 0x21, 0x21, 0x21, 0x21, 0x21, 0x21, 0x21, 0x21, 0x21,
|
|
|
|
0x22, 0x22, 0x22, 0x22, 0x22, 0x22, 0x22, 0x22, 0x22, 0x22, 0x22, 0x22, 0x22, 0x22, 0x22, 0x22, 0x22, 0x22, 0x22, 0x22,
|
|
|
|
0x23
|
|
|
|
};
|
|
|
|
|
2019-03-07 04:58:05 +01:00
|
|
|
|
2019-03-08 08:10:44 +01:00
|
|
|
static const struct WindowTemplate sMoveRelearnerWindowTemplates[] =
|
2019-03-07 04:58:05 +01:00
|
|
|
{
|
|
|
|
{
|
|
|
|
.bg = 1,
|
|
|
|
.tilemapLeft = 1,
|
|
|
|
.tilemapTop = 1,
|
|
|
|
.width = 16,
|
|
|
|
.height = 12,
|
|
|
|
.paletteNum = 0xF,
|
|
|
|
.baseBlock = 0xA
|
|
|
|
},
|
|
|
|
{
|
|
|
|
.bg = 1,
|
|
|
|
.tilemapLeft = 1,
|
|
|
|
.tilemapTop = 1,
|
|
|
|
.width = 16,
|
|
|
|
.height = 12,
|
|
|
|
.paletteNum = 0xF,
|
|
|
|
.baseBlock = 0xCA
|
|
|
|
},
|
|
|
|
{
|
|
|
|
.bg = 1,
|
|
|
|
.tilemapLeft = 19,
|
|
|
|
.tilemapTop = 1,
|
|
|
|
.width = 10,
|
|
|
|
.height = 12,
|
|
|
|
.paletteNum = 0xF,
|
|
|
|
.baseBlock = 0x18A
|
|
|
|
},
|
|
|
|
{
|
|
|
|
.bg = 1,
|
|
|
|
.tilemapLeft = 4,
|
|
|
|
.tilemapTop = 15,
|
|
|
|
.width = 22,
|
|
|
|
.height = 4,
|
|
|
|
.paletteNum = 0xF,
|
|
|
|
.baseBlock = 0x202
|
|
|
|
},
|
|
|
|
{
|
|
|
|
.bg = 0,
|
|
|
|
.tilemapLeft = 22,
|
|
|
|
.tilemapTop = 8,
|
|
|
|
.width = 5,
|
|
|
|
.height = 4,
|
|
|
|
.paletteNum = 0xF,
|
|
|
|
.baseBlock = 0x25A
|
|
|
|
},
|
|
|
|
DUMMY_WIN_TEMPLATE
|
|
|
|
};
|
|
|
|
|
2019-03-08 08:10:44 +01:00
|
|
|
static const struct WindowTemplate sMoveRelearnerYesNoMenuTemplate =
|
2019-03-07 04:58:05 +01:00
|
|
|
{
|
|
|
|
.bg = 0,
|
|
|
|
.tilemapLeft = 22,
|
|
|
|
.tilemapTop = 8,
|
|
|
|
.width = 5,
|
|
|
|
.height = 4,
|
|
|
|
.paletteNum = 0xF,
|
|
|
|
.baseBlock = 0x25A
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2019-03-08 08:10:44 +01:00
|
|
|
static const struct ListMenuTemplate sMoveRelearnerMovesListTemplate =
|
2019-03-07 04:58:05 +01:00
|
|
|
{
|
|
|
|
.items = NULL,
|
|
|
|
.moveCursorFunc = MoveRelearnerCursorCallback,
|
|
|
|
.itemPrintFunc = NULL,
|
|
|
|
.totalItems = 0,
|
|
|
|
.maxShowed = 0,
|
|
|
|
.windowId = 2,
|
|
|
|
.header_X = 0,
|
|
|
|
.item_X = 8,
|
|
|
|
.cursor_X = 0,
|
|
|
|
.upText_Y = 1,
|
|
|
|
.cursorPal = 2,
|
|
|
|
.fillValue = 1,
|
|
|
|
.cursorShadowPal = 3,
|
|
|
|
.lettersSpacing = 0,
|
|
|
|
.itemVerticalPadding = 0,
|
|
|
|
.scrollMultiple = LIST_NO_MULTIPLE_SCROLL,
|
|
|
|
.fontId = 1,
|
|
|
|
.cursorKind = 0
|
|
|
|
};
|
|
|
|
|
2019-03-05 12:06:20 +01:00
|
|
|
bool8 sub_81D1C44(u8 count)
|
|
|
|
{
|
2019-03-22 17:27:18 +01:00
|
|
|
u8 i;
|
|
|
|
|
|
|
|
sUnknown_0203CF4C = Alloc(count * sizeof(*sUnknown_0203CF4C) + sizeof(*sUnknown_0203CF4C));
|
2019-03-06 04:32:28 +01:00
|
|
|
if (sUnknown_0203CF4C == NULL)
|
2019-03-05 12:06:20 +01:00
|
|
|
return FALSE;
|
2019-03-22 17:27:18 +01:00
|
|
|
|
|
|
|
for (i = 0; i < ARRAY_COUNT(sUnknown_0203CF48); i++)
|
|
|
|
sUnknown_0203CF48[i] = 0xFF;
|
2019-03-05 12:06:20 +01:00
|
|
|
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
u8 sub_81D1C84(u8 a0)
|
|
|
|
{
|
2019-03-22 17:27:18 +01:00
|
|
|
if (sUnknown_0203CF48[a0] == 0xFF)
|
2019-03-05 12:06:20 +01:00
|
|
|
{
|
2019-03-08 08:10:44 +01:00
|
|
|
if (a0 == 2)
|
2019-03-05 12:06:20 +01:00
|
|
|
{
|
2019-03-22 17:27:18 +01:00
|
|
|
struct WindowTemplate template = sUnknown_086253E8[2];
|
|
|
|
template.width = GetMaxWidthInMenuTable(&gMailboxMailOptions[0], 4);
|
2019-03-08 08:10:44 +01:00
|
|
|
sUnknown_0203CF48[2] = AddWindow(&template);
|
2019-03-05 12:06:20 +01:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2019-03-06 04:32:28 +01:00
|
|
|
sUnknown_0203CF48[a0] = AddWindow(&sUnknown_086253E8[a0]);
|
2019-03-05 12:06:20 +01:00
|
|
|
}
|
2019-03-06 04:32:28 +01:00
|
|
|
SetStandardWindowBorderStyle(sUnknown_0203CF48[a0], 0);
|
2019-03-05 12:06:20 +01:00
|
|
|
}
|
2019-03-06 04:32:28 +01:00
|
|
|
return sUnknown_0203CF48[a0];
|
2019-03-05 12:06:20 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void sub_81D1D04(u8 a0)
|
|
|
|
{
|
2019-03-08 08:35:19 +01:00
|
|
|
ClearStdWindowAndFrameToTransparent(sUnknown_0203CF48[a0], 0);
|
2019-03-06 04:32:28 +01:00
|
|
|
ClearWindowTilemap(sUnknown_0203CF48[a0]);
|
|
|
|
RemoveWindow(sUnknown_0203CF48[a0]);
|
|
|
|
sUnknown_0203CF48[a0] = 0xFF;
|
2019-03-05 12:06:20 +01:00
|
|
|
}
|
|
|
|
|
Undo PokeCodec's PRs
This commit undoes most of PokeCodec's PRs after the debate in chat. Some
harmless or completely superseded PRs have been left alone, as there is not
much benefit in attempting to undo them.
Reverts #1104, #1108, #1115, #1118, #1119, #1124, #1126, #1127, #1132, #1136,
#1137, #1139, #1140, #1144, #1148, #1149, #1150, #1153, #1155, #1177, #1179,
#1180, #1181, #1182 and #1183.
2020-09-13 09:22:50 +02:00
|
|
|
static u8 sub_81D1D34(u8 a0)
|
2019-03-05 12:06:20 +01:00
|
|
|
{
|
2019-03-06 04:32:28 +01:00
|
|
|
return sUnknown_0203CF48[a0];
|
2019-03-05 12:06:20 +01:00
|
|
|
}
|
|
|
|
|
2019-03-08 08:10:44 +01:00
|
|
|
static void sub_81D1D44(u8 windowId, s32 itemId, u8 y)
|
2019-03-05 12:06:20 +01:00
|
|
|
{
|
|
|
|
u8 buffer[30];
|
|
|
|
u16 length;
|
|
|
|
|
2019-04-03 04:18:36 +02:00
|
|
|
if (itemId == LIST_CANCEL)
|
2019-03-05 12:06:20 +01:00
|
|
|
return;
|
2019-03-22 17:27:18 +01:00
|
|
|
|
2019-03-05 12:06:20 +01:00
|
|
|
StringCopy(buffer, gSaveBlock1Ptr->mail[6 + itemId].playerName);
|
|
|
|
sub_81DB52C(buffer);
|
|
|
|
length = StringLength(buffer);
|
|
|
|
if (length <= 5)
|
|
|
|
ConvertInternationalString(buffer, LANGUAGE_JAPANESE);
|
2019-12-10 19:48:20 +01:00
|
|
|
AddTextPrinterParameterized4(windowId, 1, 8, y, 0, 0, sPlayerNameTextColors, -1, buffer);
|
2019-03-05 12:06:20 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
u8 sub_81D1DC0(struct PlayerPCItemPageStruct *page)
|
|
|
|
{
|
|
|
|
u16 i;
|
|
|
|
for (i = 0; i < page->count; i++)
|
|
|
|
{
|
2019-03-06 04:32:28 +01:00
|
|
|
sUnknown_0203CF4C[i].name = sEmptyItemName;
|
|
|
|
sUnknown_0203CF4C[i].id = i;
|
2019-03-05 12:06:20 +01:00
|
|
|
}
|
|
|
|
|
2019-03-06 04:32:28 +01:00
|
|
|
sUnknown_0203CF4C[i].name = gText_Cancel2;
|
|
|
|
sUnknown_0203CF4C[i].id = LIST_CANCEL;
|
2019-03-05 12:06:20 +01:00
|
|
|
|
2019-03-06 04:32:28 +01:00
|
|
|
gMultiuseListMenuTemplate.items = sUnknown_0203CF4C;
|
2019-03-05 12:06:20 +01:00
|
|
|
gMultiuseListMenuTemplate.totalItems = page->count + 1;
|
2019-03-06 04:32:28 +01:00
|
|
|
gMultiuseListMenuTemplate.windowId = sUnknown_0203CF48[1];
|
2019-03-05 12:06:20 +01:00
|
|
|
gMultiuseListMenuTemplate.header_X = 0;
|
|
|
|
gMultiuseListMenuTemplate.item_X = 8;
|
|
|
|
gMultiuseListMenuTemplate.cursor_X = 0;
|
|
|
|
gMultiuseListMenuTemplate.maxShowed = 8;
|
|
|
|
gMultiuseListMenuTemplate.upText_Y = 9;
|
|
|
|
gMultiuseListMenuTemplate.cursorPal = 2;
|
|
|
|
gMultiuseListMenuTemplate.fillValue = 1;
|
|
|
|
gMultiuseListMenuTemplate.cursorShadowPal = 3;
|
|
|
|
gMultiuseListMenuTemplate.moveCursorFunc = sub_81D1E7C;
|
|
|
|
gMultiuseListMenuTemplate.itemPrintFunc = sub_81D1D44;
|
|
|
|
gMultiuseListMenuTemplate.fontId = 1;
|
|
|
|
gMultiuseListMenuTemplate.cursorKind = 0;
|
|
|
|
gMultiuseListMenuTemplate.lettersSpacing = 0;
|
|
|
|
gMultiuseListMenuTemplate.itemVerticalPadding = 0;
|
|
|
|
gMultiuseListMenuTemplate.scrollMultiple = LIST_NO_MULTIPLE_SCROLL;
|
|
|
|
return ListMenuInit(&gMultiuseListMenuTemplate, page->itemsAbove, page->cursorPos);
|
|
|
|
}
|
|
|
|
|
2019-03-08 08:10:44 +01:00
|
|
|
static void sub_81D1E7C(s32 itemIndex, bool8 onInit, struct ListMenu *list)
|
2019-03-05 12:06:20 +01:00
|
|
|
{
|
|
|
|
if (onInit != TRUE)
|
|
|
|
PlaySE(SE_SELECT);
|
|
|
|
}
|
|
|
|
|
|
|
|
void sub_81D1E90(struct PlayerPCItemPageStruct *page)
|
|
|
|
{
|
|
|
|
page->scrollIndicatorId = AddScrollIndicatorArrowPairParameterized(2, 0xC8, 12, 0x94, page->count - page->pageItems + 1, 0x6E, 0x6E, &page->itemsAbove);
|
|
|
|
}
|
|
|
|
|
|
|
|
void sub_81D1EC0(void)
|
|
|
|
{
|
2019-03-06 04:32:28 +01:00
|
|
|
Free(sUnknown_0203CF4C);
|
2019-03-06 02:32:14 +01:00
|
|
|
}
|
|
|
|
|
2020-10-11 00:17:34 +02:00
|
|
|
void InitConditionGraphData(struct ConditionGraph *graph)
|
2019-03-06 02:32:14 +01:00
|
|
|
{
|
2019-03-22 17:27:18 +01:00
|
|
|
u8 i, j;
|
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
for (j = 0; j < FLAVOR_COUNT; j++)
|
2019-03-06 02:32:14 +01:00
|
|
|
{
|
|
|
|
for (i = 0; i < 10; i++)
|
|
|
|
{
|
2020-10-11 00:17:34 +02:00
|
|
|
graph->unk64[i][j].unk0 = 0;
|
|
|
|
graph->unk64[i][j].unk2 = 0;
|
2019-03-06 02:32:14 +01:00
|
|
|
}
|
|
|
|
for (i = 0; i < 4; i++)
|
|
|
|
{
|
2020-10-11 00:17:34 +02:00
|
|
|
graph->stat[i][j] = 0;
|
|
|
|
graph->unk14[i][j].unk0 = 155;
|
|
|
|
graph->unk14[i][j].unk2 = 91;
|
2019-03-06 02:32:14 +01:00
|
|
|
}
|
|
|
|
|
2020-10-11 00:17:34 +02:00
|
|
|
graph->unk12C[j].unk0 = 0;
|
|
|
|
graph->unk12C[j].unk2 = 0;
|
2019-03-06 02:32:14 +01:00
|
|
|
}
|
|
|
|
|
2020-10-11 00:17:34 +02:00
|
|
|
graph->unk354 = 0;
|
|
|
|
graph->unk352 = 0;
|
2019-03-06 04:32:28 +01:00
|
|
|
}
|
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
void sub_81D1F84(struct ConditionGraph *graph, struct UnknownSubStruct_81D1ED4 *arg1, struct UnknownSubStruct_81D1ED4 *arg2)
|
2019-03-06 04:32:28 +01:00
|
|
|
{
|
2019-03-22 17:27:18 +01:00
|
|
|
u16 i, j;
|
|
|
|
s32 r5, r6;
|
|
|
|
|
2020-10-11 00:17:34 +02:00
|
|
|
for (i = 0; i < FLAVOR_COUNT; i++)
|
2019-03-22 17:27:18 +01:00
|
|
|
{
|
|
|
|
r5 = arg1[i].unk0 << 8;
|
|
|
|
r6 = ((arg2[i].unk0 - arg1[i].unk0) << 8) / 10;
|
|
|
|
for (j = 0; j < 9; j++)
|
|
|
|
{
|
2020-08-12 17:44:39 +02:00
|
|
|
graph->unk64[j][i].unk0 = (r5 >> 8) + ((r5 >> 7) & 1);
|
2019-03-22 17:27:18 +01:00
|
|
|
r5 += r6;
|
|
|
|
}
|
2020-08-12 17:44:39 +02:00
|
|
|
graph->unk64[j][i].unk0 = arg2[i].unk0;
|
2019-03-22 17:27:18 +01:00
|
|
|
|
|
|
|
r5 = arg1[i].unk2 << 8;
|
|
|
|
r6 = ((arg2[i].unk2 - arg1[i].unk2) << 8) / 10;
|
|
|
|
for (j = 0; j < 9; j++)
|
|
|
|
{
|
2020-08-12 17:44:39 +02:00
|
|
|
graph->unk64[j][i].unk2 = (r5 >> 8) + ((r5 >> 7) & 1);
|
2019-03-22 17:27:18 +01:00
|
|
|
r5 += r6;
|
|
|
|
}
|
2020-08-12 17:44:39 +02:00
|
|
|
graph->unk64[j][i].unk2 = arg2[i].unk2;
|
2019-03-22 17:27:18 +01:00
|
|
|
}
|
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
graph->unk352 = 0;
|
2019-03-06 04:32:28 +01:00
|
|
|
}
|
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
bool32 TransitionConditionGraph(struct ConditionGraph *graph)
|
2019-03-06 04:32:28 +01:00
|
|
|
{
|
2020-08-12 17:44:39 +02:00
|
|
|
if (graph->unk352 < 10)
|
2019-03-06 04:32:28 +01:00
|
|
|
{
|
2020-08-12 17:44:39 +02:00
|
|
|
sub_81D2230(graph);
|
|
|
|
return (++graph->unk352 != 10);
|
2019-03-06 04:32:28 +01:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-10-11 00:17:34 +02:00
|
|
|
void InitConditionGraphState(struct ConditionGraph *graph)
|
2019-03-06 04:32:28 +01:00
|
|
|
{
|
2020-10-11 00:17:34 +02:00
|
|
|
graph->state = 0;
|
2019-03-06 04:32:28 +01:00
|
|
|
}
|
|
|
|
|
2020-10-11 00:17:34 +02:00
|
|
|
bool8 SetupConditionGraphScanlineParams(struct ConditionGraph *graph)
|
2019-03-06 04:32:28 +01:00
|
|
|
{
|
|
|
|
struct ScanlineEffectParams params;
|
2019-03-22 17:27:18 +01:00
|
|
|
|
2020-10-11 00:17:34 +02:00
|
|
|
switch (graph->state)
|
2019-03-06 04:32:28 +01:00
|
|
|
{
|
|
|
|
case 0:
|
|
|
|
ScanlineEffect_Clear();
|
2020-10-11 00:17:34 +02:00
|
|
|
graph->state++;
|
2019-03-06 04:32:28 +01:00
|
|
|
return TRUE;
|
|
|
|
case 1:
|
2020-08-12 17:44:39 +02:00
|
|
|
params = sConditionGraphScanline;
|
2019-03-06 04:32:28 +01:00
|
|
|
ScanlineEffect_SetParams(params);
|
2020-10-11 00:17:34 +02:00
|
|
|
graph->state++;
|
2019-03-06 04:32:28 +01:00
|
|
|
return FALSE;
|
|
|
|
default:
|
|
|
|
return FALSE;
|
|
|
|
}
|
2019-03-07 04:27:30 +01:00
|
|
|
}
|
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
void sub_81D2108(struct ConditionGraph *graph)
|
2019-03-07 04:27:30 +01:00
|
|
|
{
|
|
|
|
u16 i;
|
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
if (graph->unk354 == 0)
|
2019-03-07 04:27:30 +01:00
|
|
|
return;
|
2019-03-22 17:27:18 +01:00
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
sub_81D24A4(graph);
|
|
|
|
sub_81D2634(graph);
|
2019-03-07 04:27:30 +01:00
|
|
|
|
2019-03-22 17:27:18 +01:00
|
|
|
for (i = 0; i < 66; i++)
|
2019-03-07 04:27:30 +01:00
|
|
|
{
|
2020-08-12 17:44:39 +02:00
|
|
|
gScanlineEffectRegBuffers[1][(i + 55) * 2] = gScanlineEffectRegBuffers[0][(i + 55) * 2] = (graph->unk140[i][0] << 8) | (graph->unk140[i][1]);
|
|
|
|
gScanlineEffectRegBuffers[1][(i + 55) * 2 + 1] = gScanlineEffectRegBuffers[0][(i + 55) * 2 + 1] = (graph->unk248[i][0] << 8) | (graph->unk248[i][1]);
|
2019-03-07 04:27:30 +01:00
|
|
|
}
|
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
graph->unk354 = 0;
|
2019-03-07 04:27:30 +01:00
|
|
|
}
|
|
|
|
|
2020-10-11 00:17:34 +02:00
|
|
|
void SetConditionGraphIOWindows(u8 bg)
|
2019-03-07 04:27:30 +01:00
|
|
|
{
|
2019-03-22 17:27:18 +01:00
|
|
|
u32 flags;
|
2019-03-07 04:27:30 +01:00
|
|
|
|
|
|
|
if (bg > 3)
|
|
|
|
bg = 0;
|
2019-03-22 17:27:18 +01:00
|
|
|
|
2019-03-07 04:27:30 +01:00
|
|
|
// Unset the WINOUT flag for the bg.
|
|
|
|
flags = (WINOUT_WIN01_BG_ALL | WINOUT_WIN01_OBJ) & ~(1 << bg);
|
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
SetGpuReg(REG_OFFSET_WIN0H, WIN_RANGE( 0, DISPLAY_WIDTH));
|
|
|
|
SetGpuReg(REG_OFFSET_WIN1H, WIN_RANGE( 0, 155));
|
|
|
|
SetGpuReg(REG_OFFSET_WIN0V, WIN_RANGE(56, 121));
|
|
|
|
SetGpuReg(REG_OFFSET_WIN1V, WIN_RANGE(56, 121));
|
2019-03-07 04:27:30 +01:00
|
|
|
SetGpuReg(REG_OFFSET_WININ, WININ_WIN0_BG_ALL | WININ_WIN0_OBJ | WININ_WIN0_CLR | WININ_WIN1_BG_ALL | WININ_WIN1_OBJ | WININ_WIN1_CLR);
|
|
|
|
SetGpuReg(REG_OFFSET_WINOUT, flags);
|
|
|
|
}
|
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
void sub_81D2230(struct ConditionGraph *graph)
|
2019-03-07 04:27:30 +01:00
|
|
|
{
|
|
|
|
u16 i;
|
2020-08-12 17:44:39 +02:00
|
|
|
for (i = 0; i < FLAVOR_COUNT; i++)
|
|
|
|
graph->unk12C[i] = graph->unk64[graph->unk352][i];
|
2019-03-22 17:27:18 +01:00
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
graph->unk354 = 1;
|
2019-03-07 04:27:30 +01:00
|
|
|
}
|
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
static void sub_81D2278(struct ConditionGraph *graph, u16 *arg1, struct UnknownSubStruct_81D1ED4 *arg2, struct UnknownSubStruct_81D1ED4 *arg3, u8 arg4, u16 *arg5)
|
2019-03-23 15:46:47 +01:00
|
|
|
{
|
2019-07-29 16:22:50 +02:00
|
|
|
u16 i, r8, r10, r0, var_30;
|
|
|
|
u16 *ptr;
|
|
|
|
s32 r4, var_2C;
|
2019-03-23 15:46:47 +01:00
|
|
|
|
2019-07-29 16:22:50 +02:00
|
|
|
var_2C = 0;
|
2019-03-23 15:46:47 +01:00
|
|
|
if (arg2->unk2 < arg3->unk2)
|
|
|
|
{
|
|
|
|
r10 = arg2->unk2;
|
|
|
|
r0 = arg3->unk2;
|
2019-07-29 16:22:50 +02:00
|
|
|
r4 = arg2->unk0 << 10;
|
2019-03-23 15:46:47 +01:00
|
|
|
var_30 = arg3->unk0;
|
2019-07-29 16:22:50 +02:00
|
|
|
r8 = r0 - r10;
|
|
|
|
if (r8 != 0)
|
|
|
|
var_2C = ((var_30 - arg2->unk0) << 10) / r8;
|
2019-03-23 15:46:47 +01:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2019-07-29 16:22:50 +02:00
|
|
|
r0 = arg2->unk2;
|
2019-03-23 15:46:47 +01:00
|
|
|
r10 = arg3->unk2;
|
2019-07-29 16:22:50 +02:00
|
|
|
r4 = arg3->unk0 << 10;
|
2019-03-23 15:46:47 +01:00
|
|
|
var_30 = arg2->unk0;
|
2019-07-29 16:22:50 +02:00
|
|
|
r8 = r0 - r10;
|
|
|
|
if (r8 != 0)
|
|
|
|
var_2C = ((var_30 - arg3->unk0) << 10) / r8;
|
2019-03-23 15:46:47 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
r8++;
|
|
|
|
if (arg5 == NULL)
|
|
|
|
{
|
2019-07-29 16:22:50 +02:00
|
|
|
arg1 += (r10 - 56) * 2;
|
|
|
|
for (i = 0; i < r8; i++)
|
|
|
|
{
|
|
|
|
arg1[arg4] = (r4 >> 10) + ((r4 >> 9) & 1) + arg4;
|
|
|
|
r4 += var_2C;
|
|
|
|
arg1 += 2;
|
|
|
|
}
|
2019-03-23 15:46:47 +01:00
|
|
|
|
2019-07-29 16:22:50 +02:00
|
|
|
ptr = arg1 - 2;
|
2019-03-23 15:46:47 +01:00
|
|
|
}
|
2019-07-29 16:22:50 +02:00
|
|
|
else if (var_2C > 0)
|
|
|
|
{
|
|
|
|
arg5 += (r10 - 56) * 2;
|
|
|
|
// Less readable than the other loops, but it has to be written this way to match.
|
|
|
|
for (i = 0; i < r8; arg5[arg4] = (r4 >> 10) + ((r4 >> 9) & 1) + arg4, r4 += var_2C, arg5 += 2, i++)
|
|
|
|
{
|
|
|
|
if (r4 >= (155 << 10))
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
graph->unk350 = r10 + i;
|
|
|
|
arg1 += (graph->unk350 - 56) * 2;
|
2019-07-29 16:22:50 +02:00
|
|
|
for (; i < r8; i++)
|
|
|
|
{
|
|
|
|
arg1[arg4] = (r4 >> 10) + ((r4 >> 9) & 1) + arg4;
|
|
|
|
r4 += var_2C;
|
|
|
|
arg1 += 2;
|
|
|
|
}
|
|
|
|
|
|
|
|
ptr = arg1 - 2;
|
|
|
|
}
|
|
|
|
else if (var_2C < 0)
|
|
|
|
{
|
|
|
|
arg1 += (r10 - 56) * 2;
|
|
|
|
for (i = 0; i < r8; i++)
|
|
|
|
{
|
|
|
|
arg1[arg4] = (r4 >> 10) + ((r4 >> 9) & 1) + arg4;
|
|
|
|
if (r4 < (155 << 10))
|
|
|
|
{
|
|
|
|
arg1[arg4] = 155;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
r4 += var_2C;
|
|
|
|
arg1 += 2;
|
|
|
|
}
|
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
graph->unk350 = r10 + i;
|
|
|
|
arg5 += (graph->unk350 - 56) * 2;
|
2019-07-29 16:22:50 +02:00
|
|
|
for (; i < r8; i++)
|
|
|
|
{
|
|
|
|
arg5[arg4] = (r4 >> 10) + ((r4 >> 9) & 1) + arg4;
|
|
|
|
r4 += var_2C;
|
|
|
|
arg5 += 2;
|
|
|
|
}
|
|
|
|
|
|
|
|
ptr = arg5 - 2;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2020-08-12 17:44:39 +02:00
|
|
|
graph->unk350 = r10;
|
2019-07-29 16:22:50 +02:00
|
|
|
arg1 += (r10 - 56) * 2;
|
|
|
|
arg5 += (r10 - 56) * 2;
|
|
|
|
arg1[1] = arg2->unk0 + 1;
|
|
|
|
arg5[0] = arg3->unk0;
|
|
|
|
arg5[1] = 155;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
ptr[arg4] = arg4 + var_30;
|
2019-03-07 04:27:30 +01:00
|
|
|
}
|
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
static void sub_81D24A4(struct ConditionGraph *graph)
|
2019-03-07 04:27:30 +01:00
|
|
|
{
|
2019-03-22 17:27:18 +01:00
|
|
|
u16 i, r6, varMax;
|
2019-03-07 04:27:30 +01:00
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
if (graph->unk12C[0].unk2 < graph->unk12C[1].unk2)
|
2019-03-22 17:27:18 +01:00
|
|
|
{
|
2020-08-12 17:44:39 +02:00
|
|
|
r6 = graph->unk12C[0].unk2;
|
|
|
|
sub_81D2278(graph, graph->unk140[0], &graph->unk12C[0], &graph->unk12C[1], 1, NULL);
|
2019-03-22 17:27:18 +01:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2020-08-12 17:44:39 +02:00
|
|
|
r6 = graph->unk12C[1].unk2;
|
|
|
|
sub_81D2278(graph, graph->unk140[0], &graph->unk12C[1], &graph->unk12C[0], 0, NULL);
|
2019-03-22 17:27:18 +01:00
|
|
|
}
|
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
sub_81D2278(graph, graph->unk140[0], &graph->unk12C[1], &graph->unk12C[2], 1, NULL);
|
2019-03-22 17:27:18 +01:00
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
i = (graph->unk12C[2].unk2 <= graph->unk12C[3].unk2);
|
|
|
|
sub_81D2278(graph, graph->unk140[0], &graph->unk12C[2], &graph->unk12C[3], i, graph->unk248[0]);
|
2019-03-22 17:27:18 +01:00
|
|
|
for (i = 56; i < r6; i++)
|
|
|
|
{
|
2020-08-12 17:44:39 +02:00
|
|
|
graph->unk140[i - 56][0] = 0;
|
|
|
|
graph->unk140[i - 56][1] = 0;
|
2019-03-22 17:27:18 +01:00
|
|
|
}
|
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
for (i = graph->unk12C[0].unk2; i <= graph->unk350; i++)
|
|
|
|
graph->unk140[i - 56][0] = 155;
|
2019-03-22 17:27:18 +01:00
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
varMax = max(graph->unk350, graph->unk12C[2].unk2);
|
2019-03-22 17:27:18 +01:00
|
|
|
for (i = varMax + 1; i < 122; i++)
|
|
|
|
{
|
2020-08-12 17:44:39 +02:00
|
|
|
graph->unk140[i - 56][0] = 0;
|
|
|
|
graph->unk140[i - 56][1] = 0;
|
2019-03-22 17:27:18 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
for (i = 56; i < 122; i++)
|
|
|
|
{
|
2020-08-12 17:44:39 +02:00
|
|
|
if (graph->unk140[i - 56][0] == 0 && graph->unk140[i - 56][1] != 0)
|
|
|
|
graph->unk140[i - 56][0] = 155;
|
2019-03-22 17:27:18 +01:00
|
|
|
}
|
2019-03-07 04:27:30 +01:00
|
|
|
}
|
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
static void sub_81D2634(struct ConditionGraph *graph)
|
2019-03-07 04:27:30 +01:00
|
|
|
{
|
2019-03-22 17:27:18 +01:00
|
|
|
s32 i, r6, varMax;
|
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
if (graph->unk12C[0].unk2 < graph->unk12C[4].unk2)
|
2019-03-07 04:27:30 +01:00
|
|
|
{
|
2020-08-12 17:44:39 +02:00
|
|
|
r6 = graph->unk12C[0].unk2;
|
|
|
|
sub_81D2278(graph, graph->unk248[0], &graph->unk12C[0], &graph->unk12C[4], 0, NULL);
|
2019-03-22 17:27:18 +01:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2020-08-12 17:44:39 +02:00
|
|
|
r6 = graph->unk12C[4].unk2;
|
|
|
|
sub_81D2278(graph, graph->unk248[0], &graph->unk12C[4], &graph->unk12C[0], 1, NULL);
|
2019-03-22 17:27:18 +01:00
|
|
|
}
|
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
sub_81D2278(graph, graph->unk248[0], &graph->unk12C[4], &graph->unk12C[3], 0, NULL);
|
2019-03-22 17:27:18 +01:00
|
|
|
|
|
|
|
for (i = 56; i < r6; i++)
|
|
|
|
{
|
2020-08-12 17:44:39 +02:00
|
|
|
graph->unk140[i + 10][0] = 0;
|
|
|
|
graph->unk140[i + 10][1] = 0;
|
2019-03-22 17:27:18 +01:00
|
|
|
}
|
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
for (i = graph->unk12C[0].unk2; i <= graph->unk350; i++)
|
|
|
|
graph->unk140[i + 10][1] = 155;
|
2019-03-07 04:27:30 +01:00
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
varMax = max(graph->unk350, graph->unk12C[3].unk2 + 1);
|
2019-03-22 17:27:18 +01:00
|
|
|
for (i = varMax; i < 122; i++)
|
|
|
|
{
|
2020-08-12 17:44:39 +02:00
|
|
|
graph->unk140[i + 10][0] = 0;
|
|
|
|
graph->unk140[i + 10][1] = 0;
|
2019-03-22 17:27:18 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
for (i = 0; i < 66; i++)
|
|
|
|
{
|
2020-08-12 17:44:39 +02:00
|
|
|
if (graph->unk248[i][0] >= graph->unk248[i][1])
|
2019-03-07 04:27:30 +01:00
|
|
|
{
|
2020-08-12 17:44:39 +02:00
|
|
|
graph->unk248[i][1] = 0;
|
|
|
|
graph->unk248[i][0] = 0;
|
2019-03-07 04:27:30 +01:00
|
|
|
}
|
|
|
|
}
|
2019-03-22 17:27:18 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void sub_81D2754(u8 *arg0, struct UnknownSubStruct_81D1ED4 *arg1)
|
|
|
|
{
|
|
|
|
u8 r2, r7;
|
|
|
|
s8 r12;
|
|
|
|
u16 i;
|
|
|
|
|
|
|
|
r2 = sUnknown_08625410[*(arg0++)];
|
|
|
|
arg1->unk0 = 155;
|
|
|
|
arg1->unk2 = 91 - r2;
|
|
|
|
|
|
|
|
r7 = 64;
|
|
|
|
r12 = 0;
|
|
|
|
for (i = 1; i < 5; i++)
|
|
|
|
{
|
|
|
|
r7 += 51;
|
|
|
|
if (--r12 < 0)
|
|
|
|
r12 = 4;
|
|
|
|
|
|
|
|
if (r12 == 2)
|
|
|
|
r7++;
|
|
|
|
|
|
|
|
r2 = sUnknown_08625410[*(arg0++)];
|
|
|
|
arg1[r12].unk0 = 155 + ((r2 * gSineTable[64 + r7]) >> 8);
|
|
|
|
arg1[r12].unk2 = 91 - ((r2 * gSineTable[r7]) >> 8);
|
|
|
|
|
|
|
|
if (r12 < 3 && (r2 != 32 || r12 != 2))
|
|
|
|
arg1[r12].unk0 = 156 + ((r2 * gSineTable[64 + r7]) >> 8);
|
|
|
|
}
|
2019-03-08 07:56:38 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void InitMoveRelearnerWindows(bool8 useContextWindow)
|
|
|
|
{
|
|
|
|
u8 i;
|
|
|
|
|
2019-03-08 08:10:44 +01:00
|
|
|
InitWindows(sMoveRelearnerWindowTemplates);
|
2019-03-08 07:56:38 +01:00
|
|
|
DeactivateAllTextPrinters();
|
|
|
|
LoadUserWindowBorderGfx(0, 1, 0xE0);
|
|
|
|
LoadPalette(gUnknown_0860F074, 0xF0, 0x20);
|
2019-03-22 17:27:18 +01:00
|
|
|
|
2019-03-08 07:56:38 +01:00
|
|
|
for (i = 0; i < 5; i++)
|
|
|
|
{
|
2019-03-08 10:02:05 +01:00
|
|
|
FillWindowPixelBuffer(i, PIXEL_FILL(1));
|
2019-03-08 07:56:38 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if (!useContextWindow)
|
|
|
|
{
|
|
|
|
PutWindowTilemap(0);
|
2019-03-08 08:35:19 +01:00
|
|
|
DrawStdFrameWithCustomTileAndPalette(0, 0, 0x1, 0xE);
|
2019-03-08 07:56:38 +01:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
PutWindowTilemap(1);
|
2019-03-08 08:35:19 +01:00
|
|
|
DrawStdFrameWithCustomTileAndPalette(1, 0, 1, 0xE);
|
2019-03-08 07:56:38 +01:00
|
|
|
}
|
|
|
|
PutWindowTilemap(2);
|
|
|
|
PutWindowTilemap(3);
|
2019-03-08 08:35:19 +01:00
|
|
|
DrawStdFrameWithCustomTileAndPalette(2, 0, 1, 0xE);
|
|
|
|
DrawStdFrameWithCustomTileAndPalette(3, 0, 1, 0xE);
|
2019-03-08 07:56:38 +01:00
|
|
|
nullsub_79();
|
2020-05-14 10:37:09 +02:00
|
|
|
ScheduleBgCopyTilemapToVram(1);
|
2019-03-08 07:56:38 +01:00
|
|
|
}
|
|
|
|
|
2019-03-08 08:10:44 +01:00
|
|
|
static void nullsub_79(void)
|
2019-03-08 07:56:38 +01:00
|
|
|
{
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
u8 LoadMoveRelearnerMovesList(const struct ListMenuItem *items, u16 numChoices)
|
|
|
|
{
|
2019-03-08 08:10:44 +01:00
|
|
|
gMultiuseListMenuTemplate = sMoveRelearnerMovesListTemplate;
|
2019-03-08 07:56:38 +01:00
|
|
|
gMultiuseListMenuTemplate.totalItems = numChoices;
|
|
|
|
gMultiuseListMenuTemplate.items = items;
|
|
|
|
|
|
|
|
if (numChoices < 6)
|
|
|
|
{
|
|
|
|
gMultiuseListMenuTemplate.maxShowed = numChoices;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
gMultiuseListMenuTemplate.maxShowed = 6;
|
|
|
|
}
|
|
|
|
return gMultiuseListMenuTemplate.maxShowed;
|
|
|
|
}
|
|
|
|
|
2019-03-08 08:10:44 +01:00
|
|
|
static void MoveRelearnerLoadBattleMoveDescription(u32 chosenMove)
|
2019-03-08 07:56:38 +01:00
|
|
|
{
|
2019-03-22 17:27:18 +01:00
|
|
|
s32 x;
|
2019-03-08 07:56:38 +01:00
|
|
|
const struct BattleMove *move;
|
|
|
|
u8 buffer[0x20];
|
2019-03-22 17:27:18 +01:00
|
|
|
const u8 *str;
|
2019-03-08 07:56:38 +01:00
|
|
|
|
2019-03-08 10:02:05 +01:00
|
|
|
FillWindowPixelBuffer(0, PIXEL_FILL(1));
|
2019-03-22 17:27:18 +01:00
|
|
|
str = gText_MoveRelearnerBattleMoves;
|
|
|
|
x = GetStringCenterAlignXOffset(1, str, 0x80);
|
|
|
|
AddTextPrinterParameterized(0, 1, str, x, 1, TEXT_SPEED_FF, NULL);
|
2019-03-08 07:56:38 +01:00
|
|
|
|
2019-03-22 17:27:18 +01:00
|
|
|
str = gText_MoveRelearnerPP;
|
|
|
|
AddTextPrinterParameterized(0, 1, str, 4, 0x29, TEXT_SPEED_FF, NULL);
|
2019-03-08 07:56:38 +01:00
|
|
|
|
2019-03-22 17:27:18 +01:00
|
|
|
str = gText_MoveRelearnerPower;
|
|
|
|
x = GetStringRightAlignXOffset(1, str, 0x6A);
|
|
|
|
AddTextPrinterParameterized(0, 1, str, x, 0x19, TEXT_SPEED_FF, NULL);
|
2019-03-08 07:56:38 +01:00
|
|
|
|
2019-03-22 17:27:18 +01:00
|
|
|
str = gText_MoveRelearnerAccuracy;
|
|
|
|
x = GetStringRightAlignXOffset(1, str, 0x6A);
|
|
|
|
AddTextPrinterParameterized(0, 1, str, x, 0x29, TEXT_SPEED_FF, NULL);
|
2019-03-08 07:56:38 +01:00
|
|
|
if (chosenMove == LIST_CANCEL)
|
|
|
|
{
|
|
|
|
CopyWindowToVram(0, 2);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
move = &gBattleMoves[chosenMove];
|
2019-03-22 17:27:18 +01:00
|
|
|
str = gTypeNames[move->type];
|
|
|
|
AddTextPrinterParameterized(0, 1, str, 4, 0x19, TEXT_SPEED_FF, NULL);
|
2019-03-08 07:56:38 +01:00
|
|
|
|
2019-03-22 17:27:18 +01:00
|
|
|
x = 4 + GetStringWidth(1, gText_MoveRelearnerPP, 0);
|
2019-09-30 21:43:44 +02:00
|
|
|
ConvertIntToDecimalStringN(buffer, move->pp, STR_CONV_MODE_LEFT_ALIGN, 2);
|
2019-03-22 17:27:18 +01:00
|
|
|
AddTextPrinterParameterized(0, 1, buffer, x, 0x29, TEXT_SPEED_FF, NULL);
|
2019-03-08 07:56:38 +01:00
|
|
|
|
|
|
|
if (move->power < 2)
|
|
|
|
{
|
2019-03-22 17:27:18 +01:00
|
|
|
str = gText_ThreeDashes;
|
2019-03-08 07:56:38 +01:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2019-09-30 21:43:44 +02:00
|
|
|
ConvertIntToDecimalStringN(buffer, move->power, STR_CONV_MODE_LEFT_ALIGN, 3);
|
2019-03-22 17:27:18 +01:00
|
|
|
str = buffer;
|
2019-03-08 07:56:38 +01:00
|
|
|
}
|
2019-03-22 17:27:18 +01:00
|
|
|
AddTextPrinterParameterized(0, 1, str, 0x6A, 0x19, TEXT_SPEED_FF, NULL);
|
2019-03-08 07:56:38 +01:00
|
|
|
|
|
|
|
if (move->accuracy == 0)
|
|
|
|
{
|
2019-03-22 17:27:18 +01:00
|
|
|
str = gText_ThreeDashes;
|
2019-03-08 07:56:38 +01:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2019-09-30 21:43:44 +02:00
|
|
|
ConvertIntToDecimalStringN(buffer, move->accuracy, STR_CONV_MODE_LEFT_ALIGN, 3);
|
2019-03-22 17:27:18 +01:00
|
|
|
str = buffer;
|
2019-03-08 07:56:38 +01:00
|
|
|
}
|
2019-03-22 17:27:18 +01:00
|
|
|
AddTextPrinterParameterized(0, 1, str, 0x6A, 0x29, TEXT_SPEED_FF, NULL);
|
|
|
|
|
|
|
|
str = gMoveDescriptionPointers[chosenMove - 1];
|
|
|
|
AddTextPrinterParameterized(0, 7, str, 0, 0x41, 0, NULL);
|
2019-03-08 07:56:38 +01:00
|
|
|
}
|
|
|
|
|
2019-03-08 08:10:44 +01:00
|
|
|
static void MoveRelearnerMenuLoadContestMoveDescription(u32 chosenMove)
|
2019-03-08 07:56:38 +01:00
|
|
|
{
|
2019-03-22 17:27:18 +01:00
|
|
|
s32 x;
|
|
|
|
const u8 *str;
|
2019-03-08 07:56:38 +01:00
|
|
|
const struct ContestMove *move;
|
|
|
|
|
|
|
|
MoveRelearnerShowHideHearts(chosenMove);
|
2019-03-08 10:02:05 +01:00
|
|
|
FillWindowPixelBuffer(1, PIXEL_FILL(1));
|
2019-03-22 17:27:18 +01:00
|
|
|
str = gText_MoveRelearnerContestMovesTitle;
|
|
|
|
x = GetStringCenterAlignXOffset(1, str, 0x80);
|
|
|
|
AddTextPrinterParameterized(1, 1, str, x, 1, TEXT_SPEED_FF, NULL);
|
|
|
|
|
|
|
|
str = gText_MoveRelearnerAppeal;
|
|
|
|
x = GetStringRightAlignXOffset(1, str, 0x5C);
|
|
|
|
AddTextPrinterParameterized(1, 1, str, x, 0x19, TEXT_SPEED_FF, NULL);
|
|
|
|
|
|
|
|
str = gText_MoveRelearnerJam;
|
|
|
|
x = GetStringRightAlignXOffset(1, str, 0x5C);
|
|
|
|
AddTextPrinterParameterized(1, 1, str, x, 0x29, TEXT_SPEED_FF, NULL);
|
2019-03-08 07:56:38 +01:00
|
|
|
|
|
|
|
if (chosenMove == MENU_NOTHING_CHOSEN)
|
|
|
|
{
|
|
|
|
CopyWindowToVram(1, 2);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
move = &gContestMoves[chosenMove];
|
2019-03-22 17:27:18 +01:00
|
|
|
str = gContestMoveTypeTextPointers[move->contestCategory];
|
|
|
|
AddTextPrinterParameterized(1, 1, str, 4, 0x19, TEXT_SPEED_FF, NULL);
|
2019-03-08 07:56:38 +01:00
|
|
|
|
2019-03-22 17:27:18 +01:00
|
|
|
str = gContestEffectDescriptionPointers[move->effect];
|
|
|
|
AddTextPrinterParameterized(1, 7, str, 0, 0x41, TEXT_SPEED_FF, NULL);
|
2019-03-08 07:56:38 +01:00
|
|
|
|
|
|
|
CopyWindowToVram(1, 2);
|
|
|
|
}
|
|
|
|
|
2019-03-08 08:10:44 +01:00
|
|
|
static void MoveRelearnerCursorCallback(s32 itemIndex, bool8 onInit, struct ListMenu *list)
|
2019-03-08 07:56:38 +01:00
|
|
|
{
|
|
|
|
if (onInit != TRUE)
|
|
|
|
PlaySE(SE_SELECT);
|
|
|
|
MoveRelearnerLoadBattleMoveDescription(itemIndex);
|
|
|
|
MoveRelearnerMenuLoadContestMoveDescription(itemIndex);
|
|
|
|
}
|
|
|
|
|
2019-03-08 08:10:44 +01:00
|
|
|
void MoveRelearnerPrintText(u8 *str)
|
2019-03-08 07:56:38 +01:00
|
|
|
{
|
|
|
|
u8 speed;
|
|
|
|
|
2019-03-08 10:02:05 +01:00
|
|
|
FillWindowPixelBuffer(3, PIXEL_FILL(1));
|
2019-03-08 07:56:38 +01:00
|
|
|
gTextFlags.canABSpeedUpPrint = TRUE;
|
|
|
|
speed = GetPlayerTextSpeedDelay();
|
2019-03-08 08:10:44 +01:00
|
|
|
AddTextPrinterParameterized2(3, 1, str, speed, NULL, TEXT_COLOR_DARK_GREY, TEXT_COLOR_WHITE, 3);
|
2019-03-08 07:56:38 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
bool16 MoveRelearnerRunTextPrinters(void)
|
|
|
|
{
|
|
|
|
RunTextPrinters();
|
|
|
|
return IsTextPrinterActive(3);
|
|
|
|
}
|
|
|
|
|
|
|
|
void MoveRelearnerCreateYesNoMenu(void)
|
|
|
|
{
|
2019-03-08 08:10:44 +01:00
|
|
|
CreateYesNoMenu(&sMoveRelearnerYesNoMenuTemplate, 1, 0xE, 0);
|
2019-03-22 17:27:18 +01:00
|
|
|
}
|
2019-03-31 12:59:01 +02:00
|
|
|
|
|
|
|
s32 GetBoxOrPartyMonData(u16 boxId, u16 monId, s32 request, u8 *dst)
|
|
|
|
{
|
|
|
|
s32 ret;
|
|
|
|
|
|
|
|
if (boxId == TOTAL_BOXES_COUNT) // Party mon.
|
|
|
|
{
|
|
|
|
if (request == MON_DATA_NICKNAME || request == MON_DATA_OT_NAME)
|
|
|
|
ret = GetMonData(&gPlayerParty[monId], request, dst);
|
|
|
|
else
|
|
|
|
ret = GetMonData(&gPlayerParty[monId], request);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
if (request == MON_DATA_NICKNAME || request == MON_DATA_OT_NAME)
|
|
|
|
ret = GetAndCopyBoxMonDataAt(boxId, monId, request, dst);
|
|
|
|
else
|
|
|
|
ret = GetBoxMonDataAt(boxId, monId, request);
|
|
|
|
}
|
|
|
|
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
2020-08-10 23:05:42 +02:00
|
|
|
// Gets the name/gender/level string for the condition menu
|
|
|
|
static u8 *GetConditionMenuMonString(u8 *dst, u16 boxId, u16 monId)
|
2019-03-31 12:59:01 +02:00
|
|
|
{
|
2020-09-19 23:38:54 +02:00
|
|
|
u16 box, mon, species, level, gender;
|
2019-03-31 12:59:01 +02:00
|
|
|
struct BoxPokemon *boxMon;
|
|
|
|
u8 *str;
|
|
|
|
|
2020-09-19 23:38:54 +02:00
|
|
|
box = boxId;
|
|
|
|
mon = monId;
|
2019-03-31 12:59:01 +02:00
|
|
|
*(dst++) = EXT_CTRL_CODE_BEGIN;
|
2020-08-10 23:05:42 +02:00
|
|
|
*(dst++) = EXT_CTRL_CODE_COLOR_HIGHLIGHT_SHADOW;
|
|
|
|
*(dst++) = TEXT_COLOR_BLUE;
|
|
|
|
*(dst++) = TEXT_COLOR_TRANSPARENT;
|
|
|
|
*(dst++) = TEXT_COLOR_LIGHT_BLUE;
|
2020-09-19 23:38:54 +02:00
|
|
|
if (GetBoxOrPartyMonData(box, mon, MON_DATA_IS_EGG, NULL))
|
2019-03-31 12:59:01 +02:00
|
|
|
return StringCopyPadded(dst, gText_EggNickname, 0, 12);
|
2020-09-19 23:38:54 +02:00
|
|
|
GetBoxOrPartyMonData(box, mon, MON_DATA_NICKNAME, dst);
|
2020-08-28 20:35:37 +02:00
|
|
|
StringGetEnd10(dst);
|
2020-09-19 23:38:54 +02:00
|
|
|
species = GetBoxOrPartyMonData(box, mon, MON_DATA_SPECIES, NULL);
|
|
|
|
if (box == TOTAL_BOXES_COUNT) // Party mon.
|
2020-08-28 20:35:37 +02:00
|
|
|
{
|
2020-09-19 23:38:54 +02:00
|
|
|
level = GetMonData(&gPlayerParty[mon], MON_DATA_LEVEL);
|
|
|
|
gender = GetMonGender(&gPlayerParty[mon]);
|
2020-08-28 20:35:37 +02:00
|
|
|
}
|
2019-03-31 12:59:01 +02:00
|
|
|
else
|
|
|
|
{
|
2020-12-11 05:30:52 +01:00
|
|
|
boxMon = GetBoxedMonPtr(box, mon);
|
2020-08-28 20:35:37 +02:00
|
|
|
gender = GetBoxMonGender(boxMon);
|
|
|
|
level = GetLevelFromBoxMonExp(boxMon);
|
|
|
|
}
|
2019-03-31 12:59:01 +02:00
|
|
|
|
2020-12-15 03:44:25 +01:00
|
|
|
if ((species == SPECIES_NIDORAN_F || species == SPECIES_NIDORAN_M) && !StringCompare(dst, gSpeciesNames[species]))
|
|
|
|
gender = MON_GENDERLESS;
|
2019-03-31 12:59:01 +02:00
|
|
|
|
2020-12-15 03:44:25 +01:00
|
|
|
for (str = dst; *str != EOS; str++)
|
|
|
|
;
|
2019-03-31 12:59:01 +02:00
|
|
|
|
2020-12-15 03:44:25 +01:00
|
|
|
*(str++) = EXT_CTRL_CODE_BEGIN;
|
|
|
|
*(str++) = EXT_CTRL_CODE_SKIP;
|
|
|
|
*(str++) = 60;
|
Undo PokeCodec's PRs
This commit undoes most of PokeCodec's PRs after the debate in chat. Some
harmless or completely superseded PRs have been left alone, as there is not
much benefit in attempting to undo them.
Reverts #1104, #1108, #1115, #1118, #1119, #1124, #1126, #1127, #1132, #1136,
#1137, #1139, #1140, #1144, #1148, #1149, #1150, #1153, #1155, #1177, #1179,
#1180, #1181, #1182 and #1183.
2020-09-13 09:22:50 +02:00
|
|
|
|
2020-12-15 03:44:25 +01:00
|
|
|
switch (gender)
|
|
|
|
{
|
|
|
|
default:
|
Undo PokeCodec's PRs
This commit undoes most of PokeCodec's PRs after the debate in chat. Some
harmless or completely superseded PRs have been left alone, as there is not
much benefit in attempting to undo them.
Reverts #1104, #1108, #1115, #1118, #1119, #1124, #1126, #1127, #1132, #1136,
#1137, #1139, #1140, #1144, #1148, #1149, #1150, #1153, #1155, #1177, #1179,
#1180, #1181, #1182 and #1183.
2020-09-13 09:22:50 +02:00
|
|
|
*(str++) = CHAR_SPACE;
|
2020-12-15 03:44:25 +01:00
|
|
|
break;
|
|
|
|
case MON_MALE:
|
|
|
|
*(str++) = EXT_CTRL_CODE_BEGIN;
|
|
|
|
*(str++) = EXT_CTRL_CODE_COLOR;
|
|
|
|
*(str++) = TEXT_COLOR_RED;
|
|
|
|
*(str++) = EXT_CTRL_CODE_BEGIN;
|
|
|
|
*(str++) = EXT_CTRL_CODE_SHADOW;
|
|
|
|
*(str++) = TEXT_COLOR_LIGHT_RED;
|
|
|
|
*(str++) = CHAR_MALE;
|
|
|
|
break;
|
|
|
|
case MON_FEMALE:
|
|
|
|
*(str++) = EXT_CTRL_CODE_BEGIN;
|
|
|
|
*(str++) = EXT_CTRL_CODE_COLOR;
|
|
|
|
*(str++) = TEXT_COLOR_GREEN;
|
|
|
|
*(str++) = EXT_CTRL_CODE_BEGIN;
|
|
|
|
*(str++) = EXT_CTRL_CODE_SHADOW;
|
|
|
|
*(str++) = TEXT_COLOR_LIGHT_GREEN;
|
|
|
|
*(str++) = CHAR_FEMALE;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
*(str++) = EXT_CTRL_CODE_BEGIN;
|
|
|
|
*(str++) = EXT_CTRL_CODE_COLOR_HIGHLIGHT_SHADOW;
|
|
|
|
*(str++) = TEXT_COLOR_BLUE;
|
|
|
|
*(str++) = TEXT_COLOR_TRANSPARENT;
|
|
|
|
*(str++) = TEXT_COLOR_LIGHT_BLUE;
|
|
|
|
*(str++) = CHAR_SLASH;
|
|
|
|
*(str++) = CHAR_EXTRA_SYMBOL;
|
|
|
|
*(str++) = CHAR_LV_2;
|
|
|
|
str = ConvertIntToDecimalStringN(str, level, STR_CONV_MODE_LEFT_ALIGN, 3);
|
|
|
|
*(str++) = CHAR_SPACE;
|
|
|
|
*str = EOS;
|
|
|
|
|
|
|
|
return str;
|
2019-03-31 12:59:01 +02:00
|
|
|
}
|
|
|
|
|
2020-08-10 23:05:42 +02:00
|
|
|
// Buffers the string in src to dest up to n chars. If src is less than n chars, fill with spaces
|
|
|
|
static u8 *BufferConditionMenuSpacedStringN(u8 *dst, const u8 *src, s16 n)
|
2019-03-31 12:59:01 +02:00
|
|
|
{
|
|
|
|
while (*src != EOS)
|
|
|
|
{
|
|
|
|
*(dst++) = *(src++);
|
|
|
|
n--;
|
|
|
|
}
|
|
|
|
while (n-- > 0)
|
|
|
|
*(dst++) = CHAR_SPACE;
|
|
|
|
|
|
|
|
*dst = EOS;
|
|
|
|
return dst;
|
|
|
|
}
|
|
|
|
|
2020-08-10 23:05:42 +02:00
|
|
|
void GetConditionMenuMonNameAndLocString(u8 *locationDst, u8 *nameDst, u16 boxId, u16 monId, u16 partyId, u16 numMons, bool8 excludesCancel)
|
2019-03-31 12:59:01 +02:00
|
|
|
{
|
|
|
|
u16 i;
|
2020-09-19 23:38:54 +02:00
|
|
|
u16 box = boxId;
|
|
|
|
u16 mon = monId;
|
2019-03-31 12:59:01 +02:00
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
// In this and the below 2 functions, numMons is passed as the number of menu selections (which includes Cancel)
|
2020-08-10 23:05:42 +02:00
|
|
|
// To indicate that the Cancel needs to be subtracted they pass an additional bool
|
|
|
|
// Unclear why they didn't just subtract 1 when it gets passed instead
|
|
|
|
if (!excludesCancel)
|
|
|
|
numMons--;
|
2019-03-31 12:59:01 +02:00
|
|
|
|
2020-08-10 23:05:42 +02:00
|
|
|
if (partyId != numMons)
|
2019-03-31 12:59:01 +02:00
|
|
|
{
|
2020-09-19 23:38:54 +02:00
|
|
|
GetConditionMenuMonString(nameDst, box, mon);
|
2020-08-10 23:05:42 +02:00
|
|
|
locationDst[0] = EXT_CTRL_CODE_BEGIN;
|
|
|
|
locationDst[1] = EXT_CTRL_CODE_COLOR_HIGHLIGHT_SHADOW;
|
|
|
|
locationDst[2] = TEXT_COLOR_BLUE;
|
|
|
|
locationDst[3] = TEXT_COLOR_TRANSPARENT;
|
|
|
|
locationDst[4] = TEXT_COLOR_LIGHT_BLUE;
|
2020-09-19 23:38:54 +02:00
|
|
|
if (box == TOTAL_BOXES_COUNT) // Party mon.
|
2020-08-10 23:05:42 +02:00
|
|
|
BufferConditionMenuSpacedStringN(&locationDst[5], gText_InParty, 8);
|
2019-03-31 12:59:01 +02:00
|
|
|
else
|
2020-09-19 23:38:54 +02:00
|
|
|
BufferConditionMenuSpacedStringN(&locationDst[5], GetBoxNamePtr(box), 8);
|
2019-03-31 12:59:01 +02:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2020-08-10 23:05:42 +02:00
|
|
|
for (i = 0; i < POKEMON_NAME_LENGTH + 2; i++)
|
2019-03-31 12:59:01 +02:00
|
|
|
nameDst[i] = CHAR_SPACE;
|
|
|
|
nameDst[i] = EOS;
|
|
|
|
for (i = 0; i < 8; i++)
|
2020-08-10 23:05:42 +02:00
|
|
|
locationDst[i] = CHAR_SPACE;
|
|
|
|
locationDst[i] = EOS;
|
2019-03-31 12:59:01 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
void GetConditionMenuMonConditions(struct ConditionGraph *graph, u8 *sheen, u16 boxId, u16 monId, u16 partyId, u16 id, u16 numMons, bool8 excludesCancel)
|
2019-03-31 12:59:01 +02:00
|
|
|
{
|
|
|
|
u16 i;
|
|
|
|
|
2020-08-10 23:05:42 +02:00
|
|
|
if (!excludesCancel)
|
|
|
|
numMons--;
|
2019-03-31 12:59:01 +02:00
|
|
|
|
2020-08-10 23:05:42 +02:00
|
|
|
if (partyId != numMons)
|
2019-03-31 12:59:01 +02:00
|
|
|
{
|
2020-10-11 00:17:34 +02:00
|
|
|
graph->stat[id][0] = GetBoxOrPartyMonData(boxId, monId, MON_DATA_COOL, NULL);
|
|
|
|
graph->stat[id][1] = GetBoxOrPartyMonData(boxId, monId, MON_DATA_TOUGH, NULL);
|
|
|
|
graph->stat[id][2] = GetBoxOrPartyMonData(boxId, monId, MON_DATA_SMART, NULL);
|
|
|
|
graph->stat[id][3] = GetBoxOrPartyMonData(boxId, monId, MON_DATA_CUTE, NULL);
|
|
|
|
graph->stat[id][4] = GetBoxOrPartyMonData(boxId, monId, MON_DATA_BEAUTY, NULL);
|
2019-03-31 12:59:01 +02:00
|
|
|
|
|
|
|
sheen[id] = (GetBoxOrPartyMonData(boxId, monId, MON_DATA_SHEEN, NULL) != 0xFF)
|
|
|
|
? GetBoxOrPartyMonData(boxId, monId, MON_DATA_SHEEN, NULL) / 29u
|
|
|
|
: 9;
|
|
|
|
|
2020-10-11 00:17:34 +02:00
|
|
|
sub_81D2754(graph->stat[id], graph->unk14[id]);
|
2019-03-31 12:59:01 +02:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2020-08-10 23:05:42 +02:00
|
|
|
for (i = 0; i < FLAVOR_COUNT; i++)
|
2019-03-31 12:59:01 +02:00
|
|
|
{
|
2020-10-11 00:17:34 +02:00
|
|
|
graph->stat[id][i] = 0;
|
2020-08-12 17:44:39 +02:00
|
|
|
graph->unk14[id][i].unk0 = 155;
|
|
|
|
graph->unk14[id][i].unk2 = 91;
|
2019-03-31 12:59:01 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-08-10 23:05:42 +02:00
|
|
|
void GetConditionMenuMonGfx(void *tilesDst, void *palDst, u16 boxId, u16 monId, u16 partyId, u16 numMons, bool8 excludesCancel)
|
2019-03-31 12:59:01 +02:00
|
|
|
{
|
2020-08-10 23:05:42 +02:00
|
|
|
if (!excludesCancel)
|
|
|
|
numMons--;
|
2019-03-31 12:59:01 +02:00
|
|
|
|
2020-08-10 23:05:42 +02:00
|
|
|
if (partyId != numMons)
|
2019-03-31 12:59:01 +02:00
|
|
|
{
|
|
|
|
u16 species = GetBoxOrPartyMonData(boxId, monId, MON_DATA_SPECIES2, NULL);
|
|
|
|
u32 trainerId = GetBoxOrPartyMonData(boxId, monId, MON_DATA_OT_ID, NULL);
|
|
|
|
u32 personality = GetBoxOrPartyMonData(boxId, monId, MON_DATA_PERSONALITY, NULL);
|
|
|
|
|
|
|
|
LoadSpecialPokePic(&gMonFrontPicTable[species], tilesDst, species, personality, TRUE);
|
2019-07-25 18:56:08 +02:00
|
|
|
LZ77UnCompWram(GetMonSpritePalFromSpeciesAndPersonality(species, trainerId, personality), palDst);
|
2019-03-31 12:59:01 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
bool8 MoveConditionMonOnscreen(s16 *x)
|
2019-03-31 12:59:01 +02:00
|
|
|
{
|
2020-08-12 17:44:39 +02:00
|
|
|
*x += 24;
|
|
|
|
if (*x > 0)
|
|
|
|
*x = 0;
|
2019-03-31 12:59:01 +02:00
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
return (*x != 0);
|
2019-03-31 12:59:01 +02:00
|
|
|
}
|
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
bool8 MoveConditionMonOffscreen(s16 *x)
|
2019-03-31 12:59:01 +02:00
|
|
|
{
|
2020-08-12 17:44:39 +02:00
|
|
|
*x -= 24;
|
|
|
|
if (*x < -80)
|
|
|
|
*x = -80;
|
2019-03-31 12:59:01 +02:00
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
return (*x != -80);
|
2019-03-31 12:59:01 +02:00
|
|
|
}
|
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
bool8 TryUpdateConditionMonTransitionOn(struct ConditionGraph *graph, s16 *x)
|
2019-03-31 12:59:01 +02:00
|
|
|
{
|
2020-08-12 17:44:39 +02:00
|
|
|
bool8 graphUpdating = TransitionConditionGraph(graph);
|
|
|
|
bool8 monUpdating = MoveConditionMonOnscreen(x);
|
2019-03-31 12:59:01 +02:00
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
return (graphUpdating || monUpdating);
|
2019-03-31 12:59:01 +02:00
|
|
|
}
|
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
bool8 TryUpdateConditionMonTransitionOff(struct ConditionGraph *graph, s16 *x)
|
2019-03-31 12:59:01 +02:00
|
|
|
{
|
2020-08-12 17:44:39 +02:00
|
|
|
bool8 graphUpdating = TransitionConditionGraph(graph);
|
|
|
|
bool8 monUpdating = MoveConditionMonOffscreen(x);
|
2019-03-31 12:59:01 +02:00
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
return (graphUpdating || monUpdating);
|
2019-03-31 12:59:01 +02:00
|
|
|
}
|
|
|
|
|
2020-08-10 19:48:16 +02:00
|
|
|
static const u32 sConditionPokeball_Gfx[] = INCBIN_U32("graphics/pokenav/condition/pokeball.4bpp");
|
|
|
|
static const u32 sConditionPokeballPlaceholder_Gfx[] = INCBIN_U32("graphics/pokenav/condition/pokeball_placeholder.4bpp");
|
|
|
|
static const u16 sConditionSparkle_Gfx[] = INCBIN_U16("graphics/pokenav/condition/sparkle.gbapal");
|
|
|
|
static const u32 sConditionSparkle_Pal[] = INCBIN_U32("graphics/pokenav/condition/sparkle.4bpp");
|
2019-03-31 12:59:01 +02:00
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
static const struct OamData sOam_ConditionMonPic =
|
2019-03-31 12:59:01 +02:00
|
|
|
{
|
|
|
|
.y = 0,
|
2019-12-04 21:25:13 +01:00
|
|
|
.affineMode = ST_OAM_AFFINE_OFF,
|
|
|
|
.objMode = ST_OAM_OBJ_NORMAL,
|
2019-03-31 12:59:01 +02:00
|
|
|
.mosaic = 0,
|
2019-12-04 21:25:13 +01:00
|
|
|
.bpp = ST_OAM_4BPP,
|
|
|
|
.shape = SPRITE_SHAPE(64x64),
|
2019-03-31 12:59:01 +02:00
|
|
|
.x = 0,
|
|
|
|
.matrixNum = 0,
|
2019-12-04 21:25:13 +01:00
|
|
|
.size = SPRITE_SIZE(64x64),
|
2019-03-31 12:59:01 +02:00
|
|
|
.tileNum = 0,
|
|
|
|
.priority = 1,
|
|
|
|
.paletteNum = 0,
|
|
|
|
.affineParam = 0
|
|
|
|
};
|
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
static const struct OamData sOam_ConditionSelectionIcon =
|
2019-03-31 12:59:01 +02:00
|
|
|
{
|
|
|
|
.y = 0,
|
2019-12-04 21:25:13 +01:00
|
|
|
.affineMode = ST_OAM_AFFINE_OFF,
|
|
|
|
.objMode = ST_OAM_OBJ_NORMAL,
|
2019-03-31 12:59:01 +02:00
|
|
|
.mosaic = 0,
|
2019-12-04 21:25:13 +01:00
|
|
|
.bpp = ST_OAM_4BPP,
|
|
|
|
.shape = SPRITE_SHAPE(16x16),
|
2019-03-31 12:59:01 +02:00
|
|
|
.x = 0,
|
|
|
|
.matrixNum = 0,
|
2019-12-04 21:25:13 +01:00
|
|
|
.size = SPRITE_SIZE(16x16),
|
2019-03-31 12:59:01 +02:00
|
|
|
.tileNum = 0,
|
|
|
|
.priority = 2,
|
|
|
|
.paletteNum = 0,
|
|
|
|
.affineParam = 0
|
|
|
|
};
|
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
static const union AnimCmd sAnim_ConditionSelectionIcon_Selected[] =
|
2019-03-31 12:59:01 +02:00
|
|
|
{
|
|
|
|
ANIMCMD_FRAME(0, 5),
|
|
|
|
ANIMCMD_END
|
|
|
|
};
|
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
static const union AnimCmd sAnim_ConditionSelectionIcon_Unselected[] =
|
2019-03-31 12:59:01 +02:00
|
|
|
{
|
|
|
|
ANIMCMD_FRAME(4, 5),
|
|
|
|
ANIMCMD_END
|
|
|
|
};
|
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
static const union AnimCmd *const sAnims_ConditionSelectionIcon[] =
|
2019-03-31 12:59:01 +02:00
|
|
|
{
|
2020-08-12 17:44:39 +02:00
|
|
|
sAnim_ConditionSelectionIcon_Selected,
|
|
|
|
sAnim_ConditionSelectionIcon_Unselected
|
2019-03-31 12:59:01 +02:00
|
|
|
};
|
|
|
|
|
2020-08-10 23:05:42 +02:00
|
|
|
// Just loads the generic data, up to the caller to load the actual sheet/pal for the specific mon
|
|
|
|
void LoadConditionMonPicTemplate(struct SpriteSheet *sheet, struct SpriteTemplate *template, struct SpritePalette *pal)
|
2019-03-31 12:59:01 +02:00
|
|
|
{
|
2020-08-12 17:44:39 +02:00
|
|
|
struct SpriteSheet dataSheet = {NULL, 0x800, TAG_CONDITION_MON};
|
2019-03-31 12:59:01 +02:00
|
|
|
|
|
|
|
struct SpriteTemplate dataTemplate =
|
|
|
|
{
|
2020-08-12 17:44:39 +02:00
|
|
|
.tileTag = TAG_CONDITION_MON,
|
|
|
|
.paletteTag = TAG_CONDITION_MON,
|
|
|
|
.oam = &sOam_ConditionMonPic,
|
2019-03-31 12:59:01 +02:00
|
|
|
.anims = gDummySpriteAnimTable,
|
|
|
|
.images = NULL,
|
|
|
|
.affineAnims = gDummySpriteAffineAnimTable,
|
|
|
|
.callback = SpriteCallbackDummy,
|
|
|
|
};
|
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
struct SpritePalette dataPal = {NULL, TAG_CONDITION_MON};
|
2019-03-31 12:59:01 +02:00
|
|
|
|
|
|
|
*sheet = dataSheet;
|
|
|
|
*template = dataTemplate;
|
|
|
|
*pal = dataPal;
|
|
|
|
}
|
|
|
|
|
2020-08-10 19:48:16 +02:00
|
|
|
void LoadConditionSelectionIcons(struct SpriteSheet *sheets, struct SpriteTemplate * template, struct SpritePalette *pals)
|
2019-03-31 12:59:01 +02:00
|
|
|
{
|
|
|
|
u8 i;
|
|
|
|
|
|
|
|
struct SpriteSheet dataSheets[] =
|
|
|
|
{
|
2020-08-12 17:44:39 +02:00
|
|
|
{sConditionPokeball_Gfx, 0x100, TAG_CONDITION_BALL},
|
|
|
|
{sConditionPokeballPlaceholder_Gfx, 0x20, TAG_CONDITION_BALL_PLACEHOLDER},
|
|
|
|
{gPokenavConditionCancel_Gfx, 0x100, TAG_CONDITION_CANCEL},
|
2019-03-31 12:59:01 +02:00
|
|
|
{},
|
|
|
|
};
|
|
|
|
|
|
|
|
struct SpritePalette dataPals[] =
|
|
|
|
{
|
2020-08-12 17:44:39 +02:00
|
|
|
{gPokenavConditionCancel_Pal, TAG_CONDITION_BALL},
|
|
|
|
{gPokenavConditionCancel_Pal + 16, TAG_CONDITION_CANCEL},
|
2019-03-31 12:59:01 +02:00
|
|
|
{},
|
|
|
|
};
|
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
// Tag is overwritten for the other selection icons
|
2019-03-31 12:59:01 +02:00
|
|
|
struct SpriteTemplate dataTemplate =
|
|
|
|
{
|
2020-08-12 17:44:39 +02:00
|
|
|
.tileTag = TAG_CONDITION_BALL,
|
|
|
|
.paletteTag = TAG_CONDITION_BALL,
|
|
|
|
.oam = &sOam_ConditionSelectionIcon,
|
|
|
|
.anims = sAnims_ConditionSelectionIcon,
|
2019-03-31 12:59:01 +02:00
|
|
|
.images = NULL,
|
|
|
|
.affineAnims = gDummySpriteAffineAnimTable,
|
|
|
|
.callback = SpriteCallbackDummy,
|
|
|
|
};
|
|
|
|
|
|
|
|
for (i = 0; i < ARRAY_COUNT(dataSheets); i++)
|
|
|
|
*(sheets++) = dataSheets[i];
|
|
|
|
|
|
|
|
*template = dataTemplate;
|
|
|
|
|
|
|
|
for (i = 0; i < ARRAY_COUNT(dataPals); i++)
|
|
|
|
*(pals++) = dataPals[i];
|
|
|
|
}
|
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
#define sSparkleId data[0]
|
|
|
|
#define sDelayTimer data[1]
|
|
|
|
#define sNumExtraSparkles data[2]
|
|
|
|
#define sCurSparkleId data[3]
|
|
|
|
#define sMonSpriteId data[4]
|
|
|
|
#define sNextSparkleSpriteId data[5]
|
|
|
|
|
2020-08-10 19:48:16 +02:00
|
|
|
void LoadConditionSparkle(struct SpriteSheet *sheet, struct SpritePalette *pal)
|
2019-03-31 12:59:01 +02:00
|
|
|
{
|
2020-08-12 17:44:39 +02:00
|
|
|
struct SpriteSheet dataSheet = {sConditionSparkle_Pal, 0x380, TAG_CONDITION_SPARKLE};
|
|
|
|
struct SpritePalette dataPal = {sConditionSparkle_Gfx, TAG_CONDITION_SPARKLE};
|
2019-03-31 12:59:01 +02:00
|
|
|
|
|
|
|
*sheet = dataSheet;
|
|
|
|
*pal = dataPal;
|
|
|
|
}
|
2019-03-31 14:32:26 +02:00
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
static void SpriteCB_ConditionSparkle_DoNextAfterDelay(struct Sprite *sprite)
|
2019-03-31 14:32:26 +02:00
|
|
|
{
|
2020-08-12 17:44:39 +02:00
|
|
|
if (++sprite->sDelayTimer > 60)
|
2019-03-31 14:32:26 +02:00
|
|
|
{
|
2020-08-12 17:44:39 +02:00
|
|
|
sprite->sDelayTimer = 0;
|
|
|
|
SetNextConditionSparkle(sprite);
|
2019-03-31 14:32:26 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
static void SpriteCB_ConditionSparkle_WaitForAllAnim(struct Sprite *sprite)
|
2019-03-31 14:32:26 +02:00
|
|
|
{
|
|
|
|
if (sprite->animEnded)
|
|
|
|
{
|
2020-08-12 17:44:39 +02:00
|
|
|
sprite->sDelayTimer = 0;
|
|
|
|
sprite->callback = SpriteCB_ConditionSparkle_DoNextAfterDelay;
|
2019-03-31 14:32:26 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-08-10 19:48:16 +02:00
|
|
|
static const struct OamData sOam_ConditionSparkle =
|
2019-04-04 21:24:21 +02:00
|
|
|
{
|
|
|
|
.y = 0,
|
2019-04-05 09:22:56 +02:00
|
|
|
.affineMode = ST_OAM_AFFINE_OFF,
|
|
|
|
.objMode = ST_OAM_OBJ_NORMAL,
|
|
|
|
.bpp = ST_OAM_4BPP,
|
|
|
|
.shape = SPRITE_SHAPE(16x16),
|
2019-04-04 21:24:21 +02:00
|
|
|
.x = 0,
|
2019-04-05 09:22:56 +02:00
|
|
|
.size = SPRITE_SIZE(16x16),
|
2019-04-04 21:24:21 +02:00
|
|
|
.priority = 0,
|
|
|
|
};
|
|
|
|
|
2020-08-10 19:48:16 +02:00
|
|
|
static const union AnimCmd sAnim_ConditionSparkle[] =
|
2019-04-04 21:24:21 +02:00
|
|
|
{
|
|
|
|
ANIMCMD_FRAME(0, 5),
|
|
|
|
ANIMCMD_FRAME(4, 5),
|
|
|
|
ANIMCMD_FRAME(8, 5),
|
|
|
|
ANIMCMD_FRAME(12, 5),
|
|
|
|
ANIMCMD_FRAME(16, 5),
|
|
|
|
ANIMCMD_FRAME(20, 5),
|
|
|
|
ANIMCMD_FRAME(24, 5),
|
|
|
|
ANIMCMD_END
|
|
|
|
};
|
|
|
|
|
2020-08-10 19:48:16 +02:00
|
|
|
static const union AnimCmd *const sAnims_ConditionSparkle[] =
|
2019-04-04 21:24:21 +02:00
|
|
|
{
|
2020-08-12 17:44:39 +02:00
|
|
|
&sAnim_ConditionSparkle[0], // Only this entry is used
|
|
|
|
&sAnim_ConditionSparkle[2],
|
|
|
|
&sAnim_ConditionSparkle[4],
|
|
|
|
&sAnim_ConditionSparkle[6],
|
|
|
|
&sAnim_ConditionSparkle[8], // Here below OOB, will crash if used
|
|
|
|
&sAnim_ConditionSparkle[10],
|
|
|
|
&sAnim_ConditionSparkle[12],
|
2019-04-04 21:24:21 +02:00
|
|
|
};
|
|
|
|
|
2020-08-10 19:48:16 +02:00
|
|
|
static const struct SpriteTemplate sSpriteTemplate_ConditionSparkle =
|
2019-04-04 21:24:21 +02:00
|
|
|
{
|
2020-08-12 17:44:39 +02:00
|
|
|
.tileTag = TAG_CONDITION_SPARKLE,
|
|
|
|
.paletteTag = TAG_CONDITION_SPARKLE,
|
2020-08-10 19:48:16 +02:00
|
|
|
.oam = &sOam_ConditionSparkle,
|
|
|
|
.anims = sAnims_ConditionSparkle,
|
2019-04-04 21:24:21 +02:00
|
|
|
.images = NULL,
|
|
|
|
.affineAnims = gDummySpriteAffineAnimTable,
|
2020-08-10 19:48:16 +02:00
|
|
|
.callback = SpriteCB_ConditionSparkle,
|
2019-04-04 21:24:21 +02:00
|
|
|
};
|
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
static const s16 sConditionSparkleCoords[MAX_CONDITION_SPARKLES][2] =
|
|
|
|
{
|
|
|
|
{ 0, -35},
|
|
|
|
{ 20, -28},
|
|
|
|
{ 33, -10},
|
|
|
|
{ 33, 10},
|
|
|
|
{ 20, 28},
|
|
|
|
{ 0, 35},
|
|
|
|
{-20, 28},
|
|
|
|
{-33, 10},
|
|
|
|
{-33, -10},
|
|
|
|
{-20, -28},
|
2019-04-04 21:24:21 +02:00
|
|
|
};
|
2019-03-31 14:32:26 +02:00
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
static void SetConditionSparklePosition(struct Sprite *sprite)
|
2019-03-31 14:32:26 +02:00
|
|
|
{
|
2020-08-12 17:44:39 +02:00
|
|
|
struct Sprite *mon = &gSprites[sprite->sMonSpriteId];
|
2019-03-31 14:32:26 +02:00
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
if (mon != NULL)
|
2019-03-31 14:32:26 +02:00
|
|
|
{
|
2020-08-12 17:44:39 +02:00
|
|
|
sprite->pos1.x = mon->pos1.x + mon->pos2.x + sConditionSparkleCoords[sprite->sSparkleId][0];
|
|
|
|
sprite->pos1.y = mon->pos1.y + mon->pos2.y + sConditionSparkleCoords[sprite->sSparkleId][1];
|
2019-03-31 14:32:26 +02:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2020-08-12 17:44:39 +02:00
|
|
|
sprite->pos1.x = sConditionSparkleCoords[sprite->sSparkleId][0] + 40;
|
|
|
|
sprite->pos1.y = sConditionSparkleCoords[sprite->sSparkleId][1] + 104;
|
2019-03-31 14:32:26 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
static void InitConditionSparkles(u8 count, bool8 allowFirstShowAll, struct Sprite **sprites)
|
2019-03-31 14:32:26 +02:00
|
|
|
{
|
|
|
|
u16 i;
|
|
|
|
|
2020-08-10 23:05:42 +02:00
|
|
|
for (i = 0; i < MAX_CONDITION_SPARKLES; i++)
|
2019-03-31 14:32:26 +02:00
|
|
|
{
|
|
|
|
if (sprites[i] != NULL)
|
|
|
|
{
|
2020-08-12 17:44:39 +02:00
|
|
|
sprites[i]->sSparkleId = i;
|
|
|
|
sprites[i]->sDelayTimer = (i * 16) + 1;
|
|
|
|
sprites[i]->sNumExtraSparkles = count;
|
|
|
|
sprites[i]->sCurSparkleId = i;
|
|
|
|
if (!allowFirstShowAll || count != MAX_CONDITION_SPARKLES - 1)
|
2019-03-31 14:32:26 +02:00
|
|
|
{
|
2020-08-10 19:48:16 +02:00
|
|
|
sprites[i]->callback = SpriteCB_ConditionSparkle;
|
2019-03-31 14:32:26 +02:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2020-08-12 17:44:39 +02:00
|
|
|
SetConditionSparklePosition(sprites[i]);
|
|
|
|
ShowAllConditionSparkles(sprites[i]);
|
|
|
|
sprites[i]->callback = SpriteCB_ConditionSparkle_WaitForAllAnim;
|
2019-03-31 14:32:26 +02:00
|
|
|
sprites[i]->invisible = FALSE;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
static void SetNextConditionSparkle(struct Sprite *sprite)
|
2019-03-31 14:32:26 +02:00
|
|
|
{
|
|
|
|
u16 i;
|
2020-08-12 17:44:39 +02:00
|
|
|
u8 id = sprite->sNextSparkleSpriteId;
|
|
|
|
for (i = 0; i < sprite->sNumExtraSparkles + 1; i++)
|
2019-03-31 14:32:26 +02:00
|
|
|
{
|
2020-08-12 17:44:39 +02:00
|
|
|
gSprites[id].sDelayTimer = (gSprites[id].sSparkleId * 16) + 1;
|
2020-08-10 19:48:16 +02:00
|
|
|
gSprites[id].callback = SpriteCB_ConditionSparkle;
|
2020-08-12 17:44:39 +02:00
|
|
|
id = gSprites[id].sNextSparkleSpriteId;
|
2019-03-31 14:32:26 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-08-10 19:48:16 +02:00
|
|
|
void ResetConditionSparkleSprites(struct Sprite **sprites)
|
2019-03-31 14:32:26 +02:00
|
|
|
{
|
|
|
|
u8 i;
|
|
|
|
|
2020-08-10 23:05:42 +02:00
|
|
|
for (i = 0; i < MAX_CONDITION_SPARKLES; i++)
|
2019-03-31 14:32:26 +02:00
|
|
|
sprites[i] = NULL;
|
|
|
|
}
|
|
|
|
|
2020-08-10 23:05:42 +02:00
|
|
|
void CreateConditionSparkleSprites(struct Sprite **sprites, u8 monSpriteId, u8 _count)
|
2019-03-31 14:32:26 +02:00
|
|
|
{
|
|
|
|
u16 i, spriteId, firstSpriteId = 0;
|
2020-08-10 19:48:16 +02:00
|
|
|
u8 count = _count;
|
2019-03-31 14:32:26 +02:00
|
|
|
|
|
|
|
for (i = 0; i < count + 1; i++)
|
|
|
|
{
|
2020-08-10 19:48:16 +02:00
|
|
|
spriteId = CreateSprite(&sSpriteTemplate_ConditionSparkle, 0, 0, 0);
|
2019-03-31 14:32:26 +02:00
|
|
|
if (spriteId != MAX_SPRITES)
|
|
|
|
{
|
|
|
|
sprites[i] = &gSprites[spriteId];
|
|
|
|
sprites[i]->invisible = TRUE;
|
2020-08-12 17:44:39 +02:00
|
|
|
sprites[i]->sMonSpriteId = monSpriteId;
|
2019-03-31 14:32:26 +02:00
|
|
|
if (i != 0)
|
2020-08-12 17:44:39 +02:00
|
|
|
sprites[i - 1]->sNextSparkleSpriteId = spriteId;
|
2019-03-31 14:32:26 +02:00
|
|
|
else
|
|
|
|
firstSpriteId = spriteId;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
sprites[count]->sNextSparkleSpriteId = firstSpriteId;
|
|
|
|
InitConditionSparkles(count, TRUE, sprites);
|
2019-03-31 14:32:26 +02:00
|
|
|
}
|
|
|
|
|
2020-08-10 19:48:16 +02:00
|
|
|
void DestroyConditionSparkleSprites(struct Sprite **sprites)
|
2019-03-31 14:32:26 +02:00
|
|
|
{
|
|
|
|
u16 i;
|
|
|
|
|
2020-08-10 23:05:42 +02:00
|
|
|
for (i = 0; i < MAX_CONDITION_SPARKLES; i++)
|
2019-03-31 14:32:26 +02:00
|
|
|
{
|
|
|
|
if (sprites[i] != NULL)
|
|
|
|
{
|
|
|
|
DestroySprite(sprites[i]);
|
|
|
|
sprites[i] = NULL;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-08-10 19:48:16 +02:00
|
|
|
void FreeConditionSparkles(struct Sprite **sprites)
|
2019-03-31 14:32:26 +02:00
|
|
|
{
|
2020-08-10 19:48:16 +02:00
|
|
|
DestroyConditionSparkleSprites(sprites);
|
2020-08-12 17:44:39 +02:00
|
|
|
FreeSpriteTilesByTag(TAG_CONDITION_SPARKLE);
|
|
|
|
FreeSpritePaletteByTag(TAG_CONDITION_SPARKLE);
|
2019-03-31 14:32:26 +02:00
|
|
|
}
|
|
|
|
|
2020-08-10 19:48:16 +02:00
|
|
|
static void SpriteCB_ConditionSparkle(struct Sprite *sprite)
|
2019-03-31 14:32:26 +02:00
|
|
|
{
|
2020-08-12 17:44:39 +02:00
|
|
|
// Delay, then do sparkle anim
|
|
|
|
if (sprite->sDelayTimer != 0)
|
2019-03-31 14:32:26 +02:00
|
|
|
{
|
2020-08-12 17:44:39 +02:00
|
|
|
if (--sprite->sDelayTimer != 0)
|
2019-03-31 14:32:26 +02:00
|
|
|
return;
|
|
|
|
|
|
|
|
SeekSpriteAnim(sprite, 0);
|
|
|
|
sprite->invisible = FALSE;
|
|
|
|
}
|
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
SetConditionSparklePosition(sprite);
|
|
|
|
|
|
|
|
// Set up next sparkle
|
2019-03-31 14:32:26 +02:00
|
|
|
if (sprite->animEnded)
|
|
|
|
{
|
|
|
|
sprite->invisible = TRUE;
|
2020-08-12 17:44:39 +02:00
|
|
|
if (sprite->sCurSparkleId == sprite->sNumExtraSparkles)
|
2019-03-31 14:32:26 +02:00
|
|
|
{
|
2020-08-12 17:44:39 +02:00
|
|
|
if (sprite->sCurSparkleId == MAX_CONDITION_SPARKLES - 1)
|
2019-03-31 14:32:26 +02:00
|
|
|
{
|
2020-08-12 17:44:39 +02:00
|
|
|
ShowAllConditionSparkles(sprite);
|
|
|
|
sprite->callback = SpriteCB_ConditionSparkle_WaitForAllAnim;
|
2019-03-31 14:32:26 +02:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2020-08-12 17:44:39 +02:00
|
|
|
sprite->callback = SpriteCB_ConditionSparkle_DoNextAfterDelay;
|
2019-03-31 14:32:26 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
sprite->callback = SpriteCallbackDummy;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
static void ShowAllConditionSparkles(struct Sprite *sprite)
|
2019-03-31 14:32:26 +02:00
|
|
|
{
|
2020-08-12 17:44:39 +02:00
|
|
|
u8 i, id = sprite->sNextSparkleSpriteId;
|
2019-03-31 14:32:26 +02:00
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
for (i = 0; i < sprite->sNumExtraSparkles + 1; i++)
|
2019-03-31 14:32:26 +02:00
|
|
|
{
|
|
|
|
SeekSpriteAnim(&gSprites[id], 0);
|
|
|
|
gSprites[id].invisible = FALSE;
|
2020-08-12 17:44:39 +02:00
|
|
|
id = gSprites[id].sNextSparkleSpriteId;
|
2019-03-31 14:32:26 +02:00
|
|
|
}
|
|
|
|
}
|
2019-04-03 04:18:36 +02:00
|
|
|
|
2020-08-12 17:44:39 +02:00
|
|
|
#undef sSparkleId
|
|
|
|
#undef sDelayTimer
|
|
|
|
#undef sNumExtraSparkles
|
|
|
|
#undef sCurSparkleId
|
|
|
|
#undef sMonSpriteId
|
|
|
|
#undef sNextSparkleSpriteId
|
|
|
|
|
2019-12-10 19:48:20 +01:00
|
|
|
static const u8 *const sLvlUpStatStrings[NUM_STATS] =
|
2019-04-03 04:18:36 +02:00
|
|
|
{
|
2019-12-10 19:48:20 +01:00
|
|
|
gText_MaxHP,
|
|
|
|
gText_Attack,
|
|
|
|
gText_Defense,
|
|
|
|
gText_SpAtk,
|
|
|
|
gText_SpDef,
|
|
|
|
gText_Speed
|
2019-04-04 21:24:21 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
void DrawLevelUpWindowPg1(u16 windowId, u16 *statsBefore, u16 *statsAfter, u8 bgClr, u8 fgClr, u8 shadowClr)
|
|
|
|
{
|
|
|
|
u16 i, x;
|
|
|
|
s16 statsDiff[NUM_STATS];
|
|
|
|
u8 text[12];
|
|
|
|
u8 color[3];
|
|
|
|
|
|
|
|
FillWindowPixelBuffer(windowId, PIXEL_FILL(bgClr));
|
|
|
|
|
|
|
|
statsDiff[0] = statsAfter[STAT_HP] - statsBefore[STAT_HP];
|
|
|
|
statsDiff[1] = statsAfter[STAT_ATK] - statsBefore[STAT_ATK];
|
|
|
|
statsDiff[2] = statsAfter[STAT_DEF] - statsBefore[STAT_DEF];
|
|
|
|
statsDiff[3] = statsAfter[STAT_SPATK] - statsBefore[STAT_SPATK];
|
|
|
|
statsDiff[4] = statsAfter[STAT_SPDEF] - statsBefore[STAT_SPDEF];
|
|
|
|
statsDiff[5] = statsAfter[STAT_SPEED] - statsBefore[STAT_SPEED];
|
|
|
|
|
|
|
|
color[0] = bgClr;
|
|
|
|
color[1] = fgClr;
|
|
|
|
color[2] = shadowClr;
|
|
|
|
|
|
|
|
for (i = 0; i < NUM_STATS; i++)
|
|
|
|
{
|
|
|
|
|
|
|
|
AddTextPrinterParameterized3(windowId,
|
|
|
|
1,
|
|
|
|
0,
|
|
|
|
15 * i,
|
|
|
|
color,
|
|
|
|
-1,
|
|
|
|
sLvlUpStatStrings[i]);
|
|
|
|
|
2019-12-10 19:48:20 +01:00
|
|
|
StringCopy(text, (statsDiff[i] >= 0) ? gText_Plus : gText_Dash);
|
2019-04-04 21:24:21 +02:00
|
|
|
AddTextPrinterParameterized3(windowId,
|
|
|
|
1,
|
|
|
|
56,
|
|
|
|
15 * i,
|
|
|
|
color,
|
|
|
|
-1,
|
|
|
|
text);
|
|
|
|
if (abs(statsDiff[i]) <= 9)
|
|
|
|
x = 18;
|
|
|
|
else
|
|
|
|
x = 12;
|
|
|
|
|
|
|
|
ConvertIntToDecimalStringN(text, abs(statsDiff[i]), STR_CONV_MODE_LEFT_ALIGN, 2);
|
|
|
|
AddTextPrinterParameterized3(windowId,
|
|
|
|
1,
|
|
|
|
56 + x,
|
|
|
|
15 * i,
|
|
|
|
color,
|
|
|
|
-1,
|
|
|
|
text);
|
2019-04-03 04:18:36 +02:00
|
|
|
}
|
|
|
|
}
|
2019-04-04 21:24:21 +02:00
|
|
|
|
|
|
|
void DrawLevelUpWindowPg2(u16 windowId, u16 *currStats, u8 bgClr, u8 fgClr, u8 shadowClr)
|
|
|
|
{
|
|
|
|
u16 i, numDigits, x;
|
|
|
|
s16 stats[NUM_STATS];
|
|
|
|
u8 text[12];
|
|
|
|
u8 color[3];
|
|
|
|
|
|
|
|
FillWindowPixelBuffer(windowId, PIXEL_FILL(bgClr));
|
|
|
|
|
|
|
|
stats[0] = currStats[STAT_HP];
|
|
|
|
stats[1] = currStats[STAT_ATK];
|
|
|
|
stats[2] = currStats[STAT_DEF];
|
|
|
|
stats[3] = currStats[STAT_SPATK];
|
|
|
|
stats[4] = currStats[STAT_SPDEF];
|
|
|
|
stats[5] = currStats[STAT_SPEED];
|
|
|
|
|
|
|
|
color[0] = bgClr;
|
|
|
|
color[1] = fgClr;
|
|
|
|
color[2] = shadowClr;
|
|
|
|
|
|
|
|
for (i = 0; i < NUM_STATS; i++)
|
|
|
|
{
|
|
|
|
if (stats[i] > 99)
|
|
|
|
numDigits = 3;
|
|
|
|
else if (stats[i] > 9)
|
|
|
|
numDigits = 2;
|
|
|
|
else
|
|
|
|
numDigits = 1;
|
|
|
|
|
|
|
|
ConvertIntToDecimalStringN(text, stats[i], STR_CONV_MODE_LEFT_ALIGN, numDigits);
|
|
|
|
x = 6 * (4 - numDigits);
|
|
|
|
|
|
|
|
AddTextPrinterParameterized3(windowId,
|
|
|
|
1,
|
|
|
|
0,
|
|
|
|
15 * i,
|
|
|
|
color,
|
|
|
|
-1,
|
|
|
|
sLvlUpStatStrings[i]);
|
|
|
|
|
|
|
|
AddTextPrinterParameterized3(windowId,
|
|
|
|
1,
|
|
|
|
56 + x,
|
|
|
|
15 * i,
|
|
|
|
color,
|
|
|
|
-1,
|
|
|
|
text);
|
2019-04-03 04:18:36 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-04-04 21:24:21 +02:00
|
|
|
void GetMonLevelUpWindowStats(struct Pokemon *mon, u16 *currStats)
|
2019-04-03 04:18:36 +02:00
|
|
|
{
|
2019-04-04 21:24:21 +02:00
|
|
|
currStats[STAT_HP] = GetMonData(mon, MON_DATA_MAX_HP);
|
|
|
|
currStats[STAT_ATK] = GetMonData(mon, MON_DATA_ATK);
|
|
|
|
currStats[STAT_DEF] = GetMonData(mon, MON_DATA_DEF);
|
|
|
|
currStats[STAT_SPEED] = GetMonData(mon, MON_DATA_SPEED);
|
|
|
|
currStats[STAT_SPATK] = GetMonData(mon, MON_DATA_SPATK);
|
|
|
|
currStats[STAT_SPDEF] = GetMonData(mon, MON_DATA_SPDEF);
|
2019-04-03 04:18:36 +02:00
|
|
|
}
|