sub_8123EB4

This commit is contained in:
PikalaxALT 2017-10-30 21:34:19 -04:00
parent f0c71c7e3f
commit 7b6792230a
4 changed files with 66 additions and 88 deletions

View File

@ -5,66 +5,6 @@
.text .text
thumb_func_start sub_8123E9C
sub_8123E9C: @ 8123E9C
push {lr}
lsls r0, 16
lsrs r0, 16
lsls r1, 16
lsrs r1, 16
bl GetRegionMapSectionIdAt
lsls r0, 16
lsrs r0, 16
pop {r1}
bx r1
thumb_func_end sub_8123E9C
thumb_func_start sub_8123EB4
sub_8123EB4: @ 8123EB4
push {lr}
lsls r0, 16
lsrs r3, r0, 16
movs r2, 0
ldr r1, =gUnknown_085A1B84
_08123EBE:
ldrh r0, [r1]
cmp r0, r3
bne _08123ED4
bl sub_8123F04
lsls r0, 16
lsrs r0, 16
b _08123F00
.pool
_08123ED4:
adds r1, 0x2
adds r2, 0x1
cmp r2, 0x2
bls _08123EBE
ldr r1, =gUnknown_085A1B24
ldrh r0, [r1]
cmp r0, 0xD5
beq _08123EFE
adds r2, r1, 0
_08123EE6:
ldrh r0, [r2]
cmp r0, r3
bne _08123EF4
ldrh r0, [r1, 0x2]
b _08123F00
.pool
_08123EF4:
adds r1, 0x4
adds r2, 0x4
ldrh r0, [r1]
cmp r0, 0xD5
bne _08123EE6
_08123EFE:
adds r0, r3, 0
_08123F00:
pop {r1}
bx r1
thumb_func_end sub_8123EB4
thumb_func_start sub_8123F04 thumb_func_start sub_8123F04
sub_8123F04: @ 8123F04 sub_8123F04: @ 8123F04
push {lr} push {lr}

View File

@ -224,7 +224,7 @@ enum {
struct RegionMap { struct RegionMap {
/*0x000*/ u16 mapSecId; /*0x000*/ u16 mapSecId;
/*0x002*/ u8 unk_002; /*0x002*/ u8 iconDrawType;
/*0x003*/ u8 unk_003; /*0x003*/ u8 unk_003;
/*0x004*/ u8 mapSecName[0x14]; /*0x004*/ u8 mapSecName[0x14];
/*0x018*/ u8 (*inputCallback)(void); /*0x018*/ u8 (*inputCallback)(void);
@ -287,16 +287,25 @@ enum
INPUT_EVENT_B_BUTTON, INPUT_EVENT_B_BUTTON,
}; };
enum {
MAPSECTYPE_NONE,
MAPSECTYPE_PLAIN,
MAPSECTYPE_CITY_CANFLY,
MAPSECTYPE_CITY_CANTFLY,
MAPSECTYPE_BATTLE_FRONTIER
};
// Exported RAM declarations // Exported RAM declarations
// Exported ROM declarations // Exported ROM declarations
void sub_8122CF8(struct RegionMap *regionMap, struct BgTemplate *template, bool8 zoomed); void sub_8122CF8(struct RegionMap *regionMap, struct BgTemplate *template, bool8 zoomed);
bool8 sub_8122DB0(void); bool8 sub_8122DB0(void);
void GetMapName(u8 *, u16, u16);
void InitRegionMap(struct RegionMap *regionMap, u8 argument); void InitRegionMap(struct RegionMap *regionMap, u8 argument);
void sub_8124288(u16 x, u16 y);
void CreateRegionMapCursor(u16 x, u16 y);
u8 sub_81230AC(void); u8 sub_81230AC(void);
void FreeRegionMapIconResources(void); void FreeRegionMapIconResources(void);
u16 sub_8123E9C(u16 x, u16 y);
void GetMapName(u8 *, u16, u16);
void sub_8124288(u16 x, u16 y);
void CreateRegionMapCursor(u16 x, u16 y);
#endif //GUARD_REGION_MAP_H #endif //GUARD_REGION_MAP_H

View File

@ -181,7 +181,7 @@ void sub_8170290(void)
static void sub_8170428(void) static void sub_8170428(void)
{ {
if (gUnknown_0203BCD0->regionMap.unk_002 != 0) if (gUnknown_0203BCD0->regionMap.iconDrawType != 0)
{ {
FillWindowPixelBuffer(0, 0x11); FillWindowPixelBuffer(0, 0x11);
PrintTextOnWindow(0, 1, gUnknown_0203BCD0->regionMap.mapSecName, 0, 1, 0, NULL); PrintTextOnWindow(0, 1, gUnknown_0203BCD0->regionMap.mapSecName, 0, 1, 0, NULL);

View File

@ -52,6 +52,7 @@ static void sub_81238AC(void);
static void sub_8123C00(void); static void sub_8123C00(void);
static u8 get_flagnr_blue_points(u16 mapSecId); static u8 get_flagnr_blue_points(u16 mapSecId);
u16 sub_8123EB4(u16 mapSecId); u16 sub_8123EB4(u16 mapSecId);
u16 sub_8123F04(void);
void sub_8123F30(u16 *x, u16 *y); void sub_8123F30(u16 *x, u16 *y);
void sub_8123FB0(void); void sub_8123FB0(void);
bool32 sub_8123F74(u8 mapSecId); bool32 sub_8123F74(u8 mapSecId);
@ -68,6 +69,8 @@ extern const u8 gUnknown_0859F77C[];
extern const u8 gUnknown_085A04E0[]; extern const u8 gUnknown_085A04E0[];
extern const u8 gUnknown_085A096C[]; extern const u8 gUnknown_085A096C[];
extern const struct RegionMapLocation gRegionMapEntries[]; extern const struct RegionMapLocation gRegionMapEntries[];
extern const u16 gUnknown_085A1B84[];
extern const u16 gUnknown_085A1B24[][2];
// .text // .text
@ -151,7 +154,7 @@ bool8 sub_8122DB0(void)
gRegionMap->unk_074 = gRegionMap->cursorPosX; gRegionMap->unk_074 = gRegionMap->cursorPosX;
gRegionMap->unk_076 = gRegionMap->cursorPosY; gRegionMap->unk_076 = gRegionMap->cursorPosY;
gRegionMap->mapSecId = sub_8123EB4(gRegionMap->mapSecId); gRegionMap->mapSecId = sub_8123EB4(gRegionMap->mapSecId);
gRegionMap->unk_002 = get_flagnr_blue_points(gRegionMap->mapSecId); gRegionMap->iconDrawType = get_flagnr_blue_points(gRegionMap->mapSecId);
GetMapName(gRegionMap->mapSecName, gRegionMap->mapSecId, 16); GetMapName(gRegionMap->mapSecName, gRegionMap->mapSecId, 16);
break; break;
case 6: case 6:
@ -287,7 +290,7 @@ static u8 MoveRegionMapCursor_Full(void)
gRegionMap->cursorPosY --; gRegionMap->cursorPosY --;
} }
mapSecId = GetRegionMapSectionIdAt(gRegionMap->cursorPosX, gRegionMap->cursorPosY); mapSecId = GetRegionMapSectionIdAt(gRegionMap->cursorPosX, gRegionMap->cursorPosY);
gRegionMap->unk_002 = get_flagnr_blue_points(mapSecId); gRegionMap->iconDrawType = get_flagnr_blue_points(mapSecId);
if (mapSecId != gRegionMap->mapSecId) if (mapSecId != gRegionMap->mapSecId)
{ {
gRegionMap->mapSecId = mapSecId; gRegionMap->mapSecId = mapSecId;
@ -360,7 +363,7 @@ static u8 MoveRegionMapCursor_Zoomed(void)
gRegionMap->unk_064 = x; gRegionMap->unk_064 = x;
gRegionMap->unk_066 = y; gRegionMap->unk_066 = y;
mapSecId = GetRegionMapSectionIdAt(x, y); mapSecId = GetRegionMapSectionIdAt(x, y);
gRegionMap->unk_002 = get_flagnr_blue_points(mapSecId); gRegionMap->iconDrawType = get_flagnr_blue_points(mapSecId);
if (mapSecId != gRegionMap->mapSecId) if (mapSecId != gRegionMap->mapSecId)
{ {
gRegionMap->mapSecId = mapSecId; gRegionMap->mapSecId = mapSecId;
@ -771,44 +774,70 @@ static u8 get_flagnr_blue_points(u16 mapSecId)
switch (mapSecId) switch (mapSecId)
{ {
case MAPSEC_NONE2: case MAPSEC_NONE2:
return 0; return MAPSECTYPE_NONE;
case MAPSEC_LITTLEROOT_TOWN: case MAPSEC_LITTLEROOT_TOWN:
return FlagGet(FLAG_VISITED_LITTLEROOT_TOWN) ? 2 : 3; return FlagGet(FLAG_VISITED_LITTLEROOT_TOWN) ? MAPSECTYPE_CITY_CANFLY : MAPSECTYPE_CITY_CANTFLY;
case MAPSEC_OLDALE_TOWN: case MAPSEC_OLDALE_TOWN:
return FlagGet(FLAG_VISITED_OLDALE_TOWN) ? 2 : 3; return FlagGet(FLAG_VISITED_OLDALE_TOWN) ? MAPSECTYPE_CITY_CANFLY : MAPSECTYPE_CITY_CANTFLY;
case MAPSEC_DEWFORD_TOWN: case MAPSEC_DEWFORD_TOWN:
return FlagGet(FLAG_VISITED_DEWFORD_TOWN) ? 2 : 3; return FlagGet(FLAG_VISITED_DEWFORD_TOWN) ? MAPSECTYPE_CITY_CANFLY : MAPSECTYPE_CITY_CANTFLY;
case MAPSEC_LAVARIDGE_TOWN: case MAPSEC_LAVARIDGE_TOWN:
return FlagGet(FLAG_VISITED_LAVARIDGE_TOWN) ? 2 : 3; return FlagGet(FLAG_VISITED_LAVARIDGE_TOWN) ? MAPSECTYPE_CITY_CANFLY : MAPSECTYPE_CITY_CANTFLY;
case MAPSEC_FALLARBOR_TOWN: case MAPSEC_FALLARBOR_TOWN:
return FlagGet(FLAG_VISITED_FALLARBOR_TOWN) ? 2 : 3; return FlagGet(FLAG_VISITED_FALLARBOR_TOWN) ? MAPSECTYPE_CITY_CANFLY : MAPSECTYPE_CITY_CANTFLY;
case MAPSEC_VERDANTURF_TOWN: case MAPSEC_VERDANTURF_TOWN:
return FlagGet(FLAG_VISITED_VERDANTURF_TOWN) ? 2 : 3; return FlagGet(FLAG_VISITED_VERDANTURF_TOWN) ? MAPSECTYPE_CITY_CANFLY : MAPSECTYPE_CITY_CANTFLY;
case MAPSEC_PACIFIDLOG_TOWN: case MAPSEC_PACIFIDLOG_TOWN:
return FlagGet(FLAG_VISITED_PACIFIDLOG_TOWN) ? 2 : 3; return FlagGet(FLAG_VISITED_PACIFIDLOG_TOWN) ? MAPSECTYPE_CITY_CANFLY : MAPSECTYPE_CITY_CANTFLY;
case MAPSEC_PETALBURG_CITY: case MAPSEC_PETALBURG_CITY:
return FlagGet(FLAG_VISITED_PETALBURG_CITY) ? 2 : 3; return FlagGet(FLAG_VISITED_PETALBURG_CITY) ? MAPSECTYPE_CITY_CANFLY : MAPSECTYPE_CITY_CANTFLY;
case MAPSEC_SLATEPORT_CITY: case MAPSEC_SLATEPORT_CITY:
return FlagGet(FLAG_VISITED_SLATEPORT_CITY) ? 2 : 3; return FlagGet(FLAG_VISITED_SLATEPORT_CITY) ? MAPSECTYPE_CITY_CANFLY : MAPSECTYPE_CITY_CANTFLY;
case MAPSEC_MAUVILLE_CITY: case MAPSEC_MAUVILLE_CITY:
return FlagGet(FLAG_VISITED_MAUVILLE_CITY) ? 2 : 3; return FlagGet(FLAG_VISITED_MAUVILLE_CITY) ? MAPSECTYPE_CITY_CANFLY : MAPSECTYPE_CITY_CANTFLY;
case MAPSEC_RUSTBORO_CITY: case MAPSEC_RUSTBORO_CITY:
return FlagGet(FLAG_VISITED_RUSTBORO_CITY) ? 2 : 3; return FlagGet(FLAG_VISITED_RUSTBORO_CITY) ? MAPSECTYPE_CITY_CANFLY : MAPSECTYPE_CITY_CANTFLY;
case MAPSEC_FORTREE_CITY: case MAPSEC_FORTREE_CITY:
return FlagGet(FLAG_VISITED_FORTREE_CITY) ? 2 : 3; return FlagGet(FLAG_VISITED_FORTREE_CITY) ? MAPSECTYPE_CITY_CANFLY : MAPSECTYPE_CITY_CANTFLY;
case MAPSEC_LILYCOVE_CITY: case MAPSEC_LILYCOVE_CITY:
return FlagGet(FLAG_VISITED_LILYCOVE_CITY) ? 2 : 3; return FlagGet(FLAG_VISITED_LILYCOVE_CITY) ? MAPSECTYPE_CITY_CANFLY : MAPSECTYPE_CITY_CANTFLY;
case MAPSEC_MOSSDEEP_CITY: case MAPSEC_MOSSDEEP_CITY:
return FlagGet(FLAG_VISITED_MOSSDEEP_CITY) ? 2 : 3; return FlagGet(FLAG_VISITED_MOSSDEEP_CITY) ? MAPSECTYPE_CITY_CANFLY : MAPSECTYPE_CITY_CANTFLY;
case MAPSEC_SOOTOPOLIS_CITY: case MAPSEC_SOOTOPOLIS_CITY:
return FlagGet(FLAG_VISITED_SOOTOPOLIS_CITY) ? 2 : 3; return FlagGet(FLAG_VISITED_SOOTOPOLIS_CITY) ? MAPSECTYPE_CITY_CANFLY : MAPSECTYPE_CITY_CANTFLY;
case MAPSEC_EVER_GRANDE_CITY: case MAPSEC_EVER_GRANDE_CITY:
return FlagGet(FLAG_VISITED_EVER_GRANDE_CITY) ? 2 : 3; return FlagGet(FLAG_VISITED_EVER_GRANDE_CITY) ? MAPSECTYPE_CITY_CANFLY : MAPSECTYPE_CITY_CANTFLY;
case MAPSEC_BATTLE_FRONTIER: case MAPSEC_BATTLE_FRONTIER:
return FlagGet(FLAG_UNLOCK_BATTLE_FRONTIER) ? 4 : 0; return FlagGet(FLAG_UNLOCK_BATTLE_FRONTIER) ? MAPSECTYPE_BATTLE_FRONTIER : MAPSECTYPE_NONE;
case MAPSEC_SOUTHERN_ISLAND: case MAPSEC_SOUTHERN_ISLAND:
return FlagGet(FLAG_UNLOCK_SOUTHERN_ISLAND) ? 1 : 0; return FlagGet(FLAG_UNLOCK_SOUTHERN_ISLAND) ? MAPSECTYPE_PLAIN : MAPSECTYPE_NONE;
default: default:
return 1; return MAPSECTYPE_PLAIN;
} }
} }
u16 sub_8123E9C(u16 x, u16 y)
{
return GetRegionMapSectionIdAt(x, y);
}
u16 sub_8123EB4(u16 mapSecId)
{
u32 i;
for (i = 0; i < 3; i ++)
{
if (gUnknown_085A1B84[i] == mapSecId)
{
return sub_8123F04();
}
}
for (i = 0; gUnknown_085A1B24[i][0] != MAPSEC_NONE2; i ++)
{
if (gUnknown_085A1B24[i][0] == mapSecId)
{
return gUnknown_085A1B24[i][1];
}
}
return mapSecId;
}