Decompile all frontier pass
This commit is contained in:
parent
0688725afb
commit
03549349f8
3 changed files with 607 additions and 17 deletions
|
@ -25,6 +25,7 @@
|
|||
#include "overworld.h"
|
||||
#include "math_util.h"
|
||||
#include "constants/battle_frontier.h"
|
||||
#include "constants/maps.h"
|
||||
#include "constants/rgb.h"
|
||||
#include "constants/region_map_sections.h"
|
||||
#include "constants/songs.h"
|
||||
|
@ -117,12 +118,11 @@ extern const struct WindowTemplate gUnknown_08571400[];
|
|||
extern const u32 gUnknown_085712F8[];
|
||||
extern const u32 gUnknown_085712C0[];
|
||||
extern const u32 gUnknown_08571060[];
|
||||
extern const u8 gUnknown_08571448[];
|
||||
extern const u8 gUnknown_0857144B[];
|
||||
extern const u8 gUnknown_08571448[][3];
|
||||
extern const u8 *const gUnknown_08571614[];
|
||||
extern const struct SpritePalette gUnknown_085714E4[];
|
||||
extern const struct CompressedSpriteSheet gUnknown_085714BC[];
|
||||
extern const struct SpriteTemplate gUnknown_085715B4;
|
||||
extern const struct SpriteTemplate gUnknown_085715B4[2];
|
||||
extern const struct SpriteTemplate gUnknown_085715E4;
|
||||
|
||||
// code
|
||||
|
@ -712,15 +712,15 @@ void ShowAndPrintWindows(void)
|
|||
}
|
||||
|
||||
x = GetStringCenterAlignXOffset(1, gText_SymbolsEarned, 0x60);
|
||||
AddTextPrinterParameterized3(WINDOW_EARNED_SYMBOLS, 1, x, 5, gUnknown_08571448, 0, gText_SymbolsEarned);
|
||||
AddTextPrinterParameterized3(WINDOW_EARNED_SYMBOLS, 1, x, 5, gUnknown_08571448[0], 0, gText_SymbolsEarned);
|
||||
|
||||
x = GetStringCenterAlignXOffset(1, gText_BattleRecord, 0x60);
|
||||
AddTextPrinterParameterized3(WINDOW_BATTLE_RECORD, 1, x, 5, gUnknown_08571448, 0, gText_BattleRecord);
|
||||
AddTextPrinterParameterized3(WINDOW_BATTLE_RECORD, 1, x, 5, gUnknown_08571448[0], 0, gText_BattleRecord);
|
||||
|
||||
AddTextPrinterParameterized3(WINDOW_BATTLE_POINTS, 8, 5, 4, gUnknown_08571448, 0, gText_BattlePoints);
|
||||
AddTextPrinterParameterized3(WINDOW_BATTLE_POINTS, 8, 5, 4, gUnknown_08571448[0], 0, gText_BattlePoints);
|
||||
ConvertIntToDecimalStringN(gStringVar4, gUnknown_02039CEC->battlePoints, STR_CONV_MODE_LEFT_ALIGN, 5);
|
||||
x = GetStringRightAlignXOffset(8, gStringVar4, 0x5B);
|
||||
AddTextPrinterParameterized3(WINDOW_BATTLE_POINTS, 8, x, 16, gUnknown_08571448, 0, gStringVar4);
|
||||
AddTextPrinterParameterized3(WINDOW_BATTLE_POINTS, 8, x, 16, gUnknown_08571448[0], 0, gStringVar4);
|
||||
|
||||
gUnknown_02039CEC->cursorArea = GetCursorAreaFromCoords(gUnknown_02039CEC->cursorX - 5, gUnknown_02039CEC->cursorY + 5);
|
||||
gUnknown_02039CEC->previousCursorArea = CURSOR_AREA_NOTHING;
|
||||
|
@ -736,9 +736,9 @@ void PrintAreaDescription(u8 cursorArea)
|
|||
{
|
||||
FillWindowPixelBuffer(WINDOW_DESCRIPTION, 0);
|
||||
if (cursorArea == CURSOR_AREA_RECORD && !gUnknown_02039CEC->hasBattleRecord)
|
||||
AddTextPrinterParameterized3(WINDOW_DESCRIPTION, 1, 2, 0, gUnknown_0857144B, 0, gUnknown_08571614[0]);
|
||||
AddTextPrinterParameterized3(WINDOW_DESCRIPTION, 1, 2, 0, gUnknown_08571448[1], 0, gUnknown_08571614[0]);
|
||||
else if (cursorArea != CURSOR_AREA_NOTHING)
|
||||
AddTextPrinterParameterized3(WINDOW_DESCRIPTION, 1, 2, 0, gUnknown_0857144B, 0, gUnknown_08571614[cursorArea]);
|
||||
AddTextPrinterParameterized3(WINDOW_DESCRIPTION, 1, 2, 0, gUnknown_08571448[1], 0, gUnknown_08571614[cursorArea]);
|
||||
|
||||
CopyWindowToVram(WINDOW_DESCRIPTION, 3);
|
||||
CopyBgTilemapBufferToVram(0);
|
||||
|
@ -884,7 +884,7 @@ void LoadCursorAndSymbolSprites(void)
|
|||
LoadSpritePalettes(gUnknown_085714E4);
|
||||
LoadCompressedSpriteSheet(&gUnknown_085714BC[0]);
|
||||
LoadCompressedSpriteSheet(&gUnknown_085714BC[2]);
|
||||
spriteId = CreateSprite(&gUnknown_085715B4, gUnknown_02039CEC->cursorX, gUnknown_02039CEC->cursorY, 0);
|
||||
spriteId = CreateSprite(&gUnknown_085715B4[0], gUnknown_02039CEC->cursorX, gUnknown_02039CEC->cursorY, 0);
|
||||
gUnknown_02039CF0->cursorSprite = &gSprites[spriteId];
|
||||
gUnknown_02039CF0->cursorSprite->oam.priority = 0;
|
||||
|
||||
|
@ -928,9 +928,440 @@ void nullsub_39(void)
|
|||
}
|
||||
|
||||
// Frontier Map code.
|
||||
/*
|
||||
void ShowFrontierMap(void (*callback)(void));
|
||||
{
|
||||
|
||||
struct FrontierMapData
|
||||
{
|
||||
void (*callback)(void);
|
||||
struct Sprite *cursorSprite;
|
||||
struct Sprite *playerHeadSprite;
|
||||
struct Sprite *mapIndicatorSprite;
|
||||
u8 cursorPos;
|
||||
u8 unk11;
|
||||
u8 tilemapBuff0[0x1000];
|
||||
u8 tilemapBuff1[0x1000];
|
||||
u8 tilemapBuff2[0x1000];
|
||||
};
|
||||
|
||||
extern struct FrontierMapData *gUnknown_02039CF4;
|
||||
|
||||
// Forward declarations.
|
||||
void sub_80C67BC(u8 taskId);
|
||||
void sub_80C6B94(void);
|
||||
void sub_80C6974(void);
|
||||
void sub_80C6C70(u8 direction);
|
||||
|
||||
extern const struct BgTemplate gUnknown_085713F4[3];
|
||||
extern const struct WindowTemplate gUnknown_08571428[];
|
||||
extern const u32 gUnknown_0856FBBC[];
|
||||
extern const u32 gUnknown_08570E00[];
|
||||
|
||||
void ShowFrontierMap(void (*callback)(void))
|
||||
{
|
||||
if (gUnknown_02039CF4 != NULL)
|
||||
SetMainCallback2(callback); // This line doesn't make sense at all, since it gets overwritten later anyway.
|
||||
|
||||
gUnknown_02039CF4 = AllocZeroed(sizeof(*gUnknown_02039CF4));
|
||||
gUnknown_02039CF4->callback = callback;
|
||||
ResetTasks();
|
||||
CreateTask(sub_80C67BC, 0);
|
||||
SetMainCallback2(CB2_FrontierPass);
|
||||
}
|
||||
|
||||
void sub_80C6498(void)
|
||||
{
|
||||
ResetTasks();
|
||||
SetMainCallback2(gUnknown_02039CF4->callback);
|
||||
memset(gUnknown_02039CF4, 0, sizeof(*gUnknown_02039CF4)); // Pointless memory clear.
|
||||
FREE_AND_SET_NULL(gUnknown_02039CF4);
|
||||
}
|
||||
|
||||
bool32 sub_80C64CC(void)
|
||||
{
|
||||
switch (gUnknown_02039CEC->state)
|
||||
{
|
||||
case 0:
|
||||
SetVBlankCallback(NULL);
|
||||
ScanlineEffect_Stop();
|
||||
SetVBlankHBlankCallbacksToNull();
|
||||
break;
|
||||
case 1:
|
||||
sub_80C50D0();
|
||||
break;
|
||||
case 2:
|
||||
ResetSpriteData();
|
||||
FreeAllSpritePalettes();
|
||||
ResetPaletteFade();
|
||||
reset_temp_tile_data_buffers();
|
||||
break;
|
||||
case 3:
|
||||
ResetBgsAndClearDma3BusyFlags(0);
|
||||
InitBgsFromTemplates(0, gUnknown_085713F4, ARRAY_COUNT(gUnknown_085713F4));
|
||||
SetBgTilemapBuffer(0, gUnknown_02039CF4->tilemapBuff0);
|
||||
SetBgTilemapBuffer(1, gUnknown_02039CF4->tilemapBuff1);
|
||||
SetBgTilemapBuffer(2, gUnknown_02039CF4->tilemapBuff2);
|
||||
FillBgTilemapBufferRect_Palette0(0, 0, 0, 0, 30, 20);
|
||||
FillBgTilemapBufferRect_Palette0(1, 0, 0, 0, 30, 20);
|
||||
FillBgTilemapBufferRect_Palette0(2, 0, 0, 0, 30, 20);
|
||||
CopyBgTilemapBufferToVram(0);
|
||||
CopyBgTilemapBufferToVram(1);
|
||||
CopyBgTilemapBufferToVram(2);
|
||||
break;
|
||||
case 4:
|
||||
InitWindows(gUnknown_08571428);
|
||||
DeactivateAllTextPrinters();
|
||||
sub_80C6B94();
|
||||
decompress_and_copy_tile_data_to_vram(1, gUnknown_0856FBBC, 0, 0, 0);
|
||||
break;
|
||||
case 5:
|
||||
if (free_temp_tile_data_buffers_if_possible())
|
||||
return FALSE;
|
||||
LoadPalette(gUnknown_08DE07C8[0], 0, 0x1A0);
|
||||
LoadPalette(stdpal_get(0), 0xF0, 0x20);
|
||||
CopyToBgTilemapBuffer(2, gUnknown_08570E00, 0, 0);
|
||||
CopyBgTilemapBufferToVram(2);
|
||||
break;
|
||||
case 6:
|
||||
SetGpuReg(REG_OFFSET_DISPCNT, DISPCNT_OBJ_ON | DISPCNT_OBJ_1D_MAP);
|
||||
ShowBg(0);
|
||||
ShowBg(1);
|
||||
ShowBg(2);
|
||||
sub_80C6974();
|
||||
SetVBlankCallback(VblankCb_FrontierPass);
|
||||
BlendPalettes(0xFFFFFFFF, 0x10, RGB_WHITE);
|
||||
BeginNormalPaletteFade(0xFFFFFFFF, 0, 0x10, 0, RGB_WHITE);
|
||||
break;
|
||||
case 7:
|
||||
if (UpdatePaletteFade())
|
||||
return FALSE;
|
||||
gUnknown_02039CEC->state = 0;
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
gUnknown_02039CEC->state++;
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
bool32 sub_80C66AC(void)
|
||||
{
|
||||
switch (gUnknown_02039CEC->state)
|
||||
{
|
||||
case 0:
|
||||
BeginNormalPaletteFade(0xFFFFFFFF, 0, 0, 0x10, RGB_WHITE);
|
||||
break;
|
||||
case 1:
|
||||
if (UpdatePaletteFade())
|
||||
return FALSE;
|
||||
SetGpuReg(REG_OFFSET_DISPCNT, 0);
|
||||
HideBg(0);
|
||||
HideBg(1);
|
||||
HideBg(2);
|
||||
break;
|
||||
case 2:
|
||||
SetVBlankCallback(NULL);
|
||||
ScanlineEffect_Stop();
|
||||
SetVBlankHBlankCallbacksToNull();
|
||||
break;
|
||||
case 3:
|
||||
if (gUnknown_02039CF4->cursorSprite != NULL)
|
||||
{
|
||||
DestroySprite(gUnknown_02039CF4->cursorSprite);
|
||||
FreeSpriteTilesByTag(0);
|
||||
}
|
||||
if (gUnknown_02039CF4->mapIndicatorSprite != NULL)
|
||||
{
|
||||
DestroySprite(gUnknown_02039CF4->mapIndicatorSprite);
|
||||
FreeSpriteTilesByTag(1);
|
||||
}
|
||||
if (gUnknown_02039CF4->playerHeadSprite != NULL)
|
||||
{
|
||||
DestroySprite(gUnknown_02039CF4->playerHeadSprite);
|
||||
FreeSpriteTilesByTag(4);
|
||||
}
|
||||
FreeAllWindowBuffers();
|
||||
break;
|
||||
case 4:
|
||||
sub_80C50D0();
|
||||
ResetSpriteData();
|
||||
FreeAllSpritePalettes();
|
||||
break;
|
||||
case 5:
|
||||
UnsetBgTilemapBuffer(0);
|
||||
UnsetBgTilemapBuffer(1);
|
||||
UnsetBgTilemapBuffer(2);
|
||||
gUnknown_02039CEC->state = 0;
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
gUnknown_02039CEC->state++;
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
void sub_80C67BC(u8 taskId)
|
||||
{
|
||||
s16 *data = gTasks[taskId].data;
|
||||
|
||||
switch (data[0])
|
||||
{
|
||||
case 0:
|
||||
if (sub_80C64CC())
|
||||
break;
|
||||
return;
|
||||
case 1:
|
||||
if (gMain.newKeys & B_BUTTON)
|
||||
{
|
||||
PlaySE(SE_PC_OFF);
|
||||
data[0] = 4;
|
||||
}
|
||||
else if (gMain.newKeys & DPAD_DOWN)
|
||||
{
|
||||
if (gUnknown_02039CF4->cursorPos >= NUM_FRONTIER_FACILITIES - 1)
|
||||
sub_80C6C70(0);
|
||||
else
|
||||
data[0] = 2;
|
||||
}
|
||||
else if (gMain.newKeys & DPAD_UP)
|
||||
{
|
||||
if (gUnknown_02039CF4->cursorPos == 0)
|
||||
sub_80C6C70(1);
|
||||
else
|
||||
data[0] = 3;
|
||||
}
|
||||
return;
|
||||
case 2:
|
||||
if (data[1] > 3)
|
||||
{
|
||||
sub_80C6C70(0);
|
||||
data[1] = 0;
|
||||
data[0] = 1;
|
||||
}
|
||||
else
|
||||
{
|
||||
gUnknown_02039CF4->cursorSprite->pos1.y += 4;
|
||||
data[1]++;
|
||||
}
|
||||
return;
|
||||
case 3:
|
||||
if (data[1] > 3)
|
||||
{
|
||||
sub_80C6C70(1);
|
||||
data[1] = 0;
|
||||
data[0] = 1;
|
||||
}
|
||||
else
|
||||
{
|
||||
gUnknown_02039CF4->cursorSprite->pos1.y -= 4;
|
||||
data[1]++;
|
||||
}
|
||||
return;
|
||||
case 4:
|
||||
if (sub_80C66AC())
|
||||
break;
|
||||
return;
|
||||
case 5:
|
||||
DestroyTask(taskId);
|
||||
sub_80C6498();
|
||||
return;
|
||||
}
|
||||
|
||||
data[0]++;
|
||||
}
|
||||
|
||||
u8 sub_80C68E8(u16 mapNum) // id + 1, zero means not a frontier map number
|
||||
{
|
||||
if ((mapNum >= MAP_NUM(BATTLE_FRONTIER_BATTLE_TOWER_LOBBY) && mapNum <= MAP_NUM(BATTLE_FRONTIER_BATTLE_TOWER_BATTLE_ROOM))
|
||||
|| (mapNum >= MAP_NUM(BATTLE_FRONTIER_BATTLE_TOWER_MULTI_BATTLE_ROOM) && mapNum <= MAP_NUM(BATTLE_FRONTIER_BATTLE_TOWER_BATTLE_ROOM2)))
|
||||
return FRONTIER_FACILITY_TOWER + 1;
|
||||
else if (mapNum == MAP_NUM(BATTLE_FRONTIER_BATTLE_DOME_LOBBY)
|
||||
|| mapNum == MAP_NUM(BATTLE_FRONTIER_BATTLE_DOME_CORRIDOR)
|
||||
|| mapNum == MAP_NUM(BATTLE_FRONTIER_BATTLE_DOME_PRE_BATTLE_ROOM)
|
||||
|| mapNum == MAP_NUM(BATTLE_FRONTIER_BATTLE_DOME_BATTLE_ROOM))
|
||||
return FRONTIER_FACILITY_DOME + 1;
|
||||
else if (mapNum == MAP_NUM(BATTLE_FRONTIER_BATTLE_PALACE_LOBBY)
|
||||
|| mapNum == MAP_NUM(BATTLE_FRONTIER_BATTLE_PALACE_CORRIDOR)
|
||||
|| mapNum == MAP_NUM(BATTLE_FRONTIER_BATTLE_PALACE_BATTLE_ROOM))
|
||||
return FRONTIER_FACILITY_PALACE + 1;
|
||||
else if (mapNum == MAP_NUM(BATTLE_FRONTIER_BATTLE_ARENA_LOBBY)
|
||||
|| mapNum == MAP_NUM(BATTLE_FRONTIER_BATTLE_ARENA_CORRIDOR)
|
||||
|| mapNum == MAP_NUM(BATTLE_FRONTIER_BATTLE_ARENA_BATTLE_ROOM))
|
||||
return FRONTIER_FACILITY_ARENA + 1;
|
||||
else if (mapNum == MAP_NUM(BATTLE_FRONTIER_BATTLE_FACTORY_LOBBY)
|
||||
|| mapNum == MAP_NUM(BATTLE_FRONTIER_BATTLE_FACTORY_PRE_BATTLE_ROOM)
|
||||
|| mapNum == MAP_NUM(BATTLE_FRONTIER_BATTLE_FACTORY_BATTLE_ROOM))
|
||||
return FRONTIER_FACILITY_FACTORY + 1;
|
||||
else if (mapNum == MAP_NUM(BATTLE_FRONTIER_BATTLE_PIKE_LOBBY)
|
||||
|| mapNum == MAP_NUM(BATTLE_FRONTIER_BATTLE_PIKE_CORRIDOR)
|
||||
|| mapNum == MAP_NUM(BATTLE_FRONTIER_BATTLE_PIKE_THREE_PATH_ROOM)
|
||||
|| mapNum == MAP_NUM(BATTLE_FRONTIER_BATTLE_PIKE_RANDOM_ROOM1)
|
||||
|| mapNum == MAP_NUM(BATTLE_FRONTIER_BATTLE_PIKE_RANDOM_ROOM2)
|
||||
|| mapNum == MAP_NUM(BATTLE_FRONTIER_BATTLE_PIKE_RANDOM_ROOM3))
|
||||
return FRONTIER_FACILITY_PIKE + 1;
|
||||
else if (mapNum == MAP_NUM(BATTLE_FRONTIER_BATTLE_PYRAMID_LOBBY)
|
||||
|| mapNum == MAP_NUM(BATTLE_FRONTIER_BATTLE_PYRAMID_EMPTY_SQUARE)
|
||||
|| mapNum == MAP_NUM(BATTLE_FRONTIER_BATTLE_PYRAMID_TOP))
|
||||
return FRONTIER_FACILITY_PYRAMID + 1;
|
||||
else
|
||||
return 0;
|
||||
}
|
||||
|
||||
struct
|
||||
{
|
||||
const u8 *name;
|
||||
const u8 *description;
|
||||
s16 x;
|
||||
s16 y;
|
||||
u8 animNum;
|
||||
} extern const gUnknown_08571650[];
|
||||
|
||||
extern const struct CompressedSpriteSheet gUnknown_085714D4[];
|
||||
extern const struct SpriteTemplate gUnknown_085715FC;
|
||||
|
||||
void sub_80C6974(void)
|
||||
{
|
||||
struct SpriteTemplate sprite;
|
||||
u8 spriteId;
|
||||
u8 id;
|
||||
s16 x = 0, y;
|
||||
|
||||
FreeAllSpritePalettes();
|
||||
LoadSpritePalettes(gUnknown_085714E4);
|
||||
|
||||
LoadCompressedSpriteSheet(&gUnknown_085714BC[0]);
|
||||
spriteId = CreateSprite(&gUnknown_085715B4[0], 155, (gUnknown_02039CF4->cursorPos * 16) + 8, 2);
|
||||
gUnknown_02039CF4->cursorSprite = &gSprites[spriteId];
|
||||
gUnknown_02039CF4->cursorSprite->oam.priority = 0;
|
||||
gUnknown_02039CF4->cursorSprite->hFlip = TRUE;
|
||||
StartSpriteAnim(gUnknown_02039CF4->cursorSprite, 1);
|
||||
|
||||
LoadCompressedSpriteSheet(&gUnknown_085714BC[1]);
|
||||
spriteId = CreateSprite(&gUnknown_085715B4[1], gUnknown_08571650[gUnknown_02039CF4->cursorPos].x, gUnknown_08571650[gUnknown_02039CF4->cursorPos].y, 1);
|
||||
gUnknown_02039CF4->mapIndicatorSprite = &gSprites[spriteId];
|
||||
gUnknown_02039CF4->mapIndicatorSprite->oam.priority = 0;
|
||||
StartSpriteAnim(gUnknown_02039CF4->mapIndicatorSprite, gUnknown_08571650[gUnknown_02039CF4->cursorPos].animNum);
|
||||
|
||||
// Create player indicator head sprite only if it's in vicinity of battle frontier.
|
||||
id = GetCurrentRegionMapSectionId();
|
||||
if (id == MAPSEC_BATTLE_FRONTIER || id == MAPSEC_ARTISAN_CAVE)
|
||||
{
|
||||
s8 mapNum = gSaveBlock1Ptr->location.mapNum;
|
||||
|
||||
if (mapNum == MAP_NUM(BATTLE_FRONTIER_OUTSIDE_WEST)
|
||||
|| (mapNum == MAP_NUM(BATTLE_FRONTIER_OUTSIDE_EAST) && (x = 55)))
|
||||
{
|
||||
x += gSaveBlock1Ptr->pos.x;
|
||||
y = gSaveBlock1Ptr->pos.y;
|
||||
|
||||
x /= 8;
|
||||
y /= 8;
|
||||
|
||||
id = 0;
|
||||
}
|
||||
else
|
||||
{
|
||||
id = sub_80C68E8(mapNum);
|
||||
if (id != 0)
|
||||
{
|
||||
x = gUnknown_08571650[id - 1].x;
|
||||
y = gUnknown_08571650[id - 1].y;
|
||||
}
|
||||
else
|
||||
{
|
||||
// Handle Artisan Cave.
|
||||
if (gSaveBlock1Ptr->escapeWarp.mapNum == MAP_NUM(BATTLE_FRONTIER_OUTSIDE_EAST))
|
||||
x = gSaveBlock1Ptr->escapeWarp.x + 55;
|
||||
else
|
||||
x = gSaveBlock1Ptr->escapeWarp.x;
|
||||
|
||||
y = gSaveBlock1Ptr->escapeWarp.y;
|
||||
|
||||
x /= 8;
|
||||
y /= 8;
|
||||
}
|
||||
}
|
||||
|
||||
LoadCompressedSpriteSheet(gUnknown_085714D4);
|
||||
sprite = gUnknown_085715FC;
|
||||
sprite.paletteTag = gSaveBlock2Ptr->playerGender + 4;
|
||||
if (id != 0)
|
||||
{
|
||||
spriteId = CreateSprite(&sprite, x, y, 0);
|
||||
}
|
||||
else
|
||||
{
|
||||
x *= 8;
|
||||
y *= 8;
|
||||
spriteId = CreateSprite(&sprite, x + 20, y + 36, 0);
|
||||
}
|
||||
|
||||
gUnknown_02039CF4->playerHeadSprite = &gSprites[spriteId];
|
||||
gUnknown_02039CF4->playerHeadSprite->oam.priority = 0;
|
||||
if (gSaveBlock2Ptr->playerGender != MALE)
|
||||
StartSpriteAnim(gUnknown_02039CF4->playerHeadSprite, 1);
|
||||
}
|
||||
}
|
||||
|
||||
enum
|
||||
{
|
||||
MAP_WINDOW_0,
|
||||
MAP_WINDOW_NAME,
|
||||
MAP_WINDOW_DESCRIPTION,
|
||||
MAP_WINDOW_COUNT
|
||||
};
|
||||
|
||||
void sub_80C6B94(void)
|
||||
{
|
||||
u8 i;
|
||||
|
||||
for (i = 0; i < MAP_WINDOW_COUNT; i++)
|
||||
{
|
||||
PutWindowTilemap(i);
|
||||
FillWindowPixelBuffer(i, 0);
|
||||
}
|
||||
|
||||
for (i = 0; i < NUM_FRONTIER_FACILITIES; i++)
|
||||
{
|
||||
if (i == gUnknown_02039CF4->cursorPos)
|
||||
AddTextPrinterParameterized3(MAP_WINDOW_NAME, 7, 4, (i * 16) + 1, gUnknown_08571448[2], 0, gUnknown_08571650[i].name);
|
||||
else
|
||||
AddTextPrinterParameterized3(MAP_WINDOW_NAME, 7, 4, (i * 16) + 1, gUnknown_08571448[1], 0, gUnknown_08571650[i].name);
|
||||
}
|
||||
|
||||
AddTextPrinterParameterized3(MAP_WINDOW_DESCRIPTION, 1, 4, 0, gUnknown_08571448[0], 0, gUnknown_08571650[gUnknown_02039CF4->cursorPos].description);
|
||||
|
||||
for (i = 0; i < MAP_WINDOW_COUNT; i++)
|
||||
CopyWindowToVram(i, 3);
|
||||
|
||||
CopyBgTilemapBufferToVram(0);
|
||||
}
|
||||
|
||||
void sub_80C6C70(u8 direction)
|
||||
{
|
||||
u8 oldCursorPos, i;
|
||||
|
||||
if (direction)
|
||||
{
|
||||
oldCursorPos = gUnknown_02039CF4->cursorPos;
|
||||
gUnknown_02039CF4->cursorPos = (oldCursorPos + 6) % NUM_FRONTIER_FACILITIES;
|
||||
}
|
||||
else
|
||||
{
|
||||
oldCursorPos = gUnknown_02039CF4->cursorPos;
|
||||
gUnknown_02039CF4->cursorPos = (oldCursorPos + 1) % NUM_FRONTIER_FACILITIES;
|
||||
}
|
||||
|
||||
AddTextPrinterParameterized3(MAP_WINDOW_NAME, 7, 4, (oldCursorPos * 16) + 1, gUnknown_08571448[1], 0, gUnknown_08571650[oldCursorPos].name);
|
||||
AddTextPrinterParameterized3(MAP_WINDOW_NAME, 7, 4, (gUnknown_02039CF4->cursorPos * 16) + 1, gUnknown_08571448[2], 0, gUnknown_08571650[gUnknown_02039CF4->cursorPos].name);
|
||||
|
||||
gUnknown_02039CF4->cursorSprite->pos1.y = (gUnknown_02039CF4->cursorPos * 16) + 8;
|
||||
|
||||
StartSpriteAnim(gUnknown_02039CF4->mapIndicatorSprite, gUnknown_08571650[gUnknown_02039CF4->cursorPos].animNum);
|
||||
gUnknown_02039CF4->mapIndicatorSprite->pos1.x = gUnknown_08571650[gUnknown_02039CF4->cursorPos].x;
|
||||
gUnknown_02039CF4->mapIndicatorSprite->pos1.y = gUnknown_08571650[gUnknown_02039CF4->cursorPos].y;
|
||||
FillWindowPixelBuffer(MAP_WINDOW_DESCRIPTION, 0);
|
||||
AddTextPrinterParameterized3(MAP_WINDOW_DESCRIPTION, 1, 4, 0, gUnknown_08571448[0], 0, gUnknown_08571650[gUnknown_02039CF4->cursorPos].description);
|
||||
|
||||
for (i = 0; i < 3; i++)
|
||||
CopyWindowToVram(i, 3);
|
||||
|
||||
CopyBgTilemapBufferToVram(0);
|
||||
PlaySE(SE_Z_SCROLL);
|
||||
}
|
||||
*/
|
||||
|
|
|
@ -463,8 +463,6 @@ EWRAM_DATA static u8 sMovingMonOrigBoxId = 0;
|
|||
EWRAM_DATA static u8 sMovingMonOrigBoxPos = 0;
|
||||
EWRAM_DATA static bool8 sCanOnlyMove = 0;
|
||||
|
||||
extern void sub_80C6D80(u8 *arg0, void *arg1, u8 arg2, u8 arg3, s32 arg4);
|
||||
|
||||
extern const struct CompressedSpriteSheet gMonFrontPicTable[];
|
||||
|
||||
// This file's functions.
|
||||
|
@ -1543,6 +1541,168 @@ static const u8 gHandCursorTiles[] = INCBIN_U8("graphics/pokemon_storage/hand_cu
|
|||
static const u8 gHandCursorShadowTiles[] = INCBIN_U8("graphics/pokemon_storage/hand_cursor_shadow.4bpp");
|
||||
|
||||
// code
|
||||
void sub_80C6D80(u8 *string, void *dst, u8 arg2, u8 arg3, s32 arg4)
|
||||
{
|
||||
s32 i, val, val2;
|
||||
u16 windowId;
|
||||
u8 txtColor[3];
|
||||
u8 *tileData1, *tileData2;
|
||||
struct WindowTemplate winTemplate = {0};
|
||||
|
||||
winTemplate.width = 24;
|
||||
winTemplate.height = 2;
|
||||
windowId = AddWindow(&winTemplate);
|
||||
FillWindowPixelBuffer(windowId, (arg3 << 4) | arg3);
|
||||
tileData1 = (u8*) GetWindowAttribute(windowId, WINDOW_TILE_DATA);
|
||||
tileData2 = (winTemplate.width * 32) + tileData1;
|
||||
|
||||
if (!arg2)
|
||||
txtColor[0] = 0;
|
||||
else
|
||||
txtColor[0] = arg3;
|
||||
txtColor[1] = 0xF;
|
||||
txtColor[2] = 0xE;
|
||||
AddTextPrinterParameterized4(windowId, 1, 0, 1, 0, 0, txtColor, -1, string);
|
||||
|
||||
val = arg4;
|
||||
if (val > 6u)
|
||||
val = 6;
|
||||
val2 = arg4 - 6;
|
||||
if (val > 0)
|
||||
{
|
||||
for (i = val; i != 0; i--)
|
||||
{
|
||||
CpuCopy16(tileData1, dst, 0x80);
|
||||
CpuCopy16(tileData2, dst + 0x80, 0x80);
|
||||
tileData1 += 0x80;
|
||||
tileData2 += 0x80;
|
||||
dst += 0x100;
|
||||
}
|
||||
}
|
||||
|
||||
if (val2 > 0)
|
||||
CpuFill16((arg3 << 4) | arg3, dst, (u32)(val2) * 0x100);
|
||||
|
||||
RemoveWindow(windowId);
|
||||
}
|
||||
|
||||
NAKED
|
||||
void sub_80C6EAC()
|
||||
{
|
||||
asm_unified("\n\
|
||||
push {r4-r7,lr}\n\
|
||||
mov r7, r10\n\
|
||||
mov r6, r9\n\
|
||||
mov r5, r8\n\
|
||||
push {r5-r7}\n\
|
||||
sub sp, 0x2C\n\
|
||||
str r0, [sp, 0x20]\n\
|
||||
str r1, [sp, 0x24]\n\
|
||||
adds r6, r3, 0\n\
|
||||
ldr r0, [sp, 0x4C]\n\
|
||||
mov r9, r0\n\
|
||||
ldr r1, [sp, 0x50]\n\
|
||||
mov r10, r1\n\
|
||||
lsls r2, 16\n\
|
||||
lsrs r2, 16\n\
|
||||
str r2, [sp, 0x28]\n\
|
||||
lsls r6, 24\n\
|
||||
lsrs r6, 24\n\
|
||||
mov r2, r9\n\
|
||||
lsls r2, 24\n\
|
||||
lsrs r2, 24\n\
|
||||
mov r9, r2\n\
|
||||
mov r0, r10\n\
|
||||
lsls r0, 24\n\
|
||||
lsrs r0, 24\n\
|
||||
mov r10, r0\n\
|
||||
movs r0, 0\n\
|
||||
movs r1, 0\n\
|
||||
str r0, [sp, 0x18]\n\
|
||||
str r1, [sp, 0x1C]\n\
|
||||
ldr r0, [sp, 0x20]\n\
|
||||
bl StringLength_Multibyte\n\
|
||||
lsls r0, 24\n\
|
||||
ldr r2, =0x00ffffff\n\
|
||||
ldr r1, [sp, 0x18]\n\
|
||||
ands r1, r2\n\
|
||||
orrs r1, r0\n\
|
||||
str r1, [sp, 0x18]\n\
|
||||
ldr r1, =0xffffff00\n\
|
||||
add r2, sp, 0x18\n\
|
||||
mov r8, r2\n\
|
||||
ldr r0, [r2, 0x4]\n\
|
||||
ands r0, r1\n\
|
||||
movs r1, 0x2\n\
|
||||
orrs r0, r1\n\
|
||||
str r0, [r2, 0x4]\n\
|
||||
ldr r5, [sp, 0x18]\n\
|
||||
lsrs r5, 24\n\
|
||||
lsls r5, 5\n\
|
||||
mov r0, r8\n\
|
||||
bl AddWindow\n\
|
||||
adds r4, r0, 0\n\
|
||||
lsls r4, 24\n\
|
||||
lsrs r4, 24\n\
|
||||
lsls r1, r6, 4\n\
|
||||
orrs r1, r6\n\
|
||||
lsls r1, 24\n\
|
||||
lsrs r1, 24\n\
|
||||
adds r0, r4, 0\n\
|
||||
bl FillWindowPixelBuffer\n\
|
||||
adds r0, r4, 0\n\
|
||||
movs r1, 0x7\n\
|
||||
bl GetWindowAttribute\n\
|
||||
adds r7, r0, 0\n\
|
||||
mov r0, r8\n\
|
||||
ldrb r0, [r0, 0x3]\n\
|
||||
lsls r0, 5\n\
|
||||
mov r8, r0\n\
|
||||
add r8, r7\n\
|
||||
add r0, sp, 0x14\n\
|
||||
movs r1, 0\n\
|
||||
strb r6, [r0]\n\
|
||||
mov r2, r9\n\
|
||||
strb r2, [r0, 0x1]\n\
|
||||
mov r2, r10\n\
|
||||
strb r2, [r0, 0x2]\n\
|
||||
str r1, [sp]\n\
|
||||
str r1, [sp, 0x4]\n\
|
||||
str r0, [sp, 0x8]\n\
|
||||
movs r0, 0x1\n\
|
||||
negs r0, r0\n\
|
||||
str r0, [sp, 0xC]\n\
|
||||
ldr r0, [sp, 0x20]\n\
|
||||
str r0, [sp, 0x10]\n\
|
||||
adds r0, r4, 0\n\
|
||||
movs r1, 0x1\n\
|
||||
movs r2, 0\n\
|
||||
movs r3, 0x2\n\
|
||||
bl AddTextPrinterParameterized4\n\
|
||||
lsrs r5, 1\n\
|
||||
adds r0, r7, 0\n\
|
||||
ldr r1, [sp, 0x24]\n\
|
||||
adds r2, r5, 0\n\
|
||||
bl CpuSet\n\
|
||||
ldr r2, [sp, 0x24]\n\
|
||||
ldr r0, [sp, 0x28]\n\
|
||||
adds r1, r2, r0\n\
|
||||
mov r0, r8\n\
|
||||
adds r2, r5, 0\n\
|
||||
bl CpuSet\n\
|
||||
adds r0, r4, 0\n\
|
||||
bl RemoveWindow\n\
|
||||
add sp, 0x2C\n\
|
||||
pop {r3-r5}\n\
|
||||
mov r8, r3\n\
|
||||
mov r9, r4\n\
|
||||
mov r10, r5\n\
|
||||
pop {r4-r7}\n\
|
||||
pop {r0}\n\
|
||||
bx r0\n\
|
||||
.pool");
|
||||
}
|
||||
|
||||
u8 CountMonsInBox(u8 boxId)
|
||||
{
|
||||
u16 i, count;
|
||||
|
|
|
@ -167,7 +167,6 @@ static bool8 sub_80C4C84(struct Task* task);
|
|||
static bool8 sub_80C4DB0(struct Task* task);
|
||||
static void sub_80C32EC(u16);
|
||||
static void sub_80C41D8(void);
|
||||
static void sub_80C6D80(const u8 *, u8 *, u8, u8, u8);
|
||||
|
||||
// const rom data
|
||||
static const u32 gUnknown_0856F018[] = INCBIN_U32("graphics/trainer_card/stickers_fr.4bpp.lz");
|
||||
|
|
Loading…
Reference in a new issue