summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorPikalaxALT <pikalaxalt@gmail.com>2020-01-07 14:21:55 -0500
committerPikalaxALT <pikalaxalt@gmail.com>2020-01-07 14:21:55 -0500
commitb39a83fc032e8f5d168561906bad3907bc794d08 (patch)
tree43f5cb219d735187ab73d57b929aeb6b6969c60c /src
parente4d869bfc6aceb8b8e208016f08158a3a89dfd46 (diff)
through sub_80C47F0
Diffstat (limited to 'src')
-rw-r--r--src/region_map.c199
1 files changed, 197 insertions, 2 deletions
diff --git a/src/region_map.c b/src/region_map.c
index 7ce44b421..90b25c36b 100644
--- a/src/region_map.c
+++ b/src/region_map.c
@@ -161,7 +161,7 @@ struct UnkStruct_20399E4
u16 field_020;
u16 field_022;
u16 field_024[0x080];
-};
+}; // size = 0x124
struct UnkStruct_20399E8
{
@@ -171,15 +171,37 @@ struct UnkStruct_20399E8
u16 field_08;
u16 field_0A;
u16 field_0C[0x40];
+}; // size = 0x8C
+
+struct UnkStruct_20399EC_2D4
+{
+ u8 field_0;
+ struct Sprite * field_4;
+ u8 filler_8[8];
};
+struct UnkStruct_20399EC
+{
+ u8 field_000[0x40];
+ u8 field_040[0x100];
+ u8 field_140[4];
+ struct UnkStruct_20399EC_2D4 field_144[25];
+ struct UnkStruct_20399EC_2D4 field_2D4[24];
+ u8 field_454[0xC];
+ u8 field_460;
+ u8 filler_461[2];
+ u8 field_463;
+ u8 filler_464[4];
+ TaskFunc field_468;
+}; // size = 0x46C
+
EWRAM_DATA struct UnkStruct_20399D4 * gUnknown_20399D4 = NULL;
EWRAM_DATA struct UnkStruct_20399D8 * gUnknown_20399D8 = NULL;
EWRAM_DATA struct UnkStruct_20399DC * gUnknown_20399DC = NULL;
EWRAM_DATA struct UnkStruct_20399E0 * gUnknown_20399E0 = NULL;
EWRAM_DATA struct UnkStruct_20399E4 * gUnknown_20399E4 = NULL;
EWRAM_DATA struct UnkStruct_20399E8 * gUnknown_20399E8 = NULL;
-EWRAM_DATA void * gUnknown_20399EC = NULL;
+EWRAM_DATA struct UnkStruct_20399EC * gUnknown_20399EC = NULL;
EWRAM_DATA void * gUnknown_20399F0[3] = {};
EWRAM_DATA void * gUnknown_20399FC = NULL;
@@ -258,6 +280,10 @@ void sub_80C4348(void);
u16 sub_80C4380();
u16 sub_80C438C();
void sub_80C4398(u8 a0, u8 taskId, TaskFunc taskFunc);
+void sub_80C440C(u8 taskId);
+void sub_80C44E4(u8 taskId);
+void sub_80C4750(void);
+void sub_80C47F0(void);
void sub_80C48BC(u8 a0, u8 a1, u8 a2);
void sub_80C4960(u8 a0, u8 a1, u8 a2);
void sub_80C4A04(void);
@@ -282,6 +308,7 @@ extern const u16 gUnknown_83EF23C[];
extern const u16 gUnknown_83EF25C[];
extern const u16 gUnknown_83EF27C[];
extern const u16 gUnknown_83EF29C[];
+extern const u16 gUnknown_83EF2BC[];
extern const u16 gUnknown_83EF2DC[];
extern const u16 gUnknown_83EF384[];
extern const u16 gUnknown_83EF3A4[];
@@ -307,6 +334,8 @@ extern const u32 gUnknown_83F1550[];
extern const u32 gUnknown_83F1640[];
extern const u32 gUnknown_83F1738[];
extern const u32 gUnknown_83F1804[];
+extern const u32 gUnknown_83F18D8[];
+extern const u32 gUnknown_83F1908[];
extern const u32 gUnknown_83F1978[];
extern const u32 gUnknown_83F19A0[];
extern const struct BgTemplate gUnknown_83F1A50[4];
@@ -327,6 +356,10 @@ extern const struct OamData gUnknown_83F1C3C;
extern const union AnimCmd *const gUnknown_83F1C50[];
extern const struct OamData gUnknown_83F1C54;
extern const union AnimCmd *const gUnknown_83F1C64[];
+extern const struct OamData gUnknown_83F1C68;
+extern const struct OamData gUnknown_83F1C70;
+extern const union AnimCmd *const gUnknown_83F1C94[];
+extern const union AnimCmd *const gUnknown_83F1C98[];
extern const u8 *const gUnknown_83F1CAC[];
extern const u16 gUnknown_83F1E60[][2];
extern const u16 gUnknown_83F2178[][2];
@@ -2829,3 +2862,165 @@ u16 sub_80C438C(void)
{
return gUnknown_20399E8->field_02;
}
+
+void sub_80C4398(u8 a0, u8 taskId, TaskFunc taskFunc)
+{
+ gUnknown_20399EC = AllocZeroed(sizeof(struct UnkStruct_20399EC));
+ gUnknown_20399EC->field_468 = taskFunc;
+ gUnknown_20399EC->field_460 = a0;
+ LZ77UnCompWram(gUnknown_83F18D8, gUnknown_20399EC->field_000);
+ LZ77UnCompWram(gUnknown_83F1908, gUnknown_20399EC->field_040);
+ gTasks[taskId].func = sub_80C440C;
+}
+
+void sub_80C440C(u8 taskId)
+{
+ switch (gUnknown_20399EC->field_463)
+ {
+ case 0:
+ sub_80C08E0();
+ gUnknown_20399EC->field_463++;
+ break;
+ case 1:
+ sub_80C47F0();
+ gUnknown_20399EC->field_463++;
+ break;
+ case 2:
+ sub_80C4750();
+ gUnknown_20399EC->field_463++;
+ break;
+ case 3:
+ BlendPalettes(0xFFFFFFFF, 16, RGB_BLACK);
+ BeginNormalPaletteFade(0xFFFFFFFF, 0, 16, 0, RGB_BLACK);
+ gUnknown_20399EC->field_463++;
+ break;
+ case 4:
+ sub_80C08F4();
+ gUnknown_20399EC->field_463++;
+ break;
+ default:
+ SetGpuReg(REG_OFFSET_DISPCNT, GetGpuReg(REG_OFFSET_DISPCNT) | DISPCNT_OBJ_ON);
+ sub_80C44E4(taskId);
+ break;
+ }
+}
+
+void sub_80C44E4(u8 taskId)
+{
+ gTasks[taskId].func = gUnknown_20399EC->field_468;
+}
+
+void sub_80C450C(u8 a0, u8 a1, u16 a2, u16 a3, u8 a4, u8 a5)
+{
+ u8 spriteId;
+ struct SpriteSheet spriteSheet = {
+ .data = gUnknown_20399EC->field_040,
+ .size = 0x100,
+ .tag = a4
+ };
+ struct SpritePalette spritePalette = {
+ .data = gUnknown_83EF2BC,
+ .tag = a5
+ };
+ struct SpriteTemplate template = {
+ .tileTag = a4,
+ .paletteTag = a5,
+ .oam = &gUnknown_83F1C68,
+ .anims = gUnknown_83F1C94,
+ .images = NULL,
+ .affineAnims = gDummySpriteAffineAnimTable,
+ .callback = SpriteCallbackDummy
+ };
+
+ LoadSpriteSheet(&spriteSheet);
+ LoadSpritePalette(&spritePalette);
+ spriteId = CreateSprite(&template, 8 * a2 + 36, 8 * a3 + 36, 1);
+ gUnknown_20399EC->field_2D4[a1].field_4 = &gSprites[spriteId];
+ gSprites[spriteId].invisible = TRUE;
+ gUnknown_20399EC->field_2D4[a1].field_0 = a0;
+}
+
+void sub_80C4614(u8 a0, u8 a1, u16 a2, u16 a3, u8 a4, u8 a5)
+{
+ u8 spriteId;
+ u8 r4;
+ s16 r7 = 0;
+ struct SpriteSheet spriteSheet = {
+ .data = gUnknown_20399EC->field_000,
+ .size = 0x40,
+ .tag = a4
+ };
+ struct SpritePalette spritePalette = {
+ .data = gUnknown_83EF2BC,
+ .tag = a5
+ };
+ struct SpriteTemplate template = {
+ .tileTag = a4,
+ .paletteTag = a5,
+ .oam = &gUnknown_83F1C70,
+ .anims = gUnknown_83F1C98,
+ .images = NULL,
+ .affineAnims = gDummySpriteAffineAnimTable,
+ .callback = SpriteCallbackDummy
+ };
+
+ LoadSpriteSheet(&spriteSheet);
+ LoadSpritePalette(&spritePalette);
+ r4 = sub_80C4164(a0, 0, a3, a2);
+ if ((sub_80C35DC(r4) == 2 || sub_80C35DC(r4) == 3) && r4 != MAPSEC_ROUTE_10_FLYDUP)
+ r7 = 2;
+ spriteId = CreateSprite(&template, 8 * a2 + 36 + r7, 8 * a3 + 36 + r7, 3);
+ gUnknown_20399EC->field_144[a1].field_4 = &gSprites[spriteId];
+ gSprites[spriteId].invisible = TRUE;
+ gUnknown_20399EC->field_144[a1].field_0 = a0;
+}
+
+void sub_80C4750(void)
+{
+ u16 i, j, k;
+ u8 r7 = 0;
+ if (sub_80C0E04(3))
+ {
+ for (i = 0; i < 4; i++)
+ {
+ for (j = 0; j < 15; j++)
+ {
+ for (k = 0; k < 22; k++)
+ {
+ if (sub_80C35DC(sub_80C4164(i, 0, j, k)) == 2)
+ {
+ sub_80C450C(i, r7, k, j, r7 + 10, 10);
+ r7++;
+ }
+ }
+ }
+ }
+ }
+}
+
+void sub_80C47F0(void)
+{
+ u16 i, j, k;
+ u8 r6 = 0;
+ u8 mapsec;
+ for (i = 0; i < 4; i++)
+ {
+ for (j = 0; j < 15; j++)
+ {
+ for (k = 0; k < 22; k++)
+ {
+ mapsec = sub_80C4164(i, 1, j, k);
+ if (mapsec == MAPSEC_NONE)
+ continue;
+ if (mapsec == MAPSEC_CERULEAN_CAVE && !FlagGet(FLAG_SYS_CAN_LINK_WITH_RS))
+ continue;
+ sub_80C4614(i, r6, k, j, r6 + 35, 10);
+ if (sub_80C3878(mapsec) != 2)
+ {
+ StartSpriteAnim(gUnknown_20399EC->field_144[r6].field_4, 1);
+ }
+ r6++;
+ }
+ }
+ }
+}