Merge pull request #1903 from GriffinRichards/frontier-gfx

Fix some frontier gfx, adjacent cleanup
This commit is contained in:
GriffinR 2023-08-10 14:49:44 -04:00 committed by GitHub
commit 60a6c9d160
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
21 changed files with 435 additions and 619 deletions

Binary file not shown.

Before

Width:  |  Height:  |  Size: 309 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 234 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.8 KiB

View File

@ -1,259 +0,0 @@
JASC-PAL
0100
256
0 0 0
255 172 65
255 255 131
222 213 180
255 255 255
230 222 222
197 197 197
213 57 49
230 230 213
255 246 205
255 82 49
164 24 0
0 0 0
106 106 106
0 0 0
0 0 0
0 0 0
90 172 131
106 156 123
123 222 139
246 255 255
0 0 0
246 255 246
0 0 0
0 0 0
0 0 0
230 238 246
222 255 238
189 238 197
123 123 123
115 197 156
0 0 0
0 0 0
197 205 230
32 115 139
255 255 255
222 238 222
0 0 0
131 197 139
0 0 0
139 156 197
115 139 189
0 90 82
106 164 139
57 115 90
189 222 197
0 0 0
0 0 0
0 0 0
205 205 246
230 238 230
213 213 255
156 156 222
238 238 255
189 189 238
230 230 255
222 222 255
197 197 246
189 189 238
180 180 230
172 172 230
164 164 222
156 156 222
0 0 0
0 0 0
131 148 180
213 230 246
189 189 222
90 98 115
230 238 255
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
197 238 222
255 205 205
205 222 255
222 255 255
246 230 164
0 0 0
189 246 180
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
255 255 255
0 0 0
0 255 0
164 180 180
255 74 0
246 255 246
246 255 255
0 0 0
246 255 246
0 0 0
0 0 0
0 0 0
230 238 246
0 0 0
189 238 197
0 0 0
0 0 0
0 0 0
0 0 0
255 213 106
255 74 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
246 255 255
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0
0 0 0

Binary file not shown.

Before

Width:  |  Height:  |  Size: 983 B

After

Width:  |  Height:  |  Size: 7.2 KiB

View File

@ -55,7 +55,7 @@
#define TRAINER_HILL_OTID 0x10000000 #define TRAINER_HILL_OTID 0x10000000
// The full map of each Trainer Hill floor is 16x21. // The full map of each Trainer Hill floor is 16x21.
// The first 5x21 at the top is the entrance/exit area, // The first 16x5 at the top is the entrance/exit area,
// and the remaining 16x16 is the randomized portion of // and the remaining 16x16 is the randomized portion of
// the room where the trainers are. // the room where the trainers are.
#define HILL_FLOOR_WIDTH 16 #define HILL_FLOOR_WIDTH 16

View File

@ -5018,9 +5018,9 @@ extern const u32 gPokenavOptions_Gfx[];
extern const u16 gPokenavOptions_Pal[]; extern const u16 gPokenavOptions_Pal[];
// Battle Factory Screen // Battle Factory Screen
extern const u16 gFrontierFactorySelectMenu_Gfx[]; extern const u16 gFrontierFactoryMenu_Gfx[34 * TILE_SIZE_4BPP / 2];
extern const u16 gFrontierFactorySelectMenu_Tilemap[]; extern const u16 gFrontierFactoryMenu_Tilemap[];
extern const u16 gFrontierFactorySelectMenu_Pal[]; extern const u16 gFrontierFactoryMenu_Pal[];
// Object event pals // Object event pals
extern const u16 gObjectEventPal_Brendan[]; extern const u16 gObjectEventPal_Brendan[];

View File

@ -1,6 +1,8 @@
#ifndef GUARD_SCRIPT_MENU_H #ifndef GUARD_SCRIPT_MENU_H
#define GUARD_SCRIPT_MENU_H #define GUARD_SCRIPT_MENU_H
#include "constants/script_menu.h"
extern const u8 *const gStdStrings[]; extern const u8 *const gStdStrings[];
bool8 ScriptMenu_Multichoice(u8 left, u8 top, u8 multichoiceId, bool8 ignoreBPress); bool8 ScriptMenu_Multichoice(u8 left, u8 top, u8 multichoiceId, bool8 ignoreBPress);

View File

@ -346,11 +346,10 @@ static u16 GetRandomAlternateMove(u8 monId)
learnset = gLevelUpLearnsets[species]; learnset = gLevelUpLearnsets[species];
j = 0; j = 0;
// Despite being open level, level up moves are only read up to level 60
if (PLAYER_APPRENTICE.lvlMode == APPRENTICE_LVL_MODE_50) if (PLAYER_APPRENTICE.lvlMode == APPRENTICE_LVL_MODE_50)
level = 50; level = FRONTIER_MAX_LEVEL_50;
else // == APPRENTICE_LVL_MODE_OPEN else // == APPRENTICE_LVL_MODE_OPEN
level = 60; level = 60; // Despite being open level, level up moves are only read up to level 60
for (j = 0; learnset[j] != LEVEL_UP_END; j++) for (j = 0; learnset[j] != LEVEL_UP_END; j++)
{ {
@ -464,7 +463,7 @@ static void GetLatestLearnedMoves(u16 species, u16 *moves)
const u16 *learnset; const u16 *learnset;
if (PLAYER_APPRENTICE.lvlMode == APPRENTICE_LVL_MODE_50) if (PLAYER_APPRENTICE.lvlMode == APPRENTICE_LVL_MODE_50)
level = 50; level = FRONTIER_MAX_LEVEL_50;
else // == APPRENTICE_LVL_MODE_OPEN else // == APPRENTICE_LVL_MODE_OPEN
level = 60; level = 60;
@ -666,11 +665,12 @@ static void Task_ChooseAnswer(u8 taskId)
case MENU_NOTHING_CHOSEN: case MENU_NOTHING_CHOSEN:
return; return;
case MENU_B_PRESSED: case MENU_B_PRESSED:
// Only ever true. Answering Apprentice questions is required.
if (tNoBButton) if (tNoBButton)
return; return;
PlaySE(SE_SELECT); PlaySE(SE_SELECT);
gSpecialVar_Result = 0x7F; gSpecialVar_Result = MULTI_B_PRESSED;
break; break;
default: default:
gSpecialVar_Result = input; gSpecialVar_Result = input;

View File

@ -40,6 +40,8 @@
#include "constants/battle_frontier.h" #include "constants/battle_frontier.h"
#include "constants/rgb.h" #include "constants/rgb.h"
#define TAG_BUTTONS 0
// Enough space to hold 2 match info cards worth of trainers and their parties // Enough space to hold 2 match info cards worth of trainers and their parties
#define NUM_INFOCARD_SPRITES ((FRONTIER_PARTY_SIZE + 1) * 4) #define NUM_INFOCARD_SPRITES ((FRONTIER_PARTY_SIZE + 1) * 4)
#define NUM_INFOCARD_TRAINERS 2 #define NUM_INFOCARD_TRAINERS 2
@ -56,7 +58,7 @@ struct TourneyTreeLineSection
{ {
u8 x; u8 x;
u8 y; u8 y;
u16 src; u16 tile;
}; };
#define DOME_TRAINERS gSaveBlock2Ptr->frontier.domeTrainers #define DOME_TRAINERS gSaveBlock2Ptr->frontier.domeTrainers
@ -904,14 +906,14 @@ static const struct ScanlineEffectParams sTourneyTreeScanlineEffectParams =
static const struct CompressedSpriteSheet sTourneyTreeButtonsSpriteSheet[] = static const struct CompressedSpriteSheet sTourneyTreeButtonsSpriteSheet[] =
{ {
{gDomeTourneyTreeButtons_Gfx, 0x0600, 0x0000}, {.data = gDomeTourneyTreeButtons_Gfx, .size = 0x0600, .tag = TAG_BUTTONS},
{}, {},
}; };
// Unused // Unused
static const struct CompressedSpritePalette sTourneyTreeButtonsSpritePal[] = static const struct CompressedSpritePalette sTourneyTreeButtonsSpritePal[] =
{ {
{gDomeTourneyTreeButtons_Pal, 0x0000}, {.data = gDomeTourneyTreeButtons_Pal, .tag = TAG_BUTTONS},
{}, {},
}; };
@ -1004,7 +1006,7 @@ static const union AnimCmd * const sSpriteAnimTable_TourneyTreePokeball[] =
// Sprite template for the pokeballs on the tourney tree that act as buttons to view a trainer/match info card // Sprite template for the pokeballs on the tourney tree that act as buttons to view a trainer/match info card
static const struct SpriteTemplate sTourneyTreePokeballSpriteTemplate = static const struct SpriteTemplate sTourneyTreePokeballSpriteTemplate =
{ {
.tileTag = 0x0000, .tileTag = TAG_BUTTONS,
.paletteTag = TAG_NONE, .paletteTag = TAG_NONE,
.oam = &sOamData_TourneyTreePokeball, .oam = &sOamData_TourneyTreePokeball,
.anims = sSpriteAnimTable_TourneyTreePokeball, .anims = sSpriteAnimTable_TourneyTreePokeball,
@ -1033,7 +1035,7 @@ static const union AnimCmd * const sSpriteAnimTable_TourneyTreeCancelButton[] =
static const struct SpriteTemplate sCancelButtonSpriteTemplate = static const struct SpriteTemplate sCancelButtonSpriteTemplate =
{ {
.tileTag = 0x0000, .tileTag = TAG_BUTTONS,
.paletteTag = TAG_NONE, .paletteTag = TAG_NONE,
.oam = &sOamData_TourneyTreeCloseButton, .oam = &sOamData_TourneyTreeCloseButton,
.anims = sSpriteAnimTable_TourneyTreeCancelButton, .anims = sSpriteAnimTable_TourneyTreeCancelButton,
@ -1062,7 +1064,7 @@ static const union AnimCmd * const sSpriteAnimTable_TourneyTreeExitButton[] =
static const struct SpriteTemplate sExitButtonSpriteTemplate = static const struct SpriteTemplate sExitButtonSpriteTemplate =
{ {
.tileTag = 0x0000, .tileTag = TAG_BUTTONS,
.paletteTag = TAG_NONE, .paletteTag = TAG_NONE,
.oam = &sOamData_TourneyTreeCloseButton, .oam = &sOamData_TourneyTreeCloseButton,
.anims = sSpriteAnimTable_TourneyTreeExitButton, .anims = sSpriteAnimTable_TourneyTreeExitButton,
@ -1109,7 +1111,7 @@ static const union AnimCmd * const sSpriteAnimTable_HorizontalScrollArrow[] =
static const struct SpriteTemplate sHorizontalScrollArrowSpriteTemplate = static const struct SpriteTemplate sHorizontalScrollArrowSpriteTemplate =
{ {
.tileTag = 0x0000, .tileTag = TAG_BUTTONS,
.paletteTag = TAG_NONE, .paletteTag = TAG_NONE,
.oam = &sOamData_HorizontalScrollArrow, .oam = &sOamData_HorizontalScrollArrow,
.anims = sSpriteAnimTable_HorizontalScrollArrow, .anims = sSpriteAnimTable_HorizontalScrollArrow,
@ -1120,7 +1122,7 @@ static const struct SpriteTemplate sHorizontalScrollArrowSpriteTemplate =
static const struct SpriteTemplate sVerticalScrollArrowSpriteTemplate = static const struct SpriteTemplate sVerticalScrollArrowSpriteTemplate =
{ {
.tileTag = 0x0000, .tileTag = TAG_BUTTONS,
.paletteTag = TAG_NONE, .paletteTag = TAG_NONE,
.oam = &sOamData_VerticalScrollArrow, .oam = &sOamData_VerticalScrollArrow,
.anims = sSpriteAnimTable_VerticalScrollArrow, .anims = sSpriteAnimTable_VerticalScrollArrow,
@ -1482,589 +1484,617 @@ static const u8 sTourneyTreePokeballCoords[DOME_TOURNAMENT_TRAINERS_COUNT + DOME
{120, 89}, // Final match {120, 89}, // Final match
}; };
// Tile values from tourney_tree.png for the highlighted lines of the tourney tree.
// These tiles will be used to replace the existing, unhighlighted line tiles on the tourney tree tilemap.
#define LINE_PAL (6 << 12)
#define LINE_H (LINE_PAL | 0x21) // Horizontal
#define LINE_CORNER_R (LINE_PAL | 0x23) // Horizontal into a right-side vertical
#define LINE_CORNER_L (LINE_PAL | 0x25) // Horizontal into a left-side vertical
#define LINE_V_R (LINE_PAL | 0x27) // Right-side vertical
#define LINE_V_L (LINE_PAL | 0x29) // Left-side vertical
#define LINE_H_BOTTOM (LINE_PAL | 0x2B) // Horizontal on the bottom of the tree
#define LINE_H_LOGO1 (LINE_PAL | 0x2C) // Horizontal, logo behind
#define LINE_H_LOGO2 (LINE_PAL | 0x2D) // Horizontal, logo behind
#define LINE_H_LOGO3 (LINE_PAL | 0x2E) // Horizontal, logo behind
#define LINE_H_LOGO4 (LINE_PAL | 0x2F) // Horizontal, logo behind
#define LINE_V_R_LOGO1 (LINE_PAL | 0x30) // Right-side vertical, logo behind
#define LINE_V_R_LOGO2 (LINE_PAL | 0x31) // Right-side vertical, logo behind
#define LINE_V_R_LOGO3 (LINE_PAL | 0x32) // Right-side vertical, logo behind
#define LINE_V_R_LOGO4 (LINE_PAL | 0x33) // Right-side vertical, logo behind
#define LINE_V_L_LOGO1 (LINE_PAL | 0x35) // Left-side vertical, logo behind
#define LINE_V_L_LOGO2 (LINE_PAL | 0x36) // Left-side vertical, logo behind
#define LINE_V_L_LOGO3 (LINE_PAL | 0x37) // Left-side vertical, logo behind
#define LINE_V_L_LOGO4 (LINE_PAL | 0x38) // Left-side vertical, logo behind
#define LINE_V_R_HALF_LOGO (LINE_PAL | 0x3B) // Right-side vertical, half lit from the top, logo behind
#define LINE_V_L_HALF_LOGO (LINE_PAL | 0x3C) // Left-side vertical, half lit from the top, logo behind
#define LINE_CORNER_R_HALF (LINE_PAL | 0x43) // Lit horizontal, unlit right-side vertical
#define LINE_CORNER_L_HALF (LINE_PAL | 0x45) // Lit horizontal, unlit left-side vertical
#define LINE_V_R_HALF (LINE_PAL | 0x47) // Right-side vertical, half lit from the top
#define LINE_V_L_HALF (LINE_PAL | 0x49) // Left-side vertical, half lit from the top
// Each of these line sections define the position of the advancement line on the tourney tree for the victor of that round // Each of these line sections define the position of the advancement line on the tourney tree for the victor of that round
// The trainers here are numbered by tourney ID (rank/seed) and ordered according to where they start on the tourney tree // The trainers here are numbered by tourney ID (rank/seed) and ordered according to where they start on the tourney tree
#define LINESECTION_ROUND1_TRAINER1(lastSrc) \ #define LINESECTION_ROUND1_TRAINER1(lastTile) \
{.src = 0x6021, .y = 0x04, .x = 0x09}, \ {.tile = LINE_H, .y = 4, .x = 9}, \
{.src = 0x6023, .y = 0x04, .x = 0x0a}, \ {.tile = LINE_CORNER_R, .y = 4, .x = 10}, \
{.src = 0x6047, .y = 0x05, .x = 0x0a}, \ {.tile = LINE_V_R_HALF, .y = 5, .x = 10}, \
{.src = lastSrc, .y = 0x05, .x = 0x0b}, {.tile = lastTile, .y = 5, .x = 11},
#define LINESECTION_ROUND1_TRAINER9(lastSrc) \ #define LINESECTION_ROUND1_TRAINER9(lastTile) \
{.src = 0x6021, .y = 0x06, .x = 0x09}, \ {.tile = LINE_H, .y = 6, .x = 9}, \
{.src = 0x6021, .y = 0x06, .x = 0x0a}, \ {.tile = LINE_H, .y = 6, .x = 10}, \
{.src = 0x6027, .y = 0x05, .x = 0x0a}, \ {.tile = LINE_V_R, .y = 5, .x = 10}, \
{.src = lastSrc, .y = 0x05, .x = 0x0b}, {.tile = lastTile, .y = 5, .x = 11},
#define LINESECTION_ROUND1_TRAINER13(lastSrc) \ #define LINESECTION_ROUND1_TRAINER13(lastTile) \
{.src = 0x6021, .y = 0x08, .x = 0x09}, \ {.tile = LINE_H, .y = 8, .x = 9}, \
{.src = 0x6023, .y = 0x08, .x = 0x0a}, \ {.tile = LINE_CORNER_R, .y = 8, .x = 10}, \
{.src = 0x6047, .y = 0x09, .x = 0x0a}, \ {.tile = LINE_V_R_HALF, .y = 9, .x = 10}, \
{.src = lastSrc, .y = 0x09, .x = 0x0b}, {.tile = lastTile, .y = 9, .x = 11},
#define LINESECTION_ROUND1_TRAINER5(lastSrc) \ #define LINESECTION_ROUND1_TRAINER5(lastTile) \
{.src = 0x6021, .y = 0x0a, .x = 0x09}, \ {.tile = LINE_H, .y = 10, .x = 9}, \
{.src = 0x6021, .y = 0x0a, .x = 0x0a}, \ {.tile = LINE_H, .y = 10, .x = 10}, \
{.src = 0x6027, .y = 0x09, .x = 0x0a}, \ {.tile = LINE_V_R, .y = 9, .x = 10}, \
{.src = lastSrc, .y = 0x09, .x = 0x0b}, {.tile = lastTile, .y = 9, .x = 11},
#define LINESECTION_ROUND1_TRAINER8(lastSrc) \ #define LINESECTION_ROUND1_TRAINER8(lastTile) \
{.src = 0x6021, .y = 0x0c, .x = 0x09}, \ {.tile = LINE_H, .y = 12, .x = 9}, \
{.src = 0x6023, .y = 0x0c, .x = 0x0a}, \ {.tile = LINE_CORNER_R, .y = 12, .x = 10}, \
{.src = 0x6047, .y = 0x0d, .x = 0x0a}, \ {.tile = LINE_V_R_HALF, .y = 13, .x = 10}, \
{.src = lastSrc, .y = 0x0d, .x = 0x0b}, {.tile = lastTile, .y = 13, .x = 11},
#define LINESECTION_ROUND1_TRAINER16(lastSrc) \ #define LINESECTION_ROUND1_TRAINER16(lastTile) \
{.src = 0x6021, .y = 0x0e, .x = 0x09}, \ {.tile = LINE_H, .y = 14, .x = 9}, \
{.src = 0x6021, .y = 0x0e, .x = 0x0a}, \ {.tile = LINE_H, .y = 14, .x = 10}, \
{.src = 0x6027, .y = 0x0d, .x = 0x0a}, \ {.tile = LINE_V_R, .y = 13, .x = 10}, \
{.src = lastSrc, .y = 0x0d, .x = 0x0b}, {.tile = lastTile, .y = 13, .x = 11},
#define LINESECTION_ROUND1_TRAINER12(lastSrc) \ #define LINESECTION_ROUND1_TRAINER12(lastTile) \
{.src = 0x6021, .y = 0x10, .x = 0x09}, \ {.tile = LINE_H, .y = 16, .x = 9}, \
{.src = 0x6023, .y = 0x10, .x = 0x0a}, \ {.tile = LINE_CORNER_R, .y = 16, .x = 10}, \
{.src = 0x6047, .y = 0x11, .x = 0x0a}, \ {.tile = LINE_V_R_HALF, .y = 17, .x = 10}, \
{.src = lastSrc, .y = 0x11, .x = 0x0b}, {.tile = lastTile, .y = 17, .x = 11},
#define LINESECTION_ROUND1_TRAINER4(lastSrc) \ #define LINESECTION_ROUND1_TRAINER4(lastTile) \
{.src = 0x602b, .y = 0x12, .x = 0x09}, \ {.tile = LINE_H_BOTTOM, .y = 18, .x = 9}, \
{.src = 0x602b, .y = 0x12, .x = 0x0a}, \ {.tile = LINE_H_BOTTOM, .y = 18, .x = 10}, \
{.src = 0x6027, .y = 0x11, .x = 0x0a}, \ {.tile = LINE_V_R, .y = 17, .x = 10}, \
{.src = lastSrc, .y = 0x11, .x = 0x0b}, {.tile = lastTile, .y = 17, .x = 11},
#define LINESECTION_ROUND1_TRAINER3(lastSrc) \ #define LINESECTION_ROUND1_TRAINER3(lastTile) \
{.src = 0x6021, .y = 0x04, .x = 0x14}, \ {.tile = LINE_H, .y = 4, .x = 20}, \
{.src = 0x6025, .y = 0x04, .x = 0x13}, \ {.tile = LINE_CORNER_L, .y = 4, .x = 19}, \
{.src = 0x6049, .y = 0x05, .x = 0x13}, \ {.tile = LINE_V_L_HALF, .y = 5, .x = 19}, \
{.src = lastSrc, .y = 0x05, .x = 0x12}, {.tile = lastTile, .y = 5, .x = 18},
#define LINESECTION_ROUND1_TRAINER11(lastSrc) \ #define LINESECTION_ROUND1_TRAINER11(lastTile) \
{.src = 0x6021, .y = 0x06, .x = 0x14}, \ {.tile = LINE_H, .y = 6, .x = 20}, \
{.src = 0x6021, .y = 0x06, .x = 0x13}, \ {.tile = LINE_H, .y = 6, .x = 19}, \
{.src = 0x6029, .y = 0x05, .x = 0x13}, \ {.tile = LINE_V_L, .y = 5, .x = 19}, \
{.src = lastSrc, .y = 0x05, .x = 0x12}, {.tile = lastTile, .y = 5, .x = 18},
#define LINESECTION_ROUND1_TRAINER15(lastSrc) \ #define LINESECTION_ROUND1_TRAINER15(lastTile) \
{.src = 0x6021, .y = 0x08, .x = 0x14}, \ {.tile = LINE_H, .y = 8, .x = 20}, \
{.src = 0x6025, .y = 0x08, .x = 0x13}, \ {.tile = LINE_CORNER_L, .y = 8, .x = 19}, \
{.src = 0x6049, .y = 0x09, .x = 0x13}, \ {.tile = LINE_V_L_HALF, .y = 9, .x = 19}, \
{.src = lastSrc, .y = 0x09, .x = 0x12}, {.tile = lastTile, .y = 9, .x = 18},
#define LINESECTION_ROUND1_TRAINER7(lastSrc) \ #define LINESECTION_ROUND1_TRAINER7(lastTile) \
{.src = 0x6021, .y = 0x0a, .x = 0x14}, \ {.tile = LINE_H, .y = 10, .x = 20}, \
{.src = 0x6021, .y = 0x0a, .x = 0x13}, \ {.tile = LINE_H, .y = 10, .x = 19}, \
{.src = 0x6029, .y = 0x09, .x = 0x13}, \ {.tile = LINE_V_L, .y = 9, .x = 19}, \
{.src = lastSrc, .y = 0x09, .x = 0x12}, {.tile = lastTile, .y = 9, .x = 18},
#define LINESECTION_ROUND1_TRAINER6(lastSrc) \ #define LINESECTION_ROUND1_TRAINER6(lastTile) \
{.src = 0x6021, .y = 0x0c, .x = 0x14}, \ {.tile = LINE_H, .y = 12, .x = 20}, \
{.src = 0x6025, .y = 0x0c, .x = 0x13}, \ {.tile = LINE_CORNER_L, .y = 12, .x = 19}, \
{.src = 0x6049, .y = 0x0d, .x = 0x13}, \ {.tile = LINE_V_L_HALF, .y = 13, .x = 19}, \
{.src = lastSrc, .y = 0x0d, .x = 0x12}, {.tile = lastTile, .y = 13, .x = 18},
#define LINESECTION_ROUND1_TRAINER14(lastSrc) \ #define LINESECTION_ROUND1_TRAINER14(lastTile) \
{.src = 0x6021, .y = 0x0e, .x = 0x14}, \ {.tile = LINE_H, .y = 14, .x = 20}, \
{.src = 0x6021, .y = 0x0e, .x = 0x13}, \ {.tile = LINE_H, .y = 14, .x = 19}, \
{.src = 0x6029, .y = 0x0d, .x = 0x13}, \ {.tile = LINE_V_L, .y = 13, .x = 19}, \
{.src = lastSrc, .y = 0x0d, .x = 0x12}, {.tile = lastTile, .y = 13, .x = 18},
#define LINESECTION_ROUND1_TRAINER10(lastSrc) \ #define LINESECTION_ROUND1_TRAINER10(lastTile) \
{.src = 0x6021, .y = 0x10, .x = 0x14}, \ {.tile = LINE_H, .y = 16, .x = 20}, \
{.src = 0x6025, .y = 0x10, .x = 0x13}, \ {.tile = LINE_CORNER_L, .y = 16, .x = 19}, \
{.src = 0x6049, .y = 0x11, .x = 0x13}, \ {.tile = LINE_V_L_HALF, .y = 17, .x = 19}, \
{.src = lastSrc, .y = 0x11, .x = 0x12}, {.tile = lastTile, .y = 17, .x = 18},
#define LINESECTION_ROUND1_TRAINER2(lastSrc) \ #define LINESECTION_ROUND1_TRAINER2(lastTile) \
{.src = 0x602b, .y = 0x12, .x = 0x14}, \ {.tile = LINE_H_BOTTOM, .y = 18, .x = 20}, \
{.src = 0x602b, .y = 0x12, .x = 0x13}, \ {.tile = LINE_H_BOTTOM, .y = 18, .x = 19}, \
{.src = 0x6029, .y = 0x11, .x = 0x13}, \ {.tile = LINE_V_L, .y = 17, .x = 19}, \
{.src = lastSrc, .y = 0x11, .x = 0x12}, {.tile = lastTile, .y = 17, .x = 18},
#define LINESECTION_ROUND2_MATCH1(lastSrc) \ #define LINESECTION_ROUND2_MATCH1(lastTile) \
{.src = 0x6027, .y = 0x06, .x = 0x0b}, \ {.tile = LINE_V_R, .y = 6, .x = 11}, \
{.src = 0x6047, .y = 0x07, .x = 0x0b}, \ {.tile = LINE_V_R_HALF, .y = 7, .x = 11}, \
{.src = lastSrc, .y = 0x07, .x = 0x0c}, {.tile = lastTile, .y = 7, .x = 12},
#define LINESECTION_ROUND2_MATCH2(lastSrc) \ #define LINESECTION_ROUND2_MATCH2(lastTile) \
{.src = 0x6027, .y = 0x08, .x = 0x0b}, \ {.tile = LINE_V_R, .y = 8, .x = 11}, \
{.src = 0x6027, .y = 0x07, .x = 0x0b}, \ {.tile = LINE_V_R, .y = 7, .x = 11}, \
{.src = lastSrc, .y = 0x07, .x = 0x0c}, {.tile = lastTile, .y = 7, .x = 12},
#define LINESECTION_ROUND2_MATCH3(lastSrc) \ #define LINESECTION_ROUND2_MATCH3(lastTile) \
{.src = 0x6027, .y = 0x0e, .x = 0x0b}, \ {.tile = LINE_V_R, .y = 14, .x = 11}, \
{.src = 0x6047, .y = 0x0f, .x = 0x0b}, \ {.tile = LINE_V_R_HALF, .y = 15, .x = 11}, \
{.src = lastSrc, .y = 0x0f, .x = 0x0c}, {.tile = lastTile, .y = 15, .x = 12},
#define LINESECTION_ROUND2_MATCH4(lastSrc) \ #define LINESECTION_ROUND2_MATCH4(lastTile) \
{.src = 0x6027, .y = 0x10, .x = 0x0b}, \ {.tile = LINE_V_R, .y = 16, .x = 11}, \
{.src = 0x6027, .y = 0x0f, .x = 0x0b}, \ {.tile = LINE_V_R, .y = 15, .x = 11}, \
{.src = lastSrc, .y = 0x0f, .x = 0x0c}, {.tile = lastTile, .y = 15, .x = 12},
#define LINESECTION_ROUND2_MATCH5(lastSrc) \ #define LINESECTION_ROUND2_MATCH5(lastTile) \
{.src = 0x6029, .y = 0x06, .x = 0x12}, \ {.tile = LINE_V_L, .y = 6, .x = 18}, \
{.src = 0x6049, .y = 0x07, .x = 0x12}, \ {.tile = LINE_V_L_HALF, .y = 7, .x = 18}, \
{.src = lastSrc, .y = 0x07, .x = 0x11}, {.tile = lastTile, .y = 7, .x = 17},
#define LINESECTION_ROUND2_MATCH6(lastSrc) \ #define LINESECTION_ROUND2_MATCH6(lastTile) \
{.src = 0x6029, .y = 0x08, .x = 0x12}, \ {.tile = LINE_V_L, .y = 8, .x = 18}, \
{.src = 0x6029, .y = 0x07, .x = 0x12}, \ {.tile = LINE_V_L, .y = 7, .x = 18}, \
{.src = lastSrc, .y = 0x07, .x = 0x11}, {.tile = lastTile, .y = 7, .x = 17},
#define LINESECTION_ROUND2_MATCH7(lastSrc) \ #define LINESECTION_ROUND2_MATCH7(lastTile) \
{.src = 0x6029, .y = 0x0e, .x = 0x12}, \ {.tile = LINE_V_L, .y = 14, .x = 18}, \
{.src = 0x6049, .y = 0x0f, .x = 0x12}, \ {.tile = LINE_V_L_HALF, .y = 15, .x = 18}, \
{.src = lastSrc, .y = 0x0f, .x = 0x11}, {.tile = lastTile, .y = 15, .x = 17},
#define LINESECTION_ROUND2_MATCH8(lastSrc) \ #define LINESECTION_ROUND2_MATCH8(lastTile) \
{.src = 0x6029, .y = 0x10, .x = 0x12}, \ {.tile = LINE_V_L, .y = 16, .x = 18}, \
{.src = 0x6029, .y = 0x0f, .x = 0x12}, \ {.tile = LINE_V_L, .y = 15, .x = 18}, \
{.src = lastSrc, .y = 0x0f, .x = 0x11}, {.tile = lastTile, .y = 15, .x = 17},
#define LINESECTION_SEMIFINAL_TOP_LEFT \ #define LINESECTION_SEMIFINAL_TOP_LEFT \
{.src = 0x6027, .y = 0x08, .x = 0x0c}, \ {.tile = LINE_V_R, .y = 8, .x = 12}, \
{.src = 0x6027, .y = 0x09, .x = 0x0c}, \ {.tile = LINE_V_R, .y = 9, .x = 12}, \
{.src = 0x6027, .y = 0x0a, .x = 0x0c}, \ {.tile = LINE_V_R, .y = 10, .x = 12}, \
{.src = 0x603b, .y = 0x0b, .x = 0x0c}, {.tile = LINE_V_R_HALF_LOGO, .y = 11, .x = 12},
#define LINESECTION_SEMIFINAL_BOTTOM_LEFT \ #define LINESECTION_SEMIFINAL_BOTTOM_LEFT \
{.src = 0x6033, .y = 0x0e, .x = 0x0c}, \ {.tile = LINE_V_R_LOGO4, .y = 14, .x = 12}, \
{.src = 0x6032, .y = 0x0d, .x = 0x0c}, \ {.tile = LINE_V_R_LOGO3, .y = 13, .x = 12}, \
{.src = 0x6031, .y = 0x0c, .x = 0x0c}, \ {.tile = LINE_V_R_LOGO2, .y = 12, .x = 12}, \
{.src = 0x6030, .y = 0x0b, .x = 0x0c}, {.tile = LINE_V_R_LOGO1, .y = 11, .x = 12},
#define LINESECTION_SEMIFINAL_TOP_RIGHT \ #define LINESECTION_SEMIFINAL_TOP_RIGHT \
{.src = 0x6029, .y = 0x08, .x = 0x11}, \ {.tile = LINE_V_L, .y = 8, .x = 17}, \
{.src = 0x6029, .y = 0x09, .x = 0x11}, \ {.tile = LINE_V_L, .y = 9, .x = 17}, \
{.src = 0x6029, .y = 0x0a, .x = 0x11}, \ {.tile = LINE_V_L, .y = 10, .x = 17}, \
{.src = 0x603c, .y = 0x0b, .x = 0x11}, {.tile = LINE_V_L_HALF_LOGO, .y = 11, .x = 17},
#define LINESECTION_SEMIFINAL_BOTTOM_RIGHT \ #define LINESECTION_SEMIFINAL_BOTTOM_RIGHT \
{.src = 0x6038, .y = 0x0e, .x = 0x11}, \ {.tile = LINE_V_L_LOGO4, .y = 14, .x = 17}, \
{.src = 0x6037, .y = 0x0d, .x = 0x11}, \ {.tile = LINE_V_L_LOGO3, .y = 13, .x = 17}, \
{.src = 0x6036, .y = 0x0c, .x = 0x11}, \ {.tile = LINE_V_L_LOGO2, .y = 12, .x = 17}, \
{.src = 0x6035, .y = 0x0b, .x = 0x11}, {.tile = LINE_V_L_LOGO1, .y = 11, .x = 17},
#define LINESECTION_FINAL_LEFT \ #define LINESECTION_FINAL_LEFT \
{.src = 0x602c, .y = 0x0b, .x = 0x0d}, \ {.tile = LINE_H_LOGO1, .y = 11, .x = 13}, \
{.src = 0x602d, .y = 0x0b, .x = 0x0e}, {.tile = LINE_H_LOGO2, .y = 11, .x = 14},
#define LINESECTION_FINAL_RIGHT \ #define LINESECTION_FINAL_RIGHT \
{.src = 0x602f, .y = 0x0b, .x = 0x10}, \ {.tile = LINE_H_LOGO4, .y = 11, .x = 16}, \
{.src = 0x602e, .y = 0x0b, .x = 0x0f}, {.tile = LINE_H_LOGO3, .y = 11, .x = 15},
static const struct TourneyTreeLineSection sLineSectionTrainer1Round1[] = static const struct TourneyTreeLineSection sLineSectionTrainer1Round1[] =
{ {
LINESECTION_ROUND1_TRAINER1(0x6043) LINESECTION_ROUND1_TRAINER1(LINE_CORNER_R_HALF)
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer1Round2[] = static const struct TourneyTreeLineSection sLineSectionTrainer1Round2[] =
{ {
LINESECTION_ROUND1_TRAINER1(0x6023) LINESECTION_ROUND1_TRAINER1(LINE_CORNER_R)
LINESECTION_ROUND2_MATCH1(0x6043) LINESECTION_ROUND2_MATCH1(LINE_CORNER_R_HALF)
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer1Semifinal[] = static const struct TourneyTreeLineSection sLineSectionTrainer1Semifinal[] =
{ {
LINESECTION_ROUND1_TRAINER1(0x6023) LINESECTION_ROUND1_TRAINER1(LINE_CORNER_R)
LINESECTION_ROUND2_MATCH1(0x6023) LINESECTION_ROUND2_MATCH1(LINE_CORNER_R)
LINESECTION_SEMIFINAL_TOP_LEFT LINESECTION_SEMIFINAL_TOP_LEFT
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer1Final[] = static const struct TourneyTreeLineSection sLineSectionTrainer1Final[] =
{ {
LINESECTION_ROUND1_TRAINER1(0x6023) LINESECTION_ROUND1_TRAINER1(LINE_CORNER_R)
LINESECTION_ROUND2_MATCH1(0x6023) LINESECTION_ROUND2_MATCH1(LINE_CORNER_R)
LINESECTION_SEMIFINAL_TOP_LEFT LINESECTION_SEMIFINAL_TOP_LEFT
LINESECTION_FINAL_LEFT LINESECTION_FINAL_LEFT
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer9Round1[] = static const struct TourneyTreeLineSection sLineSectionTrainer9Round1[] =
{ {
LINESECTION_ROUND1_TRAINER9(0x6043) LINESECTION_ROUND1_TRAINER9(LINE_CORNER_R_HALF)
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer9Round2[] = static const struct TourneyTreeLineSection sLineSectionTrainer9Round2[] =
{ {
LINESECTION_ROUND1_TRAINER9(0x6023) LINESECTION_ROUND1_TRAINER9(LINE_CORNER_R)
LINESECTION_ROUND2_MATCH1(0x6043) LINESECTION_ROUND2_MATCH1(LINE_CORNER_R_HALF)
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer9Semifinal[] = static const struct TourneyTreeLineSection sLineSectionTrainer9Semifinal[] =
{ {
LINESECTION_ROUND1_TRAINER9(0x6023) LINESECTION_ROUND1_TRAINER9(LINE_CORNER_R)
LINESECTION_ROUND2_MATCH1(0x6023) LINESECTION_ROUND2_MATCH1(LINE_CORNER_R)
LINESECTION_SEMIFINAL_TOP_LEFT LINESECTION_SEMIFINAL_TOP_LEFT
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer9Final[] = static const struct TourneyTreeLineSection sLineSectionTrainer9Final[] =
{ {
LINESECTION_ROUND1_TRAINER9(0x6023) LINESECTION_ROUND1_TRAINER9(LINE_CORNER_R)
LINESECTION_ROUND2_MATCH1(0x6023) LINESECTION_ROUND2_MATCH1(LINE_CORNER_R)
LINESECTION_SEMIFINAL_TOP_LEFT LINESECTION_SEMIFINAL_TOP_LEFT
LINESECTION_FINAL_LEFT LINESECTION_FINAL_LEFT
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer13Round1[] = static const struct TourneyTreeLineSection sLineSectionTrainer13Round1[] =
{ {
LINESECTION_ROUND1_TRAINER13(0x6021) LINESECTION_ROUND1_TRAINER13(LINE_H)
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer13Round2[] = static const struct TourneyTreeLineSection sLineSectionTrainer13Round2[] =
{ {
LINESECTION_ROUND1_TRAINER13(0x6021) LINESECTION_ROUND1_TRAINER13(LINE_H)
LINESECTION_ROUND2_MATCH2(0x6043) LINESECTION_ROUND2_MATCH2(LINE_CORNER_R_HALF)
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer13Semifinal[] = static const struct TourneyTreeLineSection sLineSectionTrainer13Semifinal[] =
{ {
LINESECTION_ROUND1_TRAINER13(0x6021) LINESECTION_ROUND1_TRAINER13(LINE_H)
LINESECTION_ROUND2_MATCH2(0x6023) LINESECTION_ROUND2_MATCH2(LINE_CORNER_R)
LINESECTION_SEMIFINAL_TOP_LEFT LINESECTION_SEMIFINAL_TOP_LEFT
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer13Final[] = static const struct TourneyTreeLineSection sLineSectionTrainer13Final[] =
{ {
LINESECTION_ROUND1_TRAINER13(0x6021) LINESECTION_ROUND1_TRAINER13(LINE_H)
LINESECTION_ROUND2_MATCH2(0x6023) LINESECTION_ROUND2_MATCH2(LINE_CORNER_R)
LINESECTION_SEMIFINAL_TOP_LEFT LINESECTION_SEMIFINAL_TOP_LEFT
LINESECTION_FINAL_LEFT LINESECTION_FINAL_LEFT
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer5Round1[] = static const struct TourneyTreeLineSection sLineSectionTrainer5Round1[] =
{ {
LINESECTION_ROUND1_TRAINER5(0x6021) LINESECTION_ROUND1_TRAINER5(LINE_H)
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer5Round2[] = static const struct TourneyTreeLineSection sLineSectionTrainer5Round2[] =
{ {
LINESECTION_ROUND1_TRAINER5(0x6021) LINESECTION_ROUND1_TRAINER5(LINE_H)
LINESECTION_ROUND2_MATCH2(0x6043) LINESECTION_ROUND2_MATCH2(LINE_CORNER_R_HALF)
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer5Semifinal[] = static const struct TourneyTreeLineSection sLineSectionTrainer5Semifinal[] =
{ {
LINESECTION_ROUND1_TRAINER5(0x6021) LINESECTION_ROUND1_TRAINER5(LINE_H)
LINESECTION_ROUND2_MATCH2(0x6023) LINESECTION_ROUND2_MATCH2(LINE_CORNER_R)
LINESECTION_SEMIFINAL_TOP_LEFT LINESECTION_SEMIFINAL_TOP_LEFT
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer5Final[] = static const struct TourneyTreeLineSection sLineSectionTrainer5Final[] =
{ {
LINESECTION_ROUND1_TRAINER5(0x6021) LINESECTION_ROUND1_TRAINER5(LINE_H)
LINESECTION_ROUND2_MATCH2(0x6023) LINESECTION_ROUND2_MATCH2(LINE_CORNER_R)
LINESECTION_SEMIFINAL_TOP_LEFT LINESECTION_SEMIFINAL_TOP_LEFT
LINESECTION_FINAL_LEFT LINESECTION_FINAL_LEFT
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer8Round1[] = static const struct TourneyTreeLineSection sLineSectionTrainer8Round1[] =
{ {
LINESECTION_ROUND1_TRAINER8(0x6043) LINESECTION_ROUND1_TRAINER8(LINE_CORNER_R_HALF)
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer8Round2[] = static const struct TourneyTreeLineSection sLineSectionTrainer8Round2[] =
{ {
LINESECTION_ROUND1_TRAINER8(0x6023) LINESECTION_ROUND1_TRAINER8(LINE_CORNER_R)
LINESECTION_ROUND2_MATCH3(0x6021) LINESECTION_ROUND2_MATCH3(LINE_H)
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer8Semifinal[] = static const struct TourneyTreeLineSection sLineSectionTrainer8Semifinal[] =
{ {
LINESECTION_ROUND1_TRAINER8(0x6023) LINESECTION_ROUND1_TRAINER8(LINE_CORNER_R)
LINESECTION_ROUND2_MATCH3(0x6021) LINESECTION_ROUND2_MATCH3(LINE_H)
LINESECTION_SEMIFINAL_BOTTOM_LEFT LINESECTION_SEMIFINAL_BOTTOM_LEFT
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer8Final[] = static const struct TourneyTreeLineSection sLineSectionTrainer8Final[] =
{ {
LINESECTION_ROUND1_TRAINER8(0x6023) LINESECTION_ROUND1_TRAINER8(LINE_CORNER_R)
LINESECTION_ROUND2_MATCH3(0x6021) LINESECTION_ROUND2_MATCH3(LINE_H)
LINESECTION_SEMIFINAL_BOTTOM_LEFT LINESECTION_SEMIFINAL_BOTTOM_LEFT
LINESECTION_FINAL_LEFT LINESECTION_FINAL_LEFT
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer16Round1[] = static const struct TourneyTreeLineSection sLineSectionTrainer16Round1[] =
{ {
LINESECTION_ROUND1_TRAINER16(0x6043) LINESECTION_ROUND1_TRAINER16(LINE_CORNER_R_HALF)
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer16Round2[] = static const struct TourneyTreeLineSection sLineSectionTrainer16Round2[] =
{ {
LINESECTION_ROUND1_TRAINER16(0x6023) LINESECTION_ROUND1_TRAINER16(LINE_CORNER_R)
LINESECTION_ROUND2_MATCH3(0x6021) LINESECTION_ROUND2_MATCH3(LINE_H)
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer16Semifinal[] = static const struct TourneyTreeLineSection sLineSectionTrainer16Semifinal[] =
{ {
LINESECTION_ROUND1_TRAINER16(0x6023) LINESECTION_ROUND1_TRAINER16(LINE_CORNER_R)
LINESECTION_ROUND2_MATCH3(0x6021) LINESECTION_ROUND2_MATCH3(LINE_H)
LINESECTION_SEMIFINAL_BOTTOM_LEFT LINESECTION_SEMIFINAL_BOTTOM_LEFT
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer16Final[] = static const struct TourneyTreeLineSection sLineSectionTrainer16Final[] =
{ {
LINESECTION_ROUND1_TRAINER16(0x6023) LINESECTION_ROUND1_TRAINER16(LINE_CORNER_R)
LINESECTION_ROUND2_MATCH3(0x6021) LINESECTION_ROUND2_MATCH3(LINE_H)
LINESECTION_SEMIFINAL_BOTTOM_LEFT LINESECTION_SEMIFINAL_BOTTOM_LEFT
LINESECTION_FINAL_LEFT LINESECTION_FINAL_LEFT
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer12Round1[] = static const struct TourneyTreeLineSection sLineSectionTrainer12Round1[] =
{ {
LINESECTION_ROUND1_TRAINER12(0x6021) LINESECTION_ROUND1_TRAINER12(LINE_H)
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer12Round2[] = static const struct TourneyTreeLineSection sLineSectionTrainer12Round2[] =
{ {
LINESECTION_ROUND1_TRAINER12(0x6021) LINESECTION_ROUND1_TRAINER12(LINE_H)
LINESECTION_ROUND2_MATCH4(0x6021) LINESECTION_ROUND2_MATCH4(LINE_H)
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer12Semifinal[] = static const struct TourneyTreeLineSection sLineSectionTrainer12Semifinal[] =
{ {
LINESECTION_ROUND1_TRAINER12(0x6021) LINESECTION_ROUND1_TRAINER12(LINE_H)
LINESECTION_ROUND2_MATCH4(0x6021) LINESECTION_ROUND2_MATCH4(LINE_H)
LINESECTION_SEMIFINAL_BOTTOM_LEFT LINESECTION_SEMIFINAL_BOTTOM_LEFT
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer12Final[] = static const struct TourneyTreeLineSection sLineSectionTrainer12Final[] =
{ {
LINESECTION_ROUND1_TRAINER12(0x6021) LINESECTION_ROUND1_TRAINER12(LINE_H)
LINESECTION_ROUND2_MATCH4(0x6021) LINESECTION_ROUND2_MATCH4(LINE_H)
LINESECTION_SEMIFINAL_BOTTOM_LEFT LINESECTION_SEMIFINAL_BOTTOM_LEFT
LINESECTION_FINAL_LEFT LINESECTION_FINAL_LEFT
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer4Round1[] = static const struct TourneyTreeLineSection sLineSectionTrainer4Round1[] =
{ {
LINESECTION_ROUND1_TRAINER4(0x6021) LINESECTION_ROUND1_TRAINER4(LINE_H)
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer4Round2[] = static const struct TourneyTreeLineSection sLineSectionTrainer4Round2[] =
{ {
LINESECTION_ROUND1_TRAINER4(0x6021) LINESECTION_ROUND1_TRAINER4(LINE_H)
LINESECTION_ROUND2_MATCH4(0x6021) LINESECTION_ROUND2_MATCH4(LINE_H)
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer4Semifinal[] = static const struct TourneyTreeLineSection sLineSectionTrainer4Semifinal[] =
{ {
LINESECTION_ROUND1_TRAINER4(0x6021) LINESECTION_ROUND1_TRAINER4(LINE_H)
LINESECTION_ROUND2_MATCH4(0x6021) LINESECTION_ROUND2_MATCH4(LINE_H)
LINESECTION_SEMIFINAL_BOTTOM_LEFT LINESECTION_SEMIFINAL_BOTTOM_LEFT
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer4Final[] = static const struct TourneyTreeLineSection sLineSectionTrainer4Final[] =
{ {
LINESECTION_ROUND1_TRAINER4(0x6021) LINESECTION_ROUND1_TRAINER4(LINE_H)
LINESECTION_ROUND2_MATCH4(0x6021) LINESECTION_ROUND2_MATCH4(LINE_H)
LINESECTION_SEMIFINAL_BOTTOM_LEFT LINESECTION_SEMIFINAL_BOTTOM_LEFT
LINESECTION_FINAL_LEFT LINESECTION_FINAL_LEFT
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer3Round1[] = static const struct TourneyTreeLineSection sLineSectionTrainer3Round1[] =
{ {
LINESECTION_ROUND1_TRAINER3(0x6045) LINESECTION_ROUND1_TRAINER3(LINE_CORNER_L_HALF)
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer3Round2[] = static const struct TourneyTreeLineSection sLineSectionTrainer3Round2[] =
{ {
LINESECTION_ROUND1_TRAINER3(0x6025) LINESECTION_ROUND1_TRAINER3(LINE_CORNER_L)
LINESECTION_ROUND2_MATCH5(0x6045) LINESECTION_ROUND2_MATCH5(LINE_CORNER_L_HALF)
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer3Semifinal[] = static const struct TourneyTreeLineSection sLineSectionTrainer3Semifinal[] =
{ {
LINESECTION_ROUND1_TRAINER3(0x6025) LINESECTION_ROUND1_TRAINER3(LINE_CORNER_L)
LINESECTION_ROUND2_MATCH5(0x6025) LINESECTION_ROUND2_MATCH5(LINE_CORNER_L)
LINESECTION_SEMIFINAL_TOP_RIGHT LINESECTION_SEMIFINAL_TOP_RIGHT
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer3Final[] = static const struct TourneyTreeLineSection sLineSectionTrainer3Final[] =
{ {
LINESECTION_ROUND1_TRAINER3(0x6025) LINESECTION_ROUND1_TRAINER3(LINE_CORNER_L)
LINESECTION_ROUND2_MATCH5(0x6025) LINESECTION_ROUND2_MATCH5(LINE_CORNER_L)
LINESECTION_SEMIFINAL_TOP_RIGHT LINESECTION_SEMIFINAL_TOP_RIGHT
LINESECTION_FINAL_RIGHT LINESECTION_FINAL_RIGHT
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer11Round1[] = static const struct TourneyTreeLineSection sLineSectionTrainer11Round1[] =
{ {
LINESECTION_ROUND1_TRAINER11(0x6045) LINESECTION_ROUND1_TRAINER11(LINE_CORNER_L_HALF)
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer11Round2[] = static const struct TourneyTreeLineSection sLineSectionTrainer11Round2[] =
{ {
LINESECTION_ROUND1_TRAINER11(0x6025) LINESECTION_ROUND1_TRAINER11(LINE_CORNER_L)
LINESECTION_ROUND2_MATCH5(0x6045) LINESECTION_ROUND2_MATCH5(LINE_CORNER_L_HALF)
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer11Semifinal[] = static const struct TourneyTreeLineSection sLineSectionTrainer11Semifinal[] =
{ {
LINESECTION_ROUND1_TRAINER11(0x6025) LINESECTION_ROUND1_TRAINER11(LINE_CORNER_L)
LINESECTION_ROUND2_MATCH5(0x6025) LINESECTION_ROUND2_MATCH5(LINE_CORNER_L)
LINESECTION_SEMIFINAL_TOP_RIGHT LINESECTION_SEMIFINAL_TOP_RIGHT
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer11Final[] = static const struct TourneyTreeLineSection sLineSectionTrainer11Final[] =
{ {
LINESECTION_ROUND1_TRAINER11(0x6025) LINESECTION_ROUND1_TRAINER11(LINE_CORNER_L)
LINESECTION_ROUND2_MATCH5(0x6025) LINESECTION_ROUND2_MATCH5(LINE_CORNER_L)
LINESECTION_SEMIFINAL_TOP_RIGHT LINESECTION_SEMIFINAL_TOP_RIGHT
LINESECTION_FINAL_RIGHT LINESECTION_FINAL_RIGHT
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer15Round1[] = static const struct TourneyTreeLineSection sLineSectionTrainer15Round1[] =
{ {
LINESECTION_ROUND1_TRAINER15(0x6021) LINESECTION_ROUND1_TRAINER15(LINE_H)
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer15Round2[] = static const struct TourneyTreeLineSection sLineSectionTrainer15Round2[] =
{ {
LINESECTION_ROUND1_TRAINER15(0x6021) LINESECTION_ROUND1_TRAINER15(LINE_H)
LINESECTION_ROUND2_MATCH6(0x6045) LINESECTION_ROUND2_MATCH6(LINE_CORNER_L_HALF)
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer15Semifinal[] = static const struct TourneyTreeLineSection sLineSectionTrainer15Semifinal[] =
{ {
LINESECTION_ROUND1_TRAINER15(0x6021) LINESECTION_ROUND1_TRAINER15(LINE_H)
LINESECTION_ROUND2_MATCH6(0x6025) LINESECTION_ROUND2_MATCH6(LINE_CORNER_L)
LINESECTION_SEMIFINAL_TOP_RIGHT LINESECTION_SEMIFINAL_TOP_RIGHT
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer15Final[] = static const struct TourneyTreeLineSection sLineSectionTrainer15Final[] =
{ {
LINESECTION_ROUND1_TRAINER15(0x6021) LINESECTION_ROUND1_TRAINER15(LINE_H)
LINESECTION_ROUND2_MATCH6(0x6025) LINESECTION_ROUND2_MATCH6(LINE_CORNER_L)
LINESECTION_SEMIFINAL_TOP_RIGHT LINESECTION_SEMIFINAL_TOP_RIGHT
LINESECTION_FINAL_RIGHT LINESECTION_FINAL_RIGHT
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer7Round1[] = static const struct TourneyTreeLineSection sLineSectionTrainer7Round1[] =
{ {
LINESECTION_ROUND1_TRAINER7(0x6021) LINESECTION_ROUND1_TRAINER7(LINE_H)
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer7Round2[] = static const struct TourneyTreeLineSection sLineSectionTrainer7Round2[] =
{ {
LINESECTION_ROUND1_TRAINER7(0x6021) LINESECTION_ROUND1_TRAINER7(LINE_H)
LINESECTION_ROUND2_MATCH6(0x6045) LINESECTION_ROUND2_MATCH6(LINE_CORNER_L_HALF)
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer7Semifinal[] = static const struct TourneyTreeLineSection sLineSectionTrainer7Semifinal[] =
{ {
LINESECTION_ROUND1_TRAINER7(0x6021) LINESECTION_ROUND1_TRAINER7(LINE_H)
LINESECTION_ROUND2_MATCH6(0x6025) LINESECTION_ROUND2_MATCH6(LINE_CORNER_L)
LINESECTION_SEMIFINAL_TOP_RIGHT LINESECTION_SEMIFINAL_TOP_RIGHT
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer7Final[] = static const struct TourneyTreeLineSection sLineSectionTrainer7Final[] =
{ {
LINESECTION_ROUND1_TRAINER7(0x6021) LINESECTION_ROUND1_TRAINER7(LINE_H)
LINESECTION_ROUND2_MATCH6(0x6025) LINESECTION_ROUND2_MATCH6(LINE_CORNER_L)
LINESECTION_SEMIFINAL_TOP_RIGHT LINESECTION_SEMIFINAL_TOP_RIGHT
LINESECTION_FINAL_RIGHT LINESECTION_FINAL_RIGHT
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer6Round1[] = static const struct TourneyTreeLineSection sLineSectionTrainer6Round1[] =
{ {
LINESECTION_ROUND1_TRAINER6(0x6045) LINESECTION_ROUND1_TRAINER6(LINE_CORNER_L_HALF)
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer6Round2[] = static const struct TourneyTreeLineSection sLineSectionTrainer6Round2[] =
{ {
LINESECTION_ROUND1_TRAINER6(0x6025) LINESECTION_ROUND1_TRAINER6(LINE_CORNER_L)
LINESECTION_ROUND2_MATCH7(0x6021) LINESECTION_ROUND2_MATCH7(LINE_H)
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer6Semifinal[] = static const struct TourneyTreeLineSection sLineSectionTrainer6Semifinal[] =
{ {
LINESECTION_ROUND1_TRAINER6(0x6025) LINESECTION_ROUND1_TRAINER6(LINE_CORNER_L)
LINESECTION_ROUND2_MATCH7(0x6021) LINESECTION_ROUND2_MATCH7(LINE_H)
LINESECTION_SEMIFINAL_BOTTOM_RIGHT LINESECTION_SEMIFINAL_BOTTOM_RIGHT
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer6Final[] = static const struct TourneyTreeLineSection sLineSectionTrainer6Final[] =
{ {
LINESECTION_ROUND1_TRAINER6(0x6025) LINESECTION_ROUND1_TRAINER6(LINE_CORNER_L)
LINESECTION_ROUND2_MATCH7(0x6021) LINESECTION_ROUND2_MATCH7(LINE_H)
LINESECTION_SEMIFINAL_BOTTOM_RIGHT LINESECTION_SEMIFINAL_BOTTOM_RIGHT
LINESECTION_FINAL_RIGHT LINESECTION_FINAL_RIGHT
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer14Round1[] = static const struct TourneyTreeLineSection sLineSectionTrainer14Round1[] =
{ {
LINESECTION_ROUND1_TRAINER14(0x6045) LINESECTION_ROUND1_TRAINER14(LINE_CORNER_L_HALF)
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer14Round2[] = static const struct TourneyTreeLineSection sLineSectionTrainer14Round2[] =
{ {
LINESECTION_ROUND1_TRAINER14(0x6025) LINESECTION_ROUND1_TRAINER14(LINE_CORNER_L)
LINESECTION_ROUND2_MATCH7(0x6021) LINESECTION_ROUND2_MATCH7(LINE_H)
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer14Semifinal[] = static const struct TourneyTreeLineSection sLineSectionTrainer14Semifinal[] =
{ {
LINESECTION_ROUND1_TRAINER14(0x6025) LINESECTION_ROUND1_TRAINER14(LINE_CORNER_L)
LINESECTION_ROUND2_MATCH7(0x6021) LINESECTION_ROUND2_MATCH7(LINE_H)
LINESECTION_SEMIFINAL_BOTTOM_RIGHT LINESECTION_SEMIFINAL_BOTTOM_RIGHT
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer14Final[] = static const struct TourneyTreeLineSection sLineSectionTrainer14Final[] =
{ {
LINESECTION_ROUND1_TRAINER14(0x6025) LINESECTION_ROUND1_TRAINER14(LINE_CORNER_L)
LINESECTION_ROUND2_MATCH7(0x6021) LINESECTION_ROUND2_MATCH7(LINE_H)
LINESECTION_SEMIFINAL_BOTTOM_RIGHT LINESECTION_SEMIFINAL_BOTTOM_RIGHT
LINESECTION_FINAL_RIGHT LINESECTION_FINAL_RIGHT
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer10Round1[] = static const struct TourneyTreeLineSection sLineSectionTrainer10Round1[] =
{ {
LINESECTION_ROUND1_TRAINER10(0x6021) LINESECTION_ROUND1_TRAINER10(LINE_H)
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer10Round2[] = static const struct TourneyTreeLineSection sLineSectionTrainer10Round2[] =
{ {
LINESECTION_ROUND1_TRAINER10(0x6021) LINESECTION_ROUND1_TRAINER10(LINE_H)
LINESECTION_ROUND2_MATCH8(0x6021) LINESECTION_ROUND2_MATCH8(LINE_H)
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer10Semifinal[] = static const struct TourneyTreeLineSection sLineSectionTrainer10Semifinal[] =
{ {
LINESECTION_ROUND1_TRAINER10(0x6021) LINESECTION_ROUND1_TRAINER10(LINE_H)
LINESECTION_ROUND2_MATCH8(0x6021) LINESECTION_ROUND2_MATCH8(LINE_H)
LINESECTION_SEMIFINAL_BOTTOM_RIGHT LINESECTION_SEMIFINAL_BOTTOM_RIGHT
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer10Final[] = static const struct TourneyTreeLineSection sLineSectionTrainer10Final[] =
{ {
LINESECTION_ROUND1_TRAINER10(0x6021) LINESECTION_ROUND1_TRAINER10(LINE_H)
LINESECTION_ROUND2_MATCH8(0x6021) LINESECTION_ROUND2_MATCH8(LINE_H)
LINESECTION_SEMIFINAL_BOTTOM_RIGHT LINESECTION_SEMIFINAL_BOTTOM_RIGHT
LINESECTION_FINAL_RIGHT LINESECTION_FINAL_RIGHT
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer2Round1[] = static const struct TourneyTreeLineSection sLineSectionTrainer2Round1[] =
{ {
LINESECTION_ROUND1_TRAINER2(0x6021) LINESECTION_ROUND1_TRAINER2(LINE_H)
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer2Round2[] = static const struct TourneyTreeLineSection sLineSectionTrainer2Round2[] =
{ {
LINESECTION_ROUND1_TRAINER2(0x6021) LINESECTION_ROUND1_TRAINER2(LINE_H)
LINESECTION_ROUND2_MATCH8(0x6021) LINESECTION_ROUND2_MATCH8(LINE_H)
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer2Semifinal[] = static const struct TourneyTreeLineSection sLineSectionTrainer2Semifinal[] =
{ {
LINESECTION_ROUND1_TRAINER2(0x6021) LINESECTION_ROUND1_TRAINER2(LINE_H)
LINESECTION_ROUND2_MATCH8(0x6021) LINESECTION_ROUND2_MATCH8(LINE_H)
LINESECTION_SEMIFINAL_BOTTOM_RIGHT LINESECTION_SEMIFINAL_BOTTOM_RIGHT
}; };
static const struct TourneyTreeLineSection sLineSectionTrainer2Final[] = static const struct TourneyTreeLineSection sLineSectionTrainer2Final[] =
{ {
LINESECTION_ROUND1_TRAINER2(0x6021) LINESECTION_ROUND1_TRAINER2(LINE_H)
LINESECTION_ROUND2_MATCH8(0x6021) LINESECTION_ROUND2_MATCH8(LINE_H)
LINESECTION_SEMIFINAL_BOTTOM_RIGHT LINESECTION_SEMIFINAL_BOTTOM_RIGHT
LINESECTION_FINAL_RIGHT LINESECTION_FINAL_RIGHT
}; };
@ -5538,7 +5568,7 @@ static void DrawTourneyAdvancementLine(u8 tournamentId, u8 roundId)
const struct TourneyTreeLineSection *lineSection = sTourneyTreeLineSections[tournamentId][roundId]; const struct TourneyTreeLineSection *lineSection = sTourneyTreeLineSections[tournamentId][roundId];
for (i = 0; i < sTourneyTreeLineSectionArrayCounts[tournamentId][roundId]; i++) for (i = 0; i < sTourneyTreeLineSectionArrayCounts[tournamentId][roundId]; i++)
CopyToBgTilemapBufferRect_ChangePalette(1, &lineSection[i].src, lineSection[i].x, lineSection[i].y, 1, 1, 17); CopyToBgTilemapBufferRect_ChangePalette(1, &lineSection[i].tile, lineSection[i].x, lineSection[i].y, 1, 1, 17);
CopyBgTilemapBufferToVram(1); CopyBgTilemapBufferToVram(1);
} }

View File

@ -525,13 +525,13 @@ static void GenerateInitialRentalMons(void)
gFacilityTrainers = gBattleFrontierTrainers; gFacilityTrainers = gBattleFrontierTrainers;
for (i = 0; i < PARTY_SIZE; i++) for (i = 0; i < PARTY_SIZE; i++)
{ {
species[i] = 0; species[i] = SPECIES_NONE;
monIds[i] = 0; monIds[i] = 0;
heldItems[i] = 0; heldItems[i] = ITEM_NONE;
} }
lvlMode = gSaveBlock2Ptr->frontier.lvlMode; lvlMode = gSaveBlock2Ptr->frontier.lvlMode;
battleMode = VarGet(VAR_FRONTIER_BATTLE_MODE); battleMode = VarGet(VAR_FRONTIER_BATTLE_MODE);
challengeNum = gSaveBlock2Ptr->frontier.factoryWinStreaks[battleMode][lvlMode] / 7; challengeNum = gSaveBlock2Ptr->frontier.factoryWinStreaks[battleMode][lvlMode] / FRONTIER_STAGES_PER_CHALLENGE;
if (VarGet(VAR_FRONTIER_BATTLE_MODE) == FRONTIER_MODE_DOUBLES) if (VarGet(VAR_FRONTIER_BATTLE_MODE) == FRONTIER_MODE_DOUBLES)
factoryBattleMode = FRONTIER_MODE_DOUBLES; factoryBattleMode = FRONTIER_MODE_DOUBLES;
else else
@ -582,7 +582,7 @@ static void GenerateInitialRentalMons(void)
// Cannot have two same held items. // Cannot have two same held items.
for (j = firstMonId; j < firstMonId + i; j++) for (j = firstMonId; j < firstMonId + i; j++)
{ {
if (heldItems[j] != 0 && heldItems[j] == gBattleFrontierHeldItems[gFacilityTrainerMons[monId].itemTableId]) if (heldItems[j] != ITEM_NONE && heldItems[j] == gBattleFrontierHeldItems[gFacilityTrainerMons[monId].itemTableId])
{ {
if (gFacilityTrainerMons[monId].species == currSpecies) if (gFacilityTrainerMons[monId].species == currSpecies)
currSpecies = SPECIES_NONE; currSpecies = SPECIES_NONE;
@ -761,7 +761,7 @@ void FillFactoryBrainParty(void)
u8 lvlMode = gSaveBlock2Ptr->frontier.lvlMode; u8 lvlMode = gSaveBlock2Ptr->frontier.lvlMode;
u8 battleMode = VarGet(VAR_FRONTIER_BATTLE_MODE); u8 battleMode = VarGet(VAR_FRONTIER_BATTLE_MODE);
u8 challengeNum = gSaveBlock2Ptr->frontier.factoryWinStreaks[battleMode][lvlMode] / 7; u8 challengeNum = gSaveBlock2Ptr->frontier.factoryWinStreaks[battleMode][lvlMode] / FRONTIER_STAGES_PER_CHALLENGE;
fixedIV = GetFactoryMonFixedIV(challengeNum + 2, FALSE); fixedIV = GetFactoryMonFixedIV(challengeNum + 2, FALSE);
monLevel = SetFacilityPtrsGetLevel(); monLevel = SetFacilityPtrsGetLevel();
i = 0; i = 0;
@ -890,7 +890,7 @@ u32 GetAiScriptsInBattleFactory(void)
else else
{ {
int battleMode = VarGet(VAR_FRONTIER_BATTLE_MODE); int battleMode = VarGet(VAR_FRONTIER_BATTLE_MODE);
int challengeNum = gSaveBlock2Ptr->frontier.factoryWinStreaks[battleMode][lvlMode] / 7; int challengeNum = gSaveBlock2Ptr->frontier.factoryWinStreaks[battleMode][lvlMode] / FRONTIER_STAGES_PER_CHALLENGE;
if (gTrainerBattleOpponent_A == TRAINER_FRONTIER_BRAIN) if (gTrainerBattleOpponent_A == TRAINER_FRONTIER_BRAIN)
return AI_SCRIPT_CHECK_BAD_MOVE | AI_SCRIPT_TRY_TO_FAINT | AI_SCRIPT_CHECK_VIABILITY; return AI_SCRIPT_CHECK_BAD_MOVE | AI_SCRIPT_TRY_TO_FAINT | AI_SCRIPT_CHECK_VIABILITY;

View File

@ -28,6 +28,7 @@
#include "strings.h" #include "strings.h"
#include "graphics.h" #include "graphics.h"
#include "constants/battle_frontier.h" #include "constants/battle_frontier.h"
#include "constants/battle_tent.h"
#include "constants/songs.h" #include "constants/songs.h"
#include "constants/rgb.h" #include "constants/rgb.h"
@ -43,6 +44,9 @@
#define SELECTABLE_MONS_COUNT 6 #define SELECTABLE_MONS_COUNT 6
#define PALNUM_FADE_TEXT 14
#define PALNUM_TEXT 15
enum { enum {
PALTAG_BALL_GRAY = 100, PALTAG_BALL_GRAY = 100,
PALTAG_BALL_SELECTED, PALTAG_BALL_SELECTED,
@ -350,7 +354,7 @@ static const struct WindowTemplate sSelect_WindowTemplates[] =
.tilemapTop = 2, .tilemapTop = 2,
.width = 12, .width = 12,
.height = 2, .height = 2,
.paletteNum = 15, .paletteNum = PALNUM_TEXT,
.baseBlock = 0x0001, .baseBlock = 0x0001,
}, },
[SELECT_WIN_SPECIES] = { [SELECT_WIN_SPECIES] = {
@ -359,7 +363,7 @@ static const struct WindowTemplate sSelect_WindowTemplates[] =
.tilemapTop = 2, .tilemapTop = 2,
.width = 11, .width = 11,
.height = 2, .height = 2,
.paletteNum = 14, .paletteNum = PALNUM_FADE_TEXT,
.baseBlock = 0x0019, .baseBlock = 0x0019,
}, },
[SELECT_WIN_INFO] = { [SELECT_WIN_INFO] = {
@ -368,7 +372,7 @@ static const struct WindowTemplate sSelect_WindowTemplates[] =
.tilemapTop = 15, .tilemapTop = 15,
.width = 20, .width = 20,
.height = 3, .height = 3,
.paletteNum = 15, .paletteNum = PALNUM_TEXT,
.baseBlock = 0x002f, .baseBlock = 0x002f,
}, },
[SELECT_WIN_OPTIONS] = { [SELECT_WIN_OPTIONS] = {
@ -377,7 +381,7 @@ static const struct WindowTemplate sSelect_WindowTemplates[] =
.tilemapTop = 14, .tilemapTop = 14,
.width = 8, .width = 8,
.height = 6, .height = 6,
.paletteNum = 15, .paletteNum = PALNUM_TEXT,
.baseBlock = 0x006b, .baseBlock = 0x006b,
}, },
[SELECT_WIN_YES_NO] = { [SELECT_WIN_YES_NO] = {
@ -386,7 +390,7 @@ static const struct WindowTemplate sSelect_WindowTemplates[] =
.tilemapTop = 14, .tilemapTop = 14,
.width = 8, .width = 8,
.height = 4, .height = 4,
.paletteNum = 15, .paletteNum = PALNUM_TEXT,
.baseBlock = 0x009b, .baseBlock = 0x009b,
}, },
[SELECT_WIN_MON_CATEGORY] = { [SELECT_WIN_MON_CATEGORY] = {
@ -395,7 +399,7 @@ static const struct WindowTemplate sSelect_WindowTemplates[] =
.tilemapTop = 0, .tilemapTop = 0,
.width = 15, .width = 15,
.height = 2, .height = 2,
.paletteNum = 15, .paletteNum = PALNUM_TEXT,
.baseBlock = 0x00bb, .baseBlock = 0x00bb,
}, },
DUMMY_WIN_TEMPLATE, DUMMY_WIN_TEMPLATE,
@ -634,7 +638,11 @@ static const struct SpriteSheet sSwap_SpriteSheets[] =
{sMenuHighlightRight_Gfx, sizeof(sMenuHighlightRight_Gfx), GFXTAG_MENU_HIGHLIGHT_RIGHT}, {sMenuHighlightRight_Gfx, sizeof(sMenuHighlightRight_Gfx), GFXTAG_MENU_HIGHLIGHT_RIGHT},
{sActionBoxLeft_Gfx, sizeof(sActionBoxLeft_Gfx), GFXTAG_ACTION_BOX_LEFT}, {sActionBoxLeft_Gfx, sizeof(sActionBoxLeft_Gfx), GFXTAG_ACTION_BOX_LEFT},
{sActionBoxRight_Gfx, sizeof(sActionBoxRight_Gfx), GFXTAG_ACTION_BOX_RIGHT}, {sActionBoxRight_Gfx, sizeof(sActionBoxRight_Gfx), GFXTAG_ACTION_BOX_RIGHT},
{sActionHighlightLeft_Gfx, 0x100, GFXTAG_ACTION_HIGHLIGHT_LEFT}, #ifdef BUGFIX
{sActionHighlightLeft_Gfx, sizeof(sActionHighlightLeft_Gfx), GFXTAG_ACTION_HIGHLIGHT_LEFT},
#else
{sActionHighlightLeft_Gfx, 8 * TILE_SIZE_4BPP, /* Incorrect size */ GFXTAG_ACTION_HIGHLIGHT_LEFT},
#endif
{sActionHighlightMiddle_Gfx, sizeof(sActionHighlightMiddle_Gfx), GFXTAG_ACTION_HIGHLIGHT_MIDDLE}, {sActionHighlightMiddle_Gfx, sizeof(sActionHighlightMiddle_Gfx), GFXTAG_ACTION_HIGHLIGHT_MIDDLE},
{sActionHighlightRight_Gfx, sizeof(sActionHighlightRight_Gfx), GFXTAG_ACTION_HIGHLIGHT_RIGHT}, {sActionHighlightRight_Gfx, sizeof(sActionHighlightRight_Gfx), GFXTAG_ACTION_HIGHLIGHT_RIGHT},
{sMonPicBgAnim_Gfx, sizeof(sMonPicBgAnim_Gfx), GFXTAG_MON_PIC_BG_ANIM}, {sMonPicBgAnim_Gfx, sizeof(sMonPicBgAnim_Gfx), GFXTAG_MON_PIC_BG_ANIM},
@ -945,7 +953,7 @@ static const struct WindowTemplate sSwap_WindowTemplates[] =
.tilemapTop = 2, .tilemapTop = 2,
.width = 12, .width = 12,
.height = 2, .height = 2,
.paletteNum = 15, .paletteNum = PALNUM_TEXT,
.baseBlock = 0x0001, .baseBlock = 0x0001,
}, },
[SWAP_WIN_SPECIES] = { [SWAP_WIN_SPECIES] = {
@ -954,7 +962,7 @@ static const struct WindowTemplate sSwap_WindowTemplates[] =
.tilemapTop = 2, .tilemapTop = 2,
.width = 11, .width = 11,
.height = 2, .height = 2,
.paletteNum = 14, .paletteNum = PALNUM_FADE_TEXT,
.baseBlock = 0x0019, .baseBlock = 0x0019,
}, },
[SWAP_WIN_INFO] = { [SWAP_WIN_INFO] = {
@ -963,7 +971,7 @@ static const struct WindowTemplate sSwap_WindowTemplates[] =
.tilemapTop = 15, .tilemapTop = 15,
.width = 20, .width = 20,
.height = 3, .height = 3,
.paletteNum = 15, .paletteNum = PALNUM_TEXT,
.baseBlock = 0x002f, .baseBlock = 0x002f,
}, },
[SWAP_WIN_OPTIONS] = { [SWAP_WIN_OPTIONS] = {
@ -972,7 +980,7 @@ static const struct WindowTemplate sSwap_WindowTemplates[] =
.tilemapTop = 14, .tilemapTop = 14,
.width = 9, .width = 9,
.height = 6, .height = 6,
.paletteNum = 15, .paletteNum = PALNUM_TEXT,
.baseBlock = 0x006b, .baseBlock = 0x006b,
}, },
[SWAP_WIN_YES_NO] = { [SWAP_WIN_YES_NO] = {
@ -981,7 +989,7 @@ static const struct WindowTemplate sSwap_WindowTemplates[] =
.tilemapTop = 14, .tilemapTop = 14,
.width = 8, .width = 8,
.height = 4, .height = 4,
.paletteNum = 15, .paletteNum = PALNUM_TEXT,
.baseBlock = 0x00a1, .baseBlock = 0x00a1,
}, },
[SWAP_WIN_ACTION_FADE] = { [SWAP_WIN_ACTION_FADE] = {
@ -990,7 +998,7 @@ static const struct WindowTemplate sSwap_WindowTemplates[] =
.tilemapTop = 15, .tilemapTop = 15,
.width = 9, .width = 9,
.height = 5, .height = 5,
.paletteNum = 14, .paletteNum = PALNUM_FADE_TEXT,
.baseBlock = 0x006b, .baseBlock = 0x006b,
}, },
[SWAP_WIN_UNUSED] = { [SWAP_WIN_UNUSED] = {
@ -999,7 +1007,7 @@ static const struct WindowTemplate sSwap_WindowTemplates[] =
.tilemapTop = 2, .tilemapTop = 2,
.width = 4, .width = 4,
.height = 2, .height = 2,
.paletteNum = 14, .paletteNum = PALNUM_FADE_TEXT,
.baseBlock = 0x00c1, .baseBlock = 0x00c1,
}, },
[SWAP_WIN_SPECIES_AT_FADE] = { [SWAP_WIN_SPECIES_AT_FADE] = {
@ -1008,7 +1016,7 @@ static const struct WindowTemplate sSwap_WindowTemplates[] =
.tilemapTop = 2, .tilemapTop = 2,
.width = 11, .width = 11,
.height = 2, .height = 2,
.paletteNum = 15, .paletteNum = PALNUM_TEXT,
.baseBlock = 0x00c9, .baseBlock = 0x00c9,
}, },
[SWAP_WIN_MON_CATEGORY] = { [SWAP_WIN_MON_CATEGORY] = {
@ -1017,7 +1025,7 @@ static const struct WindowTemplate sSwap_WindowTemplates[] =
.tilemapTop = 0, .tilemapTop = 0,
.width = 15, .width = 15,
.height = 2, .height = 2,
.paletteNum = 15, .paletteNum = PALNUM_TEXT,
.baseBlock = 0x00df, .baseBlock = 0x00df,
}, },
DUMMY_WIN_TEMPLATE, DUMMY_WIN_TEMPLATE,
@ -1142,8 +1150,12 @@ static void CB2_InitSelectScreen(void)
gMain.state++; gMain.state++;
break; break;
case 1: case 1:
sSelectMenuTilesetBuffer = Alloc(0x440); sSelectMenuTilesetBuffer = Alloc(sizeof(gFrontierFactoryMenu_Gfx));
sSelectMonPicBgTilesetBuffer = AllocZeroed(0x440); #ifdef BUGFIX
sSelectMonPicBgTilesetBuffer = AllocZeroed(sizeof(sMonPicBg_Gfx));
#else
sSelectMonPicBgTilesetBuffer = AllocZeroed(sizeof(gFrontierFactoryMenu_Gfx)); // Incorrect size
#endif
sSelectMenuTilemapBuffer = Alloc(BG_SCREEN_SIZE); sSelectMenuTilemapBuffer = Alloc(BG_SCREEN_SIZE);
sSelectMonPicBgTilemapBuffer = AllocZeroed(BG_SCREEN_SIZE); sSelectMonPicBgTilemapBuffer = AllocZeroed(BG_SCREEN_SIZE);
ChangeBgX(0, 0, BG_COORD_SET); ChangeBgX(0, 0, BG_COORD_SET);
@ -1169,21 +1181,21 @@ static void CB2_InitSelectScreen(void)
ResetSpriteData(); ResetSpriteData();
ResetTasks(); ResetTasks();
FreeAllSpritePalettes(); FreeAllSpritePalettes();
CpuCopy16(gFrontierFactorySelectMenu_Gfx, sSelectMenuTilesetBuffer, 0x440); CpuCopy16(gFrontierFactoryMenu_Gfx, sSelectMenuTilesetBuffer, sizeof(gFrontierFactoryMenu_Gfx));
CpuCopy16(sMonPicBg_Gfx, sSelectMonPicBgTilesetBuffer, 0x60); CpuCopy16(sMonPicBg_Gfx, sSelectMonPicBgTilesetBuffer, sizeof(sMonPicBg_Gfx));
LoadBgTiles(1, sSelectMenuTilesetBuffer, 0x440, 0); LoadBgTiles(1, sSelectMenuTilesetBuffer, sizeof(gFrontierFactoryMenu_Gfx), 0);
LoadBgTiles(3, sSelectMonPicBgTilesetBuffer, 0x60, 0); LoadBgTiles(3, sSelectMonPicBgTilesetBuffer, sizeof(sMonPicBg_Gfx), 0);
CpuCopy16(gFrontierFactorySelectMenu_Tilemap, sSelectMenuTilemapBuffer, BG_SCREEN_SIZE); CpuCopy16(gFrontierFactoryMenu_Tilemap, sSelectMenuTilemapBuffer, BG_SCREEN_SIZE);
LoadBgTilemap(1, sSelectMenuTilemapBuffer, BG_SCREEN_SIZE, 0); LoadBgTilemap(1, sSelectMenuTilemapBuffer, BG_SCREEN_SIZE, 0);
LoadPalette(gFrontierFactorySelectMenu_Pal, 0, 2 * PLTT_SIZE_4BPP); LoadPalette(gFrontierFactoryMenu_Pal, 0, 2 * PLTT_SIZE_4BPP);
LoadPalette(sSelectText_Pal, BG_PLTT_ID(15), PLTT_SIZEOF(4)); LoadPalette(sSelectText_Pal, BG_PLTT_ID(PALNUM_TEXT), PLTT_SIZEOF(4));
LoadPalette(sSelectText_Pal, BG_PLTT_ID(14), PLTT_SIZEOF(5)); LoadPalette(sSelectText_Pal, BG_PLTT_ID(PALNUM_FADE_TEXT), PLTT_SIZEOF(5));
#ifdef UBFIX #ifdef UBFIX
if (sFactorySelectScreen && sFactorySelectScreen->fromSummaryScreen) if (sFactorySelectScreen && sFactorySelectScreen->fromSummaryScreen)
#else #else
if (sFactorySelectScreen->fromSummaryScreen == TRUE) if (sFactorySelectScreen->fromSummaryScreen == TRUE)
#endif #endif
gPlttBufferUnfaded[BG_PLTT_ID(14) + 4] = sFactorySelectScreen->speciesNameColorBackup; gPlttBufferUnfaded[BG_PLTT_ID(PALNUM_FADE_TEXT) + 4] = sFactorySelectScreen->speciesNameColorBackup;
LoadPalette(sMonPicBg_Pal, BG_PLTT_ID(2), PLTT_SIZEOF(2)); LoadPalette(sMonPicBg_Pal, BG_PLTT_ID(2), PLTT_SIZEOF(2));
gMain.state++; gMain.state++;
break; break;
@ -1449,7 +1461,7 @@ static void Select_Task_OpenSummaryScreen(u8 taskId)
switch (gTasks[taskId].tState) switch (gTasks[taskId].tState)
{ {
case STATE_SUMMARY_FADE: case STATE_SUMMARY_FADE:
gPlttBufferUnfaded[BG_PLTT_ID(14) + 4] = gPlttBufferFaded[BG_PLTT_ID(14) + 4]; gPlttBufferUnfaded[BG_PLTT_ID(PALNUM_FADE_TEXT) + 4] = gPlttBufferFaded[BG_PLTT_ID(PALNUM_FADE_TEXT) + 4];
BeginNormalPaletteFade(PALETTES_ALL, 0, 0, 16, RGB_BLACK); BeginNormalPaletteFade(PALETTES_ALL, 0, 0, 16, RGB_BLACK);
gTasks[taskId].tState = STATE_SUMMARY_CLEAN; gTasks[taskId].tState = STATE_SUMMARY_CLEAN;
break; break;
@ -1468,7 +1480,7 @@ static void Select_Task_OpenSummaryScreen(u8 taskId)
} }
break; break;
case STATE_SUMMARY_SHOW: case STATE_SUMMARY_SHOW:
sFactorySelectScreen->speciesNameColorBackup = gPlttBufferUnfaded[BG_PLTT_ID(14) + 4]; sFactorySelectScreen->speciesNameColorBackup = gPlttBufferUnfaded[BG_PLTT_ID(PALNUM_FADE_TEXT) + 4];
DestroyTask(taskId); DestroyTask(taskId);
sFactorySelectScreen->fromSummaryScreen = TRUE; sFactorySelectScreen->fromSummaryScreen = TRUE;
currMonId = sFactorySelectScreen->cursorPos; currMonId = sFactorySelectScreen->cursorPos;
@ -1641,8 +1653,8 @@ static void Select_Task_HandleMenu(u8 taskId)
{ {
if (sFactorySelectScreen->fromSummaryScreen == TRUE) if (sFactorySelectScreen->fromSummaryScreen == TRUE)
{ {
gPlttBufferFaded[BG_PLTT_ID(14) + 4] = sFactorySelectScreen->speciesNameColorBackup; gPlttBufferFaded[BG_PLTT_ID(PALNUM_FADE_TEXT) + 4] = sFactorySelectScreen->speciesNameColorBackup;
gPlttBufferUnfaded[BG_PLTT_ID(14) + 4] = gPlttBufferUnfaded[BG_PLTT_ID(15) + 4]; gPlttBufferUnfaded[BG_PLTT_ID(PALNUM_FADE_TEXT) + 4] = gPlttBufferUnfaded[BG_PLTT_ID(PALNUM_TEXT) + 4];
} }
sFactorySelectScreen->fromSummaryScreen = FALSE; sFactorySelectScreen->fromSummaryScreen = FALSE;
gTasks[taskId].tState = STATE_MENU_HANDLE_INPUT; gTasks[taskId].tState = STATE_MENU_HANDLE_INPUT;
@ -1735,9 +1747,9 @@ static void CreateFrontierFactorySelectableMons(u8 firstMonId)
gFacilityTrainerMons = gBattleFrontierMons; gFacilityTrainerMons = gBattleFrontierMons;
if (gSaveBlock2Ptr->frontier.lvlMode != FRONTIER_LVL_50) if (gSaveBlock2Ptr->frontier.lvlMode != FRONTIER_LVL_50)
level = 100; level = FRONTIER_MAX_LEVEL_OPEN;
else else
level = 50; level = FRONTIER_MAX_LEVEL_50;
rentalRank = GetNumPastRentalsRank(battleMode, lvlMode); rentalRank = GetNumPastRentalsRank(battleMode, lvlMode);
otId = T1_READ_32(gSaveBlock2Ptr->playerTrainerId); otId = T1_READ_32(gSaveBlock2Ptr->playerTrainerId);
@ -1769,7 +1781,7 @@ static void CreateSlateportTentSelectableMons(u8 firstMonId)
{ {
u8 i, j; u8 i, j;
u8 ivs = 0; u8 ivs = 0;
u8 level = 30; u8 level = TENT_MIN_LEVEL;
u8 friendship = 0; u8 friendship = 0;
u32 otId = 0; u32 otId = 0;
@ -1993,7 +2005,7 @@ static void Select_PrintMonCategory(void)
FillWindowPixelBuffer(SELECT_WIN_MON_CATEGORY, PIXEL_FILL(0)); FillWindowPixelBuffer(SELECT_WIN_MON_CATEGORY, PIXEL_FILL(0));
species = GetMonData(&sFactorySelectScreen->mons[monId].monData, MON_DATA_SPECIES, NULL); species = GetMonData(&sFactorySelectScreen->mons[monId].monData, MON_DATA_SPECIES, NULL);
CopyMonCategoryText(SpeciesToNationalPokedexNum(species), text); CopyMonCategoryText(SpeciesToNationalPokedexNum(species), text);
x = GetStringRightAlignXOffset(FONT_NORMAL, text, 0x76); x = GetStringRightAlignXOffset(FONT_NORMAL, text, 118);
AddTextPrinterParameterized(SELECT_WIN_MON_CATEGORY, FONT_NORMAL, text, x, 1, 0, NULL); AddTextPrinterParameterized(SELECT_WIN_MON_CATEGORY, FONT_NORMAL, text, x, 1, 0, NULL);
CopyWindowToVram(SELECT_WIN_MON_CATEGORY, COPYWIN_GFX); CopyWindowToVram(SELECT_WIN_MON_CATEGORY, COPYWIN_GFX);
} }
@ -2290,7 +2302,7 @@ static void Select_Task_FadeSpeciesName(u8 taskId)
else else
sFactorySelectScreen->fadeSpeciesNameCoeff++; sFactorySelectScreen->fadeSpeciesNameCoeff++;
} }
BlendPalettes(0x4000, sFactorySelectScreen->fadeSpeciesNameCoeff, 0); BlendPalettes(1 << PALNUM_FADE_TEXT, sFactorySelectScreen->fadeSpeciesNameCoeff, 0);
if (sFactorySelectScreen->fadeSpeciesNameCoeff > 5) if (sFactorySelectScreen->fadeSpeciesNameCoeff > 5)
{ {
sFactorySelectScreen->fadeSpeciesNameFadeOut = FALSE; sFactorySelectScreen->fadeSpeciesNameFadeOut = FALSE;
@ -2388,7 +2400,7 @@ static void Swap_Task_OpenSummaryScreen(u8 taskId)
case STATE_SUMMARY_SHOW: case STATE_SUMMARY_SHOW:
DestroyTask(taskId); DestroyTask(taskId);
sFactorySwapScreen->fromSummaryScreen = TRUE; sFactorySwapScreen->fromSummaryScreen = TRUE;
sFactorySwapScreen->speciesNameColorBackup = gPlttBufferUnfaded[BG_PLTT_ID(15) + 4]; sFactorySwapScreen->speciesNameColorBackup = gPlttBufferUnfaded[BG_PLTT_ID(PALNUM_TEXT) + 4];
ShowPokemonSummaryScreen(SUMMARY_MODE_NORMAL, gPlayerParty, sFactorySwapScreen->cursorPos, FRONTIER_PARTY_SIZE - 1, CB2_InitSwapScreen); ShowPokemonSummaryScreen(SUMMARY_MODE_NORMAL, gPlayerParty, sFactorySwapScreen->cursorPos, FRONTIER_PARTY_SIZE - 1, CB2_InitSwapScreen);
break; break;
} }
@ -2709,7 +2721,7 @@ static void Swap_Task_FadeSpeciesName(u8 taskId)
else else
sFactorySwapScreen->fadeSpeciesNameCoeff++; sFactorySwapScreen->fadeSpeciesNameCoeff++;
} }
BlendPalettes(0x4000, sFactorySwapScreen->fadeSpeciesNameCoeff, 0); BlendPalettes(1 << PALNUM_FADE_TEXT, sFactorySwapScreen->fadeSpeciesNameCoeff, 0);
if (sFactorySwapScreen->fadeSpeciesNameCoeff > 5) if (sFactorySwapScreen->fadeSpeciesNameCoeff > 5)
{ {
sFactorySwapScreen->fadeSpeciesNameFadeOut = FALSE; sFactorySwapScreen->fadeSpeciesNameFadeOut = FALSE;
@ -2748,7 +2760,7 @@ static void Swap_Task_FadeOutSpeciesName(u8 taskId)
gTasks[taskId].tState++; gTasks[taskId].tState++;
break; break;
case 1: case 1:
LoadPalette(&gPlttBufferUnfaded[BG_PLTT_ID(15)], BG_PLTT_ID(14), PLTT_SIZEOF(5)); LoadPalette(&gPlttBufferUnfaded[BG_PLTT_ID(PALNUM_TEXT)], BG_PLTT_ID(PALNUM_FADE_TEXT), PLTT_SIZEOF(5));
gTasks[taskId].tState++; gTasks[taskId].tState++;
break; break;
case 2: case 2:
@ -2761,10 +2773,10 @@ static void Swap_Task_FadeOutSpeciesName(u8 taskId)
if (sFactorySwapScreen->fadeSpeciesNameCoeffDelay > 3) if (sFactorySwapScreen->fadeSpeciesNameCoeffDelay > 3)
{ {
sFactorySwapScreen->fadeSpeciesNameCoeffDelay = 0; sFactorySwapScreen->fadeSpeciesNameCoeffDelay = 0;
gPlttBufferUnfaded[BG_PLTT_ID(15) + 4] = gPlttBufferFaded[BG_PLTT_ID(14) + 4]; gPlttBufferUnfaded[BG_PLTT_ID(PALNUM_TEXT) + 4] = gPlttBufferFaded[BG_PLTT_ID(PALNUM_FADE_TEXT) + 4];
sFactorySwapScreen->fadeSpeciesNameCoeff++; sFactorySwapScreen->fadeSpeciesNameCoeff++;
} }
BlendPalettes(0x4000, sFactorySwapScreen->fadeSpeciesNameCoeff, 0); BlendPalettes(1 << PALNUM_FADE_TEXT, sFactorySwapScreen->fadeSpeciesNameCoeff, 0);
break; break;
} }
} }
@ -2994,7 +3006,7 @@ static void Swap_Task_ScreenInfoTransitionOut(u8 taskId)
switch (gTasks[taskId].tState) switch (gTasks[taskId].tState)
{ {
case 0: case 0:
LoadPalette(sSwapText_Pal, BG_PLTT_ID(14), sizeof(sSwapText_Pal)); LoadPalette(sSwapText_Pal, BG_PLTT_ID(PALNUM_FADE_TEXT), sizeof(sSwapText_Pal));
Swap_PrintActionStrings(); Swap_PrintActionStrings();
PutWindowTilemap(SWAP_WIN_ACTION_FADE); PutWindowTilemap(SWAP_WIN_ACTION_FADE);
gTasks[taskId].tState++; gTasks[taskId].tState++;
@ -3004,7 +3016,7 @@ static void Swap_Task_ScreenInfoTransitionOut(u8 taskId)
gTasks[taskId].tState++; gTasks[taskId].tState++;
break; break;
case 2: case 2:
BeginNormalPaletteFade(0x4000, 0, 0, 16, sPokeballGray_Pal[37]); BeginNormalPaletteFade(1 << PALNUM_FADE_TEXT, 0, 0, 16, sPokeballGray_Pal[37]);
gTasks[taskId].tState++; gTasks[taskId].tState++;
break; break;
case 3: case 3:
@ -3125,14 +3137,14 @@ static void Swap_Task_ScreenInfoTransitionIn(u8 taskId)
if (gTasks[taskId].tSlideFinishedPkmn == TRUE if (gTasks[taskId].tSlideFinishedPkmn == TRUE
&& gTasks[taskId].tSlideFinishedCancel == TRUE) && gTasks[taskId].tSlideFinishedCancel == TRUE)
{ {
gPlttBufferFaded[BG_PLTT_ID(14) + 2] = sPokeballGray_Pal[37]; gPlttBufferFaded[BG_PLTT_ID(PALNUM_FADE_TEXT) + 2] = sPokeballGray_Pal[37];
Swap_PrintActionStrings(); Swap_PrintActionStrings();
PutWindowTilemap(SWAP_WIN_ACTION_FADE); PutWindowTilemap(SWAP_WIN_ACTION_FADE);
gTasks[taskId].tState++; gTasks[taskId].tState++;
} }
break; break;
case 3: case 3:
BeginNormalPaletteFade(0x4000, 0, 16, 0, sPokeballGray_Pal[37]); BeginNormalPaletteFade(1 << PALNUM_FADE_TEXT, 0, 16, 0, sPokeballGray_Pal[37]);
gTasks[taskId].tState++; gTasks[taskId].tState++;
break; break;
case 4: case 4:
@ -3275,8 +3287,12 @@ static void CB2_InitSwapScreen(void)
gMain.state++; gMain.state++;
break; break;
case 1: case 1:
sSwapMenuTilesetBuffer = Alloc(0x440); sSwapMenuTilesetBuffer = Alloc(sizeof(gFrontierFactoryMenu_Gfx));
sSwapMonPicBgTilesetBuffer = AllocZeroed(0x440); #ifdef BUGFIX
sSwapMonPicBgTilesetBuffer = AllocZeroed(sizeof(sMonPicBg_Gfx));
#else
sSwapMonPicBgTilesetBuffer = AllocZeroed(sizeof(gFrontierFactoryMenu_Gfx)); // Incorrect size
#endif
sSwapMenuTilemapBuffer = Alloc(BG_SCREEN_SIZE); sSwapMenuTilemapBuffer = Alloc(BG_SCREEN_SIZE);
sSwapMonPicBgTilemapBuffer = AllocZeroed(BG_SCREEN_SIZE); sSwapMonPicBgTilemapBuffer = AllocZeroed(BG_SCREEN_SIZE);
ChangeBgX(0, 0, BG_COORD_SET); ChangeBgX(0, 0, BG_COORD_SET);
@ -3303,15 +3319,15 @@ static void CB2_InitSwapScreen(void)
ResetTasks(); ResetTasks();
FreeAllSpritePalettes(); FreeAllSpritePalettes();
ResetAllPicSprites(); ResetAllPicSprites();
CpuCopy16(gFrontierFactorySelectMenu_Gfx, sSwapMenuTilesetBuffer, 0x440); CpuCopy16(gFrontierFactoryMenu_Gfx, sSwapMenuTilesetBuffer, sizeof(gFrontierFactoryMenu_Gfx));
CpuCopy16(sMonPicBg_Gfx, sSwapMonPicBgTilesetBuffer, 0x60); CpuCopy16(sMonPicBg_Gfx, sSwapMonPicBgTilesetBuffer, sizeof(sMonPicBg_Gfx));
LoadBgTiles(1, sSwapMenuTilesetBuffer, 0x440, 0); LoadBgTiles(1, sSwapMenuTilesetBuffer, sizeof(gFrontierFactoryMenu_Gfx), 0);
LoadBgTiles(3, sSwapMonPicBgTilesetBuffer, 0x60, 0); LoadBgTiles(3, sSwapMonPicBgTilesetBuffer, sizeof(sMonPicBg_Gfx), 0);
CpuCopy16(gFrontierFactorySelectMenu_Tilemap, sSwapMenuTilemapBuffer, BG_SCREEN_SIZE); CpuCopy16(gFrontierFactoryMenu_Tilemap, sSwapMenuTilemapBuffer, BG_SCREEN_SIZE);
LoadBgTilemap(1, sSwapMenuTilemapBuffer, BG_SCREEN_SIZE, 0); LoadBgTilemap(1, sSwapMenuTilemapBuffer, BG_SCREEN_SIZE, 0);
LoadPalette(gFrontierFactorySelectMenu_Pal, 0, 2 * PLTT_SIZE_4BPP); LoadPalette(gFrontierFactoryMenu_Pal, 0, 2 * PLTT_SIZE_4BPP);
LoadPalette(sSwapText_Pal, BG_PLTT_ID(15), sizeof(sSwapText_Pal)); LoadPalette(sSwapText_Pal, BG_PLTT_ID(PALNUM_TEXT), sizeof(sSwapText_Pal));
LoadPalette(sSwapText_Pal, BG_PLTT_ID(14), sizeof(sSwapText_Pal)); LoadPalette(sSwapText_Pal, BG_PLTT_ID(PALNUM_FADE_TEXT), sizeof(sSwapText_Pal));
LoadPalette(sMonPicBg_Pal, BG_PLTT_ID(2), PLTT_SIZEOF(2)); LoadPalette(sMonPicBg_Pal, BG_PLTT_ID(2), PLTT_SIZEOF(2));
gMain.state++; gMain.state++;
break; break;
@ -3808,7 +3824,7 @@ static void Swap_PrintYesNoOptions(void)
static void Swap_PrintActionString(const u8 *str, u32 y, u32 windowId) static void Swap_PrintActionString(const u8 *str, u32 y, u32 windowId)
{ {
s32 x = GetStringRightAlignXOffset(FONT_SMALL, str, 0x46); s32 x = GetStringRightAlignXOffset(FONT_SMALL, str, 70);
AddTextPrinterParameterized3(windowId, FONT_SMALL, x, y, sSwapMenuOptionsTextColors, 0, str); AddTextPrinterParameterized3(windowId, FONT_SMALL, x, y, sSwapMenuOptionsTextColors, 0, str);
} }
@ -3864,10 +3880,10 @@ static void Swap_PrintMonSpeciesAtFade(void)
CpuCopy16(sSwapText_Pal, pal, 8); CpuCopy16(sSwapText_Pal, pal, 8);
if (!sFactorySwapScreen->fromSummaryScreen) if (!sFactorySwapScreen->fromSummaryScreen)
pal[4] = gPlttBufferFaded[BG_PLTT_ID(14) + 4]; pal[4] = gPlttBufferFaded[BG_PLTT_ID(PALNUM_FADE_TEXT) + 4];
else else
pal[4] = sFactorySwapScreen->speciesNameColorBackup; pal[4] = sFactorySwapScreen->speciesNameColorBackup;
LoadPalette(pal, BG_PLTT_ID(15), sizeof(sSwapText_Pal)); LoadPalette(pal, BG_PLTT_ID(PALNUM_TEXT), sizeof(sSwapText_Pal));
PutWindowTilemap(SWAP_WIN_SPECIES_AT_FADE); PutWindowTilemap(SWAP_WIN_SPECIES_AT_FADE);
FillWindowPixelBuffer(SWAP_WIN_SPECIES_AT_FADE, PIXEL_FILL(0)); FillWindowPixelBuffer(SWAP_WIN_SPECIES_AT_FADE, PIXEL_FILL(0));
@ -3895,8 +3911,8 @@ static void Swap_PrintMonSpeciesForTransition(void)
u16 species; u16 species;
u8 x; u8 x;
LoadPalette(sSwapText_Pal, BG_PLTT_ID(14), sizeof(sSwapText_Pal)); LoadPalette(sSwapText_Pal, BG_PLTT_ID(PALNUM_FADE_TEXT), sizeof(sSwapText_Pal));
CpuCopy16(&gPlttBufferUnfaded[BG_PLTT_ID(15)], &gPlttBufferFaded[BG_PLTT_ID(14)], PLTT_SIZEOF(5)); CpuCopy16(&gPlttBufferUnfaded[BG_PLTT_ID(PALNUM_TEXT)], &gPlttBufferFaded[BG_PLTT_ID(PALNUM_FADE_TEXT)], PLTT_SIZEOF(5));
if (sFactorySwapScreen->cursorPos >= FRONTIER_PARTY_SIZE) if (sFactorySwapScreen->cursorPos >= FRONTIER_PARTY_SIZE)
{ {
@ -3936,7 +3952,7 @@ static void Swap_PrintMonCategory(void)
else else
species = GetMonData(&gEnemyParty[monId], MON_DATA_SPECIES, NULL); species = GetMonData(&gEnemyParty[monId], MON_DATA_SPECIES, NULL);
CopyMonCategoryText(SpeciesToNationalPokedexNum(species), text); CopyMonCategoryText(SpeciesToNationalPokedexNum(species), text);
x = GetStringRightAlignXOffset(FONT_NORMAL, text, 0x76); x = GetStringRightAlignXOffset(FONT_NORMAL, text, 118);
AddTextPrinterParameterized(SWAP_WIN_MON_CATEGORY, FONT_NORMAL, text, x, 1, 0, NULL); AddTextPrinterParameterized(SWAP_WIN_MON_CATEGORY, FONT_NORMAL, text, x, 1, 0, NULL);
CopyWindowToVram(SWAP_WIN_MON_CATEGORY, COPYWIN_GFX); CopyWindowToVram(SWAP_WIN_MON_CATEGORY, COPYWIN_GFX);
} }

View File

@ -1267,6 +1267,10 @@ static void TryHealMons(u8 healCount)
for (i = 0; i < FRONTIER_PARTY_SIZE; i++) for (i = 0; i < FRONTIER_PARTY_SIZE; i++)
indices[i] = i; indices[i] = i;
// Only 'healCount' number of pokemon will be healed.
// The order in which they're (attempted to be) healed is random,
// and determined by performing 10 random swaps to this index array.
for (k = 0; k < 10; k++) for (k = 0; k < 10; k++)
{ {
u8 temp; u8 temp;
@ -1423,6 +1427,7 @@ static void PrepareTwoTrainers(void)
gFacilityTrainers = gBattleFrontierTrainers; gFacilityTrainers = gBattleFrontierTrainers;
do do
{ {
// Pick the 1st trainer, making sure it's not one that's been encountered yet in this challenge.
trainerId = GetRandomScaledFrontierTrainerId(challengeNum, 1); trainerId = GetRandomScaledFrontierTrainerId(challengeNum, 1);
for (i = 0; i < gSaveBlock2Ptr->frontier.curChallengeBattleNum - 1; i++) for (i = 0; i < gSaveBlock2Ptr->frontier.curChallengeBattleNum - 1; i++)
{ {
@ -1438,6 +1443,7 @@ static void PrepareTwoTrainers(void)
do do
{ {
// Pick the 2nd trainer, making sure it's not one that's been encountered yet in this challenge.
trainerId = GetRandomScaledFrontierTrainerId(challengeNum, 1); trainerId = GetRandomScaledFrontierTrainerId(challengeNum, 1);
for (i = 0; i < gSaveBlock2Ptr->frontier.curChallengeBattleNum; i++) for (i = 0; i < gSaveBlock2Ptr->frontier.curChallengeBattleNum; i++)
{ {

View File

@ -38,6 +38,8 @@
#include "constants/moves.h" #include "constants/moves.h"
#include "constants/trainers.h" #include "constants/trainers.h"
#define NUM_LAYOUT_OFFSETS 8 // Assumed to be a power of 2
extern const struct MapLayout *const gMapLayouts[]; extern const struct MapLayout *const gMapLayouts[];
struct PyramidWildMon struct PyramidWildMon
@ -55,7 +57,7 @@ struct PyramidFloorTemplate
u8 itemPositions; u8 itemPositions;
u8 trainerPositions; u8 trainerPositions;
u8 runMultiplier; u8 runMultiplier;
u8 layoutOffsets[8]; u8 layoutOffsets[NUM_LAYOUT_OFFSETS];
}; };
struct PyramidTrainerEncounterMusic struct PyramidTrainerEncounterMusic
@ -1902,7 +1904,7 @@ static void GetPyramidFloorLayoutOffsets(u8 *layoutOffsets)
for (i = 0; i < NUM_PYRAMID_FLOOR_SQUARES; i++) for (i = 0; i < NUM_PYRAMID_FLOOR_SQUARES; i++)
{ {
layoutOffsets[i] = sPyramidFloorTemplates[id].layoutOffsets[rand & 0x7]; layoutOffsets[i] = sPyramidFloorTemplates[id].layoutOffsets[rand & (NUM_LAYOUT_OFFSETS - 1)];
rand >>= 3; rand >>= 3;
if (i == 7) if (i == 7)
{ {

View File

@ -3175,7 +3175,7 @@ void CalcApprenticeChecksum(struct Apprentice *apprentice)
s32 i; s32 i;
apprentice->checksum = 0; apprentice->checksum = 0;
for (i = 0; i < (sizeof(struct Apprentice) - 4) / 4; i++) for (i = 0; i < offsetof(struct Apprentice, checksum) / sizeof(u32); i++)
apprentice->checksum += ((u32 *)apprentice)[i]; apprentice->checksum += ((u32 *)apprentice)[i];
} }
@ -3183,7 +3183,7 @@ static void ClearApprentice(struct Apprentice *apprentice)
{ {
s32 i; s32 i;
for (i = 0; i < (sizeof(struct Apprentice)) / 4; i++) for (i = 0; i < sizeof(struct Apprentice) / sizeof(u32); i++)
((u32 *)apprentice)[i] = 0; ((u32 *)apprentice)[i] = 0;
ResetApprenticeStruct(apprentice); ResetApprenticeStruct(apprentice);
} }
@ -3196,7 +3196,7 @@ static void ValidateApprenticesChecksums(void)
{ {
u32 *data = (u32 *) &gSaveBlock2Ptr->apprentices[i]; u32 *data = (u32 *) &gSaveBlock2Ptr->apprentices[i];
u32 checksum = 0; u32 checksum = 0;
for (j = 0; j < (sizeof(struct Apprentice) - 4) / 4; j++) for (j = 0; j < offsetof(struct Apprentice, checksum) / sizeof(u32); j++)
checksum += data[j]; checksum += data[j];
if (gSaveBlock2Ptr->apprentices[i].checksum != checksum) if (gSaveBlock2Ptr->apprentices[i].checksum != checksum)
ClearApprentice(&gSaveBlock2Ptr->apprentices[i]); ClearApprentice(&gSaveBlock2Ptr->apprentices[i]);
@ -3506,7 +3506,7 @@ bool32 ValidateBattleTowerRecord(u8 recordId) // unused
u32 *record = (u32 *)(&gSaveBlock2Ptr->frontier.towerRecords[recordId]); u32 *record = (u32 *)(&gSaveBlock2Ptr->frontier.towerRecords[recordId]);
u32 checksum = 0; u32 checksum = 0;
u32 hasData = 0; u32 hasData = 0;
for (i = 0; i < (sizeof(struct EmeraldBattleTowerRecord) - 4) / 4; i++) // - 4, because of the last fjeld bejng the checksum jtself. for (i = 0; i < offsetof(struct EmeraldBattleTowerRecord, checksum) / sizeof(u32); i++)
{ {
checksum += record[i]; checksum += record[i];
hasData |= record[i]; hasData |= record[i];

View File

@ -57,7 +57,6 @@
#include "constants/heal_locations.h" #include "constants/heal_locations.h"
#include "constants/map_types.h" #include "constants/map_types.h"
#include "constants/mystery_gift.h" #include "constants/mystery_gift.h"
#include "constants/script_menu.h"
#include "constants/slot_machine.h" #include "constants/slot_machine.h"
#include "constants/songs.h" #include "constants/songs.h"
#include "constants/moves.h" #include "constants/moves.h"

View File

@ -698,8 +698,8 @@ static const u8 *const sRecordsWindowChallengeTexts[][2] =
static const u8 *const sLevelModeText[] = static const u8 *const sLevelModeText[] =
{ {
gText_RecordsLv50, [FRONTIER_LVL_50] = gText_RecordsLv50,
gText_RecordsOpenLevel, [FRONTIER_LVL_OPEN] = gText_RecordsOpenLevel,
}; };
static const u8 *const sHallFacilityToRecordsText[] = static const u8 *const sHallFacilityToRecordsText[] =

View File

@ -955,7 +955,7 @@ const u32 gDomeTourneyInfoCard_Gfx[] = INCBIN_U32("graphics/battle_frontier/tour
const u32 gDomeTourneyInfoCard_Tilemap[] = INCBIN_U32("graphics/battle_frontier/tourney_info_card_tilemap.bin.lz"); const u32 gDomeTourneyInfoCard_Tilemap[] = INCBIN_U32("graphics/battle_frontier/tourney_info_card_tilemap.bin.lz");
const u32 gDomeTourneyInfoCardBg_Tilemap[] = INCBIN_U32("graphics/battle_frontier/tourney_info_card_bg.bin.lz"); const u32 gDomeTourneyInfoCardBg_Tilemap[] = INCBIN_U32("graphics/battle_frontier/tourney_info_card_bg.bin.lz");
const u32 gDomeTourneyTreeButtons_Gfx[] = INCBIN_U32("graphics/battle_frontier/tourney_buttons.4bpp.lz"); // exit/cancel and pokeball buttons const u32 gDomeTourneyTreeButtons_Gfx[] = INCBIN_U32("graphics/battle_frontier/tourney_buttons.4bpp.lz"); // exit/cancel and pokeball buttons
const u32 gDomeTourneyTree_Pal[] = INCBIN_U32("graphics/battle_frontier/tourney.gbapal.lz"); const u32 gDomeTourneyTree_Pal[] = INCBIN_U32("graphics/battle_frontier/tourney_tree.gbapal.lz");
const u32 gDomeTourneyTreeButtons_Pal[] = INCBIN_U32("graphics/battle_frontier/tourney_buttons.gbapal.lz"); const u32 gDomeTourneyTreeButtons_Pal[] = INCBIN_U32("graphics/battle_frontier/tourney_buttons.gbapal.lz");
const u32 gDomeTourneyMatchCardBg_Pal[] = INCBIN_U32("graphics/battle_frontier/tourney_match_card_bg.gbapal.lz"); const u32 gDomeTourneyMatchCardBg_Pal[] = INCBIN_U32("graphics/battle_frontier/tourney_match_card_bg.gbapal.lz");
@ -1216,13 +1216,9 @@ const u32 gRouletteMultiplier_Gfx[] = INCBIN_U32("graphics/roulette/multiplier.4
#include "data/graphics/mail.h" #include "data/graphics/mail.h"
const u16 gFrontierFactorySelectMenu_Pal[] = INCBIN_U16("graphics/battle_frontier/factory_menu1.gbapal"); const u16 gFrontierFactoryMenu_Pal[] = INCBIN_U16("graphics/battle_frontier/factory_screen/menu.gbapal");
const u16 gFrontierFactorySelectMenu_Pal2[] = INCBIN_U16("graphics/battle_frontier/factory_menu2.gbapal"); const u16 gFrontierFactoryMenu_Gfx[] = INCBIN_U16("graphics/battle_frontier/factory_screen/menu.4bpp");
const u16 gFrontierFactoryMenu_Tilemap[] = INCBIN_U16("graphics/battle_frontier/factory_screen/menu.bin");
const u16 gFrontierFactorySelectMenu_Gfx[] = INCBIN_U16("graphics/battle_frontier/factory_menu1.4bpp");
const u16 gFrontierFactorySelectMenu_Gfx2[] = INCBIN_U16("graphics/battle_frontier/factory_menu2.4bpp");
const u16 gFrontierFactorySelectMenu_Tilemap[] = INCBIN_U16("graphics/battle_frontier/factory_menu.bin");
const u32 gFrontierPassMedals_Gfx[] = INCBIN_U32("graphics/frontier_pass/medals.4bpp.lz"); const u32 gFrontierPassMedals_Gfx[] = INCBIN_U32("graphics/frontier_pass/medals.4bpp.lz");

View File

@ -137,7 +137,15 @@ static void Task_SaveAfterLinkBattle(u8 taskId);
static void Task_WaitForBattleTowerLinkSave(u8 taskId); static void Task_WaitForBattleTowerLinkSave(u8 taskId);
static bool8 FieldCB_ReturnToFieldStartMenu(void); static bool8 FieldCB_ReturnToFieldStartMenu(void);
static const struct WindowTemplate sSafariBallsWindowTemplate = {0, 1, 1, 9, 4, 0xF, 8}; static const struct WindowTemplate sWindowTemplate_SafariBalls = {
.bg = 0,
.tilemapLeft = 1,
.tilemapTop = 1,
.width = 9,
.height = 4,
.paletteNum = 15,
.baseBlock = 0x8
};
static const u8 *const sPyramidFloorNames[FRONTIER_STAGES_PER_CHALLENGE + 1] = static const u8 *const sPyramidFloorNames[FRONTIER_STAGES_PER_CHALLENGE + 1] =
{ {
@ -151,8 +159,25 @@ static const u8 *const sPyramidFloorNames[FRONTIER_STAGES_PER_CHALLENGE + 1] =
gText_Peak gText_Peak
}; };
static const struct WindowTemplate sPyramidFloorWindowTemplate_2 = {0, 1, 1, 0xA, 4, 0xF, 8}; static const struct WindowTemplate sWindowTemplate_PyramidFloor = {
static const struct WindowTemplate sPyramidFloorWindowTemplate_1 = {0, 1, 1, 0xC, 4, 0xF, 8}; .bg = 0,
.tilemapLeft = 1,
.tilemapTop = 1,
.width = 10,
.height = 4,
.paletteNum = 15,
.baseBlock = 0x8
};
static const struct WindowTemplate sWindowTemplate_PyramidPeak = {
.bg = 0,
.tilemapLeft = 1,
.tilemapTop = 1,
.width = 12,
.height = 4,
.paletteNum = 15,
.baseBlock = 0x8
};
static const struct MenuAction sStartMenuItems[] = static const struct MenuAction sStartMenuItems[] =
{ {
@ -382,7 +407,7 @@ static void BuildMultiPartnerRoomStartMenu(void)
static void ShowSafariBallsWindow(void) static void ShowSafariBallsWindow(void)
{ {
sSafariBallsWindowId = AddWindow(&sSafariBallsWindowTemplate); sSafariBallsWindowId = AddWindow(&sWindowTemplate_SafariBalls);
PutWindowTilemap(sSafariBallsWindowId); PutWindowTilemap(sSafariBallsWindowId);
DrawStdWindowFrame(sSafariBallsWindowId, FALSE); DrawStdWindowFrame(sSafariBallsWindowId, FALSE);
ConvertIntToDecimalStringN(gStringVar1, gNumSafariBalls, STR_CONV_MODE_RIGHT_ALIGN, 2); ConvertIntToDecimalStringN(gStringVar1, gNumSafariBalls, STR_CONV_MODE_RIGHT_ALIGN, 2);
@ -394,9 +419,9 @@ static void ShowSafariBallsWindow(void)
static void ShowPyramidFloorWindow(void) static void ShowPyramidFloorWindow(void)
{ {
if (gSaveBlock2Ptr->frontier.curChallengeBattleNum == FRONTIER_STAGES_PER_CHALLENGE) if (gSaveBlock2Ptr->frontier.curChallengeBattleNum == FRONTIER_STAGES_PER_CHALLENGE)
sBattlePyramidFloorWindowId = AddWindow(&sPyramidFloorWindowTemplate_1); sBattlePyramidFloorWindowId = AddWindow(&sWindowTemplate_PyramidPeak);
else else
sBattlePyramidFloorWindowId = AddWindow(&sPyramidFloorWindowTemplate_2); sBattlePyramidFloorWindowId = AddWindow(&sWindowTemplate_PyramidFloor);
PutWindowTilemap(sBattlePyramidFloorWindowId); PutWindowTilemap(sBattlePyramidFloorWindowId);
DrawStdWindowFrame(sBattlePyramidFloorWindowId, FALSE); DrawStdWindowFrame(sBattlePyramidFloorWindowId, FALSE);

View File

@ -45,7 +45,6 @@
#include "constants/metatile_labels.h" #include "constants/metatile_labels.h"
#include "constants/moves.h" #include "constants/moves.h"
#include "constants/region_map_sections.h" #include "constants/region_map_sections.h"
#include "constants/script_menu.h"
#define LAST_TVSHOW_IDX (TV_SHOWS_COUNT - 1) #define LAST_TVSHOW_IDX (TV_SHOWS_COUNT - 1)