mirror of
https://github.com/Ninjdai1/pokeemerald.git
synced 2025-01-26 05:10:23 +01:00
Begin frontier records
This commit is contained in:
parent
0e6fbbfe09
commit
826d0ea2ab
File diff suppressed because it is too large
Load Diff
@ -15,5 +15,6 @@ bool32 sub_8138168(void);
|
||||
bool32 sub_81381B0(void);
|
||||
bool32 sub_81381F8(void);
|
||||
bool32 CountSSTidalStep(u16 delta);
|
||||
void sub_813A878(u8 a0);
|
||||
|
||||
#endif // GUARD_FIELD_SPECIALS_H
|
||||
|
@ -401,10 +401,7 @@ struct BattleFrontier
|
||||
/*0xCB4*/ u16 field_CB4[20];
|
||||
/*0xCDC*/ u32 field_CDC;
|
||||
/*0xCE0*/ u16 winStreaks[4][2];
|
||||
/*0xCF0*/ u16 field_CF0[2];
|
||||
/*0xCF4*/ u16 field_CF4[2];
|
||||
/*0xCF8*/ u16 field_CF8[2];
|
||||
/*0xCFC*/ u16 field_CFC[2];
|
||||
/*0xCF0*/ u16 field_CF0[4][2];
|
||||
/*0xD06*/ u16 field_D00;
|
||||
/*0xD06*/ u16 field_D02;
|
||||
/*0xD06*/ u16 field_D04;
|
||||
|
@ -246,6 +246,7 @@ SECTIONS {
|
||||
src/menu.o(.text);
|
||||
src/battle_factory.o(.text);
|
||||
src/apprentice.o(.text);
|
||||
src/battle_frontier_2.o(.text);
|
||||
asm/battle_frontier_2.o(.text);
|
||||
src/item_menu.o(.text);
|
||||
src/list_menu.o(.text);
|
||||
|
378
src/battle_frontier_2.c
Normal file
378
src/battle_frontier_2.c
Normal file
@ -0,0 +1,378 @@
|
||||
#include "global.h"
|
||||
#include "event_data.h"
|
||||
#include "battle_setup.h"
|
||||
#include "overworld.h"
|
||||
#include "random.h"
|
||||
#include "battle_tower.h"
|
||||
#include "field_specials.h"
|
||||
#include "battle.h"
|
||||
#include "script_pokemon_util_80F87D8.h"
|
||||
#include "main.h"
|
||||
#include "window.h"
|
||||
#include "menu.h"
|
||||
#include "text.h"
|
||||
#include "battle_records.h"
|
||||
#include "international_string_util.h"
|
||||
#include "string_util.h"
|
||||
#include "constants/battle_frontier.h"
|
||||
|
||||
extern u8 gUnknown_0203CEF8[];
|
||||
|
||||
extern void (* const gUnknown_08611C18[])(void);
|
||||
extern const u16 gUnknown_08611BFC[][2];
|
||||
|
||||
extern void sub_81B8558(void);
|
||||
|
||||
// This file's functions.
|
||||
u8 sub_81A3B30(u8 facility);
|
||||
|
||||
void sub_81A1780(void)
|
||||
{
|
||||
gUnknown_08611C18[gSpecialVar_0x8004]();
|
||||
}
|
||||
|
||||
void sub_81A17A0(void)
|
||||
{
|
||||
VarSet(VAR_TEMP_0, 0xFF);
|
||||
switch (gSaveBlock2Ptr->frontier.field_CA8)
|
||||
{
|
||||
case 0:
|
||||
break;
|
||||
case 1:
|
||||
sub_813A878(0);
|
||||
VarSet(VAR_TEMP_0, gSaveBlock2Ptr->frontier.field_CA8);
|
||||
break;
|
||||
case 4:
|
||||
sub_813A878(0);
|
||||
VarSet(VAR_TEMP_0, gSaveBlock2Ptr->frontier.field_CA8);
|
||||
break;
|
||||
case 3:
|
||||
sub_813A878(1);
|
||||
VarSet(VAR_TEMP_0, gSaveBlock2Ptr->frontier.field_CA8);
|
||||
break;
|
||||
case 2:
|
||||
VarSet(VAR_TEMP_0, gSaveBlock2Ptr->frontier.field_CA8);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
void sub_81A1830(void)
|
||||
{
|
||||
u8 facility = VarGet(VAR_FRONTIER_FACILITY);
|
||||
u8 currSymbol = sub_81A3B30(facility);
|
||||
if (currSymbol == 2)
|
||||
currSymbol = 1;
|
||||
|
||||
switch (gSpecialVar_0x8005)
|
||||
{
|
||||
case 0:
|
||||
gSpecialVar_Result = gSaveBlock2Ptr->frontier.field_CA8;
|
||||
break;
|
||||
case 1:
|
||||
gSpecialVar_Result = gSaveBlock2Ptr->frontier.lvlMode;
|
||||
break;
|
||||
case 2:
|
||||
gSpecialVar_Result = gSaveBlock2Ptr->frontier.curChallengeBattleNum;
|
||||
break;
|
||||
case 3:
|
||||
gSpecialVar_Result = gSaveBlock2Ptr->frontier.field_CA9_a;
|
||||
break;
|
||||
case 5:
|
||||
gSpecialVar_Result = gBattleOutcome;
|
||||
gBattleOutcome = 0;
|
||||
break;
|
||||
case 6:
|
||||
gSpecialVar_Result = gSaveBlock2Ptr->frontier.field_CA9_b;
|
||||
break;
|
||||
case 7:
|
||||
gSpecialVar_Result = gSaveBlock2Ptr->frontier.field_D00 & gUnknown_08611BFC[facility][currSymbol];
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
void sub_81A1968(void)
|
||||
{
|
||||
s32 i;
|
||||
u8 facility = VarGet(VAR_FRONTIER_FACILITY);
|
||||
u8 currSymbol = sub_81A3B30(facility);
|
||||
if (currSymbol == 2)
|
||||
currSymbol = 1;
|
||||
|
||||
switch (gSpecialVar_0x8005)
|
||||
{
|
||||
case 0:
|
||||
gSaveBlock2Ptr->frontier.field_CA8 = gSpecialVar_0x8006;
|
||||
break;
|
||||
case 1:
|
||||
gSaveBlock2Ptr->frontier.lvlMode = gSpecialVar_0x8006;
|
||||
break;
|
||||
case 2:
|
||||
gSaveBlock2Ptr->frontier.curChallengeBattleNum = gSpecialVar_0x8006;
|
||||
break;
|
||||
case 3:
|
||||
gSaveBlock2Ptr->frontier.field_CA9_a = gSpecialVar_0x8006;
|
||||
break;
|
||||
case 4:
|
||||
for (i = 0; i < 4; i++)
|
||||
gSaveBlock2Ptr->frontier.selectedPartyMons[i] = gUnknown_0203CEF8[i];
|
||||
break;
|
||||
case 6:
|
||||
gSaveBlock2Ptr->frontier.field_CA9_b = gSpecialVar_0x8006;
|
||||
break;
|
||||
case 7:
|
||||
gSaveBlock2Ptr->frontier.field_D00 |= gUnknown_08611BFC[facility][currSymbol];
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
void sub_81A1AD4(void)
|
||||
{
|
||||
s32 i;
|
||||
|
||||
sub_81B8558();
|
||||
for (i = 0; i < gSpecialVar_0x8005; i++)
|
||||
gUnknown_0203CEF8[i] = gSaveBlock2Ptr->frontier.selectedPartyMons[i];
|
||||
ReducePlayerPartyToThree();
|
||||
}
|
||||
|
||||
void sub_81A1B1C(void)
|
||||
{
|
||||
DoSoftReset();
|
||||
}
|
||||
|
||||
extern const struct BattleFrontierTrainer gBattleFrontierTrainers[];
|
||||
|
||||
void sub_81A1B28(void)
|
||||
{
|
||||
gFacilityTrainers = gBattleFrontierTrainers;
|
||||
}
|
||||
|
||||
void sub_81A1B38(void)
|
||||
{
|
||||
u8 i;
|
||||
|
||||
for (i = 0; i < 4; i++)
|
||||
{
|
||||
u16 monId = gSaveBlock2Ptr->frontier.selectedPartyMons[i] - 1;
|
||||
if (monId < PARTY_SIZE)
|
||||
gSaveBlock1Ptr->playerParty[gSaveBlock2Ptr->frontier.selectedPartyMons[i] - 1] = gPlayerParty[i];
|
||||
}
|
||||
}
|
||||
|
||||
void PutTowerResultsWindow(u8);
|
||||
void sub_81A2134(u8);
|
||||
void sub_81A2460(u8);
|
||||
void sub_81A2698(void);
|
||||
void sub_81A2C94(u8);
|
||||
void sub_81A2968(void);
|
||||
void sub_81A2F38(void);
|
||||
void sub_81A2FF8(void);
|
||||
|
||||
void sub_81A1B98(void)
|
||||
{
|
||||
if (gSpecialVar_0x8006 > 3)
|
||||
gSpecialVar_0x8006 = 0;
|
||||
switch (gSpecialVar_0x8005)
|
||||
{
|
||||
case 0:
|
||||
PutTowerResultsWindow(gSpecialVar_0x8006);
|
||||
break;
|
||||
case 1:
|
||||
sub_81A2134(gSpecialVar_0x8006);
|
||||
break;
|
||||
case 2:
|
||||
sub_81A2460(gSpecialVar_0x8006);
|
||||
break;
|
||||
case 5:
|
||||
sub_81A2698();
|
||||
break;
|
||||
case 4:
|
||||
sub_81A2C94(gSpecialVar_0x8006);
|
||||
break;
|
||||
case 3:
|
||||
sub_81A2968();
|
||||
break;
|
||||
case 6:
|
||||
sub_81A2F38();
|
||||
break;
|
||||
case 7:
|
||||
sub_81A2FF8();
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
bool8 sub_81A1C24(u32 flags)
|
||||
{
|
||||
if (gSaveBlock2Ptr->frontier.field_CDC & flags)
|
||||
return TRUE;
|
||||
else
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
void sub_81A1C4C(const u8 *str, s32 y)
|
||||
{
|
||||
s32 x = GetStringCenterAlignXOffset(1, str, 0xE0);
|
||||
y = (y * 8) + 1;
|
||||
AddTextPrinterParameterized(gRecordsWindowId, 1, str, x, y, TEXT_SPEED_FF, NULL);
|
||||
}
|
||||
|
||||
void PrintHyphens(s32 y)
|
||||
{
|
||||
s32 i;
|
||||
u8 text[37];
|
||||
|
||||
for (i = 0; i < 36; i++)
|
||||
text[i] = CHAR_HYPHEN;
|
||||
text[i] = EOS;
|
||||
|
||||
y = (y * 8) + 1;
|
||||
AddTextPrinterParameterized(gRecordsWindowId, 1, text, 4, y, TEXT_SPEED_FF, NULL);
|
||||
}
|
||||
|
||||
extern const u8 gText_WinStreak[];
|
||||
extern const u8 gText_Record[];
|
||||
extern const u8 gText_Current[];
|
||||
extern const u8 gText_Prev[];
|
||||
extern const u8 gText_SingleBattleRoomResults[];
|
||||
extern const u8 gText_DoubleBattleRoomResults[];
|
||||
extern const u8 gText_MultiBattleRoomResults[];
|
||||
extern const u8 gText_LinkMultiBattleRoomResults[];
|
||||
extern const u8 gText_Lv502[];
|
||||
extern const u8 gText_OpenLv[];
|
||||
extern const u8 gText_ClearStreak[];
|
||||
|
||||
void TowerPrintStreak(const u8 *str, u16 num, u8 x1, u8 x2, u8 y)
|
||||
{
|
||||
AddTextPrinterParameterized(gRecordsWindowId, 1, str, x1, y, TEXT_SPEED_FF, NULL);
|
||||
if (num > 9999)
|
||||
num = 9999;
|
||||
ConvertIntToDecimalStringN(gStringVar1, num, STR_CONV_MODE_RIGHT_ALIGN, 4);
|
||||
StringExpandPlaceholders(gStringVar4, gText_WinStreak);
|
||||
AddTextPrinterParameterized(gRecordsWindowId, 1, gStringVar4, x2, y, TEXT_SPEED_FF, NULL);
|
||||
}
|
||||
|
||||
void TowerPrintRecordStreak(u8 battleMode, u8 lvlMode, u8 x1, u8 x2, u8 y)
|
||||
{
|
||||
u16 num = gSaveBlock2Ptr->frontier.field_CF0[battleMode][lvlMode];
|
||||
TowerPrintStreak(gText_Record, num, x1, x2, y);
|
||||
}
|
||||
|
||||
u16 TowerGetStreak(u8 battleMode, u8 lvlMode)
|
||||
{
|
||||
u16 winStreak = gSaveBlock2Ptr->frontier.winStreaks[battleMode][lvlMode];
|
||||
if (winStreak > 9999)
|
||||
return 9999;
|
||||
else
|
||||
return winStreak;
|
||||
}
|
||||
|
||||
void TowerPrintPrevOrCurrentStreak(u8 battleMode, u8 lvlMode, u8 x1, u8 x2, u8 y)
|
||||
{
|
||||
bool8 isCurrent;
|
||||
u16 winStreak = TowerGetStreak(battleMode, lvlMode);
|
||||
switch (battleMode)
|
||||
{
|
||||
default:
|
||||
case FRONTIER_MODE_SINGLES:
|
||||
if (lvlMode != FRONTIER_LVL_50)
|
||||
isCurrent = sub_81A1C24(2);
|
||||
else
|
||||
isCurrent = sub_81A1C24(1);
|
||||
break;
|
||||
case FRONTIER_MODE_DOUBLES:
|
||||
if (lvlMode != FRONTIER_LVL_50)
|
||||
isCurrent = sub_81A1C24(0x8000);
|
||||
else
|
||||
isCurrent = sub_81A1C24(0x4000);
|
||||
break;
|
||||
case FRONTIER_MODE_MULTIS:
|
||||
if (lvlMode != FRONTIER_LVL_50)
|
||||
isCurrent = sub_81A1C24(0x20000);
|
||||
else
|
||||
isCurrent = sub_81A1C24(0x10000);
|
||||
break;
|
||||
case FRONTIER_MODE_LINK_MULTIS:
|
||||
if (lvlMode != FRONTIER_LVL_50)
|
||||
isCurrent = sub_81A1C24(0x80000);
|
||||
else
|
||||
isCurrent = sub_81A1C24(0x40000);
|
||||
break;
|
||||
}
|
||||
|
||||
if (isCurrent == TRUE)
|
||||
TowerPrintStreak(gText_Current, winStreak, x1, x2, y);
|
||||
else
|
||||
TowerPrintStreak(gText_Prev, winStreak, x1, x2, y);
|
||||
}
|
||||
|
||||
extern const struct WindowTemplate gUnknown_08611C74;
|
||||
|
||||
void PutTowerResultsWindow(u8 battleMode)
|
||||
{
|
||||
gRecordsWindowId = AddWindow(&gUnknown_08611C74);
|
||||
NewMenuHelpers_DrawStdWindowFrame(gRecordsWindowId, FALSE);
|
||||
FillWindowPixelBuffer(gRecordsWindowId, 0x11);
|
||||
if (battleMode == FRONTIER_MODE_SINGLES)
|
||||
StringExpandPlaceholders(gStringVar4, gText_SingleBattleRoomResults);
|
||||
else if (battleMode == FRONTIER_MODE_DOUBLES)
|
||||
StringExpandPlaceholders(gStringVar4, gText_DoubleBattleRoomResults);
|
||||
else if (battleMode == FRONTIER_MODE_MULTIS)
|
||||
StringExpandPlaceholders(gStringVar4, gText_MultiBattleRoomResults);
|
||||
else
|
||||
StringExpandPlaceholders(gStringVar4, gText_LinkMultiBattleRoomResults);
|
||||
|
||||
sub_81A1C4C(gStringVar4, 2);
|
||||
AddTextPrinterParameterized(gRecordsWindowId, 1, gText_Lv502, 16, 49, TEXT_SPEED_FF, NULL);
|
||||
AddTextPrinterParameterized(gRecordsWindowId, 1, gText_OpenLv, 16, 97, TEXT_SPEED_FF, NULL);
|
||||
PrintHyphens(10);
|
||||
TowerPrintPrevOrCurrentStreak(battleMode, FRONTIER_LVL_50, 72, 132, 49);
|
||||
TowerPrintRecordStreak(battleMode, FRONTIER_LVL_50, 72, 132, 65);
|
||||
TowerPrintPrevOrCurrentStreak(battleMode, FRONTIER_LVL_OPEN, 72, 132, 97);
|
||||
TowerPrintRecordStreak(battleMode, FRONTIER_LVL_OPEN, 72, 132, 113);
|
||||
PutWindowTilemap(gRecordsWindowId);
|
||||
CopyWindowToVram(gRecordsWindowId, 3);
|
||||
}
|
||||
|
||||
u16 sub_81A1FD8(u8 battleMode, u8 lvlMode)
|
||||
{
|
||||
u16 winStreak = gSaveBlock2Ptr->frontier.field_D0C[battleMode][lvlMode];
|
||||
if (winStreak > 9999)
|
||||
return 9999;
|
||||
else
|
||||
return winStreak;
|
||||
}
|
||||
|
||||
void sub_81A2008(const u8 *str1, const u8 *str2, u16 num, u8 x1, u8 x2, u8 y)
|
||||
{
|
||||
AddTextPrinterParameterized(gRecordsWindowId, 1, str1, x1, y, TEXT_SPEED_FF, NULL);
|
||||
ConvertIntToDecimalStringN(gStringVar1, num, STR_CONV_MODE_RIGHT_ALIGN, 4);
|
||||
StringExpandPlaceholders(gStringVar4, str2);
|
||||
AddTextPrinterParameterized(gRecordsWindowId, 1, gStringVar4, x2, y, TEXT_SPEED_FF, NULL);
|
||||
}
|
||||
|
||||
void sub_81A2094(u8 battleMode, u8 lvlMode, u8 x1, u8 x2, u8 y)
|
||||
{
|
||||
bool8 isCurrent;
|
||||
u16 winStreak = sub_81A1FD8(battleMode, lvlMode);
|
||||
switch (battleMode)
|
||||
{
|
||||
default:
|
||||
case FRONTIER_MODE_SINGLES:
|
||||
if (lvlMode != FRONTIER_LVL_50)
|
||||
isCurrent = sub_81A1C24(8);
|
||||
else
|
||||
isCurrent = sub_81A1C24(4);
|
||||
break;
|
||||
case FRONTIER_MODE_DOUBLES:
|
||||
if (lvlMode != FRONTIER_LVL_50)
|
||||
isCurrent = sub_81A1C24(0x200000);
|
||||
else
|
||||
isCurrent = sub_81A1C24(0x100000);
|
||||
break;
|
||||
}
|
||||
|
||||
if (isCurrent == TRUE)
|
||||
sub_81A2008(gText_Current, gText_ClearStreak, winStreak, x1, x2, y);
|
||||
else
|
||||
sub_81A2008(gText_Prev, gText_ClearStreak, winStreak, x1, x2, y);
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user