mirror of
https://github.com/Ninjdai1/pokeemerald.git
synced 2024-12-27 04:04:17 +01:00
sub_8123EB4
This commit is contained in:
parent
f0c71c7e3f
commit
7b6792230a
@ -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}
|
||||||
|
@ -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
|
||||||
|
@ -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);
|
||||||
|
@ -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;
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user