Merge branch 'master' of https://github.com/pret/pokeemerald into sideways_stairs
1
.gitignore
vendored
@ -36,3 +36,4 @@ porymap.project.cfg
|
|||||||
*.sna
|
*.sna
|
||||||
*.diff
|
*.diff
|
||||||
*.sym
|
*.sym
|
||||||
|
*.js
|
||||||
|
Before Width: | Height: | Size: 230 B After Width: | Height: | Size: 230 B |
Before Width: | Height: | Size: 227 B After Width: | Height: | Size: 227 B |
Before Width: | Height: | Size: 225 B After Width: | Height: | Size: 225 B |
Before Width: | Height: | Size: 228 B After Width: | Height: | Size: 228 B |
Before Width: | Height: | Size: 230 B After Width: | Height: | Size: 230 B |
Before Width: | Height: | Size: 227 B After Width: | Height: | Size: 227 B |
Before Width: | Height: | Size: 225 B After Width: | Height: | Size: 225 B |
Before Width: | Height: | Size: 228 B After Width: | Height: | Size: 228 B |
Before Width: | Height: | Size: 257 B After Width: | Height: | Size: 257 B |
Before Width: | Height: | Size: 257 B After Width: | Height: | Size: 257 B |
Before Width: | Height: | Size: 253 B After Width: | Height: | Size: 253 B |
Before Width: | Height: | Size: 255 B After Width: | Height: | Size: 255 B |
Before Width: | Height: | Size: 257 B After Width: | Height: | Size: 257 B |
Before Width: | Height: | Size: 257 B After Width: | Height: | Size: 257 B |
Before Width: | Height: | Size: 254 B After Width: | Height: | Size: 254 B |
Before Width: | Height: | Size: 254 B After Width: | Height: | Size: 254 B |
@ -2,7 +2,6 @@
|
|||||||
|
|
||||||
static void *sHeapStart;
|
static void *sHeapStart;
|
||||||
static u32 sHeapSize;
|
static u32 sHeapSize;
|
||||||
static u32 sFiller; // needed to align dma3_manager.o(.bss)
|
|
||||||
|
|
||||||
#define MALLOC_SYSTEM_ID 0xA3A3
|
#define MALLOC_SYSTEM_ID 0xA3A3
|
||||||
|
|
||||||
|
@ -14,7 +14,7 @@ struct Item
|
|||||||
u8 holdEffectParam;
|
u8 holdEffectParam;
|
||||||
const u8 *description;
|
const u8 *description;
|
||||||
u8 importance;
|
u8 importance;
|
||||||
u8 unk19;
|
bool8 registrability; // unused
|
||||||
u8 pocket;
|
u8 pocket;
|
||||||
u8 type;
|
u8 type;
|
||||||
ItemUseFunc fieldUseFunc;
|
ItemUseFunc fieldUseFunc;
|
||||||
@ -68,7 +68,7 @@ u8 ItemId_GetHoldEffect(u16 itemId);
|
|||||||
u8 ItemId_GetHoldEffectParam(u16 itemId);
|
u8 ItemId_GetHoldEffectParam(u16 itemId);
|
||||||
const u8 *ItemId_GetDescription(u16 itemId);
|
const u8 *ItemId_GetDescription(u16 itemId);
|
||||||
u8 ItemId_GetImportance(u16 itemId);
|
u8 ItemId_GetImportance(u16 itemId);
|
||||||
u8 ItemId_GetUnknownValue(u16 itemId);
|
u8 ItemId_GetRegistrability(u16 itemId);
|
||||||
u8 ItemId_GetPocket(u16 itemId);
|
u8 ItemId_GetPocket(u16 itemId);
|
||||||
u8 ItemId_GetType(u16 itemId);
|
u8 ItemId_GetType(u16 itemId);
|
||||||
ItemUseFunc ItemId_GetFieldFunc(u16 itemId);
|
ItemUseFunc ItemId_GetFieldFunc(u16 itemId);
|
||||||
|
@ -3146,7 +3146,7 @@ const struct Item gItems[] =
|
|||||||
.price = 0,
|
.price = 0,
|
||||||
.description = sMachBikeDesc,
|
.description = sMachBikeDesc,
|
||||||
.importance = 1,
|
.importance = 1,
|
||||||
.unk19 = 1,
|
.registrability = TRUE,
|
||||||
.pocket = POCKET_KEY_ITEMS,
|
.pocket = POCKET_KEY_ITEMS,
|
||||||
.type = ITEM_USE_FIELD,
|
.type = ITEM_USE_FIELD,
|
||||||
.fieldUseFunc = ItemUseOutOfBattle_Bike,
|
.fieldUseFunc = ItemUseOutOfBattle_Bike,
|
||||||
@ -3172,7 +3172,7 @@ const struct Item gItems[] =
|
|||||||
.price = 0,
|
.price = 0,
|
||||||
.description = sItemfinderDesc,
|
.description = sItemfinderDesc,
|
||||||
.importance = 1,
|
.importance = 1,
|
||||||
.unk19 = 1,
|
.registrability = TRUE,
|
||||||
.pocket = POCKET_KEY_ITEMS,
|
.pocket = POCKET_KEY_ITEMS,
|
||||||
.type = ITEM_USE_FIELD,
|
.type = ITEM_USE_FIELD,
|
||||||
.fieldUseFunc = ItemUseOutOfBattle_Itemfinder,
|
.fieldUseFunc = ItemUseOutOfBattle_Itemfinder,
|
||||||
@ -3185,7 +3185,7 @@ const struct Item gItems[] =
|
|||||||
.price = 0,
|
.price = 0,
|
||||||
.description = sOldRodDesc,
|
.description = sOldRodDesc,
|
||||||
.importance = 1,
|
.importance = 1,
|
||||||
.unk19 = 1,
|
.registrability = TRUE,
|
||||||
.pocket = POCKET_KEY_ITEMS,
|
.pocket = POCKET_KEY_ITEMS,
|
||||||
.type = ITEM_USE_FIELD,
|
.type = ITEM_USE_FIELD,
|
||||||
.fieldUseFunc = ItemUseOutOfBattle_Rod,
|
.fieldUseFunc = ItemUseOutOfBattle_Rod,
|
||||||
@ -3199,7 +3199,7 @@ const struct Item gItems[] =
|
|||||||
.price = 0,
|
.price = 0,
|
||||||
.description = sGoodRodDesc,
|
.description = sGoodRodDesc,
|
||||||
.importance = 1,
|
.importance = 1,
|
||||||
.unk19 = 1,
|
.registrability = TRUE,
|
||||||
.pocket = POCKET_KEY_ITEMS,
|
.pocket = POCKET_KEY_ITEMS,
|
||||||
.type = ITEM_USE_FIELD,
|
.type = ITEM_USE_FIELD,
|
||||||
.fieldUseFunc = ItemUseOutOfBattle_Rod,
|
.fieldUseFunc = ItemUseOutOfBattle_Rod,
|
||||||
@ -3213,7 +3213,7 @@ const struct Item gItems[] =
|
|||||||
.price = 0,
|
.price = 0,
|
||||||
.description = sSuperRodDesc,
|
.description = sSuperRodDesc,
|
||||||
.importance = 1,
|
.importance = 1,
|
||||||
.unk19 = 1,
|
.registrability = TRUE,
|
||||||
.pocket = POCKET_KEY_ITEMS,
|
.pocket = POCKET_KEY_ITEMS,
|
||||||
.type = ITEM_USE_FIELD,
|
.type = ITEM_USE_FIELD,
|
||||||
.fieldUseFunc = ItemUseOutOfBattle_Rod,
|
.fieldUseFunc = ItemUseOutOfBattle_Rod,
|
||||||
@ -3310,7 +3310,7 @@ const struct Item gItems[] =
|
|||||||
.price = 0,
|
.price = 0,
|
||||||
.description = sAcroBikeDesc,
|
.description = sAcroBikeDesc,
|
||||||
.importance = 1,
|
.importance = 1,
|
||||||
.unk19 = 1,
|
.registrability = TRUE,
|
||||||
.pocket = POCKET_KEY_ITEMS,
|
.pocket = POCKET_KEY_ITEMS,
|
||||||
.type = ITEM_USE_FIELD,
|
.type = ITEM_USE_FIELD,
|
||||||
.fieldUseFunc = ItemUseOutOfBattle_Bike,
|
.fieldUseFunc = ItemUseOutOfBattle_Bike,
|
||||||
@ -3324,7 +3324,7 @@ const struct Item gItems[] =
|
|||||||
.price = 0,
|
.price = 0,
|
||||||
.description = sPokeblockCaseDesc,
|
.description = sPokeblockCaseDesc,
|
||||||
.importance = 1,
|
.importance = 1,
|
||||||
.unk19 = 1,
|
.registrability = TRUE,
|
||||||
.pocket = POCKET_KEY_ITEMS,
|
.pocket = POCKET_KEY_ITEMS,
|
||||||
.type = ITEM_USE_PBLOCK_CASE,
|
.type = ITEM_USE_PBLOCK_CASE,
|
||||||
.fieldUseFunc = ItemUseOutOfBattle_PokeblockCase,
|
.fieldUseFunc = ItemUseOutOfBattle_PokeblockCase,
|
||||||
@ -4322,7 +4322,7 @@ const struct Item gItems[] =
|
|||||||
.price = 0,
|
.price = 0,
|
||||||
.description = sBicycleDesc,
|
.description = sBicycleDesc,
|
||||||
.importance = 1,
|
.importance = 1,
|
||||||
.unk19 = 1,
|
.registrability = TRUE,
|
||||||
.pocket = POCKET_KEY_ITEMS,
|
.pocket = POCKET_KEY_ITEMS,
|
||||||
.type = ITEM_USE_FIELD,
|
.type = ITEM_USE_FIELD,
|
||||||
.fieldUseFunc = ItemUseOutOfBattle_CannotUse,
|
.fieldUseFunc = ItemUseOutOfBattle_CannotUse,
|
||||||
@ -4335,7 +4335,7 @@ const struct Item gItems[] =
|
|||||||
.price = 0,
|
.price = 0,
|
||||||
.description = sTownMapDesc,
|
.description = sTownMapDesc,
|
||||||
.importance = 1,
|
.importance = 1,
|
||||||
.unk19 = 1,
|
.registrability = TRUE,
|
||||||
.pocket = POCKET_KEY_ITEMS,
|
.pocket = POCKET_KEY_ITEMS,
|
||||||
.type = ITEM_USE_BAG_MENU,
|
.type = ITEM_USE_BAG_MENU,
|
||||||
.fieldUseFunc = ItemUseOutOfBattle_CannotUse,
|
.fieldUseFunc = ItemUseOutOfBattle_CannotUse,
|
||||||
@ -4348,7 +4348,7 @@ const struct Item gItems[] =
|
|||||||
.price = 0,
|
.price = 0,
|
||||||
.description = sVSSeekerDesc,
|
.description = sVSSeekerDesc,
|
||||||
.importance = 1,
|
.importance = 1,
|
||||||
.unk19 = 1,
|
.registrability = TRUE,
|
||||||
.pocket = POCKET_KEY_ITEMS,
|
.pocket = POCKET_KEY_ITEMS,
|
||||||
.type = ITEM_USE_FIELD,
|
.type = ITEM_USE_FIELD,
|
||||||
.fieldUseFunc = ItemUseOutOfBattle_CannotUse,
|
.fieldUseFunc = ItemUseOutOfBattle_CannotUse,
|
||||||
@ -4361,7 +4361,7 @@ const struct Item gItems[] =
|
|||||||
.price = 0,
|
.price = 0,
|
||||||
.description = sFameCheckerDesc,
|
.description = sFameCheckerDesc,
|
||||||
.importance = 1,
|
.importance = 1,
|
||||||
.unk19 = 1,
|
.registrability = TRUE,
|
||||||
.pocket = POCKET_KEY_ITEMS,
|
.pocket = POCKET_KEY_ITEMS,
|
||||||
.type = ITEM_USE_BAG_MENU,
|
.type = ITEM_USE_BAG_MENU,
|
||||||
.fieldUseFunc = ItemUseOutOfBattle_CannotUse,
|
.fieldUseFunc = ItemUseOutOfBattle_CannotUse,
|
||||||
@ -4374,7 +4374,7 @@ const struct Item gItems[] =
|
|||||||
.price = 0,
|
.price = 0,
|
||||||
.description = sTMCaseDesc,
|
.description = sTMCaseDesc,
|
||||||
.importance = 1,
|
.importance = 1,
|
||||||
.unk19 = 1,
|
.registrability = TRUE,
|
||||||
.pocket = POCKET_KEY_ITEMS,
|
.pocket = POCKET_KEY_ITEMS,
|
||||||
.type = ITEM_USE_BAG_MENU,
|
.type = ITEM_USE_BAG_MENU,
|
||||||
.fieldUseFunc = ItemUseOutOfBattle_CannotUse,
|
.fieldUseFunc = ItemUseOutOfBattle_CannotUse,
|
||||||
@ -4387,7 +4387,7 @@ const struct Item gItems[] =
|
|||||||
.price = 0,
|
.price = 0,
|
||||||
.description = sBerryPouchDesc,
|
.description = sBerryPouchDesc,
|
||||||
.importance = 1,
|
.importance = 1,
|
||||||
.unk19 = 1,
|
.registrability = TRUE,
|
||||||
.pocket = POCKET_KEY_ITEMS,
|
.pocket = POCKET_KEY_ITEMS,
|
||||||
.type = ITEM_USE_BAG_MENU,
|
.type = ITEM_USE_BAG_MENU,
|
||||||
.fieldUseFunc = ItemUseOutOfBattle_CannotUse,
|
.fieldUseFunc = ItemUseOutOfBattle_CannotUse,
|
||||||
@ -4400,7 +4400,7 @@ const struct Item gItems[] =
|
|||||||
.price = 0,
|
.price = 0,
|
||||||
.description = sTeachyTVDesc,
|
.description = sTeachyTVDesc,
|
||||||
.importance = 1,
|
.importance = 1,
|
||||||
.unk19 = 1,
|
.registrability = TRUE,
|
||||||
.pocket = POCKET_KEY_ITEMS,
|
.pocket = POCKET_KEY_ITEMS,
|
||||||
.type = ITEM_USE_FIELD,
|
.type = ITEM_USE_FIELD,
|
||||||
.fieldUseFunc = ItemUseOutOfBattle_CannotUse,
|
.fieldUseFunc = ItemUseOutOfBattle_CannotUse,
|
||||||
@ -4413,7 +4413,7 @@ const struct Item gItems[] =
|
|||||||
.price = 0,
|
.price = 0,
|
||||||
.description = sTriPassDesc,
|
.description = sTriPassDesc,
|
||||||
.importance = 1,
|
.importance = 1,
|
||||||
.unk19 = 1,
|
.registrability = TRUE,
|
||||||
.pocket = POCKET_KEY_ITEMS,
|
.pocket = POCKET_KEY_ITEMS,
|
||||||
.type = ITEM_USE_BAG_MENU,
|
.type = ITEM_USE_BAG_MENU,
|
||||||
.fieldUseFunc = ItemUseOutOfBattle_CannotUse,
|
.fieldUseFunc = ItemUseOutOfBattle_CannotUse,
|
||||||
@ -4426,7 +4426,7 @@ const struct Item gItems[] =
|
|||||||
.price = 0,
|
.price = 0,
|
||||||
.description = sRainbowPassDesc,
|
.description = sRainbowPassDesc,
|
||||||
.importance = 1,
|
.importance = 1,
|
||||||
.unk19 = 1,
|
.registrability = TRUE,
|
||||||
.pocket = POCKET_KEY_ITEMS,
|
.pocket = POCKET_KEY_ITEMS,
|
||||||
.type = ITEM_USE_BAG_MENU,
|
.type = ITEM_USE_BAG_MENU,
|
||||||
.fieldUseFunc = ItemUseOutOfBattle_CannotUse,
|
.fieldUseFunc = ItemUseOutOfBattle_CannotUse,
|
||||||
@ -4439,7 +4439,7 @@ const struct Item gItems[] =
|
|||||||
.price = 0,
|
.price = 0,
|
||||||
.description = sTeaDesc,
|
.description = sTeaDesc,
|
||||||
.importance = 1,
|
.importance = 1,
|
||||||
.unk19 = 1,
|
.registrability = TRUE,
|
||||||
.pocket = POCKET_KEY_ITEMS,
|
.pocket = POCKET_KEY_ITEMS,
|
||||||
.type = ITEM_USE_BAG_MENU,
|
.type = ITEM_USE_BAG_MENU,
|
||||||
.fieldUseFunc = ItemUseOutOfBattle_CannotUse,
|
.fieldUseFunc = ItemUseOutOfBattle_CannotUse,
|
||||||
@ -4452,7 +4452,7 @@ const struct Item gItems[] =
|
|||||||
.price = 0,
|
.price = 0,
|
||||||
.description = sMysticTicketDesc,
|
.description = sMysticTicketDesc,
|
||||||
.importance = 1,
|
.importance = 1,
|
||||||
.unk19 = 1,
|
.registrability = TRUE,
|
||||||
.pocket = POCKET_KEY_ITEMS,
|
.pocket = POCKET_KEY_ITEMS,
|
||||||
.type = ITEM_USE_BAG_MENU,
|
.type = ITEM_USE_BAG_MENU,
|
||||||
.fieldUseFunc = ItemUseOutOfBattle_CannotUse,
|
.fieldUseFunc = ItemUseOutOfBattle_CannotUse,
|
||||||
@ -4465,7 +4465,7 @@ const struct Item gItems[] =
|
|||||||
.price = 0,
|
.price = 0,
|
||||||
.description = sAuroraTicketDesc,
|
.description = sAuroraTicketDesc,
|
||||||
.importance = 1,
|
.importance = 1,
|
||||||
.unk19 = 1,
|
.registrability = TRUE,
|
||||||
.pocket = POCKET_KEY_ITEMS,
|
.pocket = POCKET_KEY_ITEMS,
|
||||||
.type = ITEM_USE_BAG_MENU,
|
.type = ITEM_USE_BAG_MENU,
|
||||||
.fieldUseFunc = ItemUseOutOfBattle_CannotUse,
|
.fieldUseFunc = ItemUseOutOfBattle_CannotUse,
|
||||||
@ -4478,7 +4478,7 @@ const struct Item gItems[] =
|
|||||||
.price = 0,
|
.price = 0,
|
||||||
.description = sPowderJarDesc,
|
.description = sPowderJarDesc,
|
||||||
.importance = 1,
|
.importance = 1,
|
||||||
.unk19 = 1,
|
.registrability = TRUE,
|
||||||
.pocket = POCKET_KEY_ITEMS,
|
.pocket = POCKET_KEY_ITEMS,
|
||||||
.type = ITEM_USE_BAG_MENU,
|
.type = ITEM_USE_BAG_MENU,
|
||||||
.fieldUseFunc = ItemUseOutOfBattle_PowderJar,
|
.fieldUseFunc = ItemUseOutOfBattle_PowderJar,
|
||||||
@ -4491,7 +4491,7 @@ const struct Item gItems[] =
|
|||||||
.price = 0,
|
.price = 0,
|
||||||
.description = sRubyDesc,
|
.description = sRubyDesc,
|
||||||
.importance = 1,
|
.importance = 1,
|
||||||
.unk19 = 1,
|
.registrability = TRUE,
|
||||||
.pocket = POCKET_KEY_ITEMS,
|
.pocket = POCKET_KEY_ITEMS,
|
||||||
.type = ITEM_USE_BAG_MENU,
|
.type = ITEM_USE_BAG_MENU,
|
||||||
.fieldUseFunc = ItemUseOutOfBattle_CannotUse,
|
.fieldUseFunc = ItemUseOutOfBattle_CannotUse,
|
||||||
@ -4504,7 +4504,7 @@ const struct Item gItems[] =
|
|||||||
.price = 0,
|
.price = 0,
|
||||||
.description = sSapphireDesc,
|
.description = sSapphireDesc,
|
||||||
.importance = 1,
|
.importance = 1,
|
||||||
.unk19 = 1,
|
.registrability = TRUE,
|
||||||
.pocket = POCKET_KEY_ITEMS,
|
.pocket = POCKET_KEY_ITEMS,
|
||||||
.type = ITEM_USE_BAG_MENU,
|
.type = ITEM_USE_BAG_MENU,
|
||||||
.fieldUseFunc = ItemUseOutOfBattle_CannotUse,
|
.fieldUseFunc = ItemUseOutOfBattle_CannotUse,
|
||||||
@ -4519,7 +4519,7 @@ const struct Item gItems[] =
|
|||||||
.price = 0,
|
.price = 0,
|
||||||
.description = sMagmaEmblemDesc,
|
.description = sMagmaEmblemDesc,
|
||||||
.importance = 1,
|
.importance = 1,
|
||||||
.unk19 = 1,
|
.registrability = TRUE,
|
||||||
.pocket = POCKET_KEY_ITEMS,
|
.pocket = POCKET_KEY_ITEMS,
|
||||||
.type = ITEM_USE_BAG_MENU,
|
.type = ITEM_USE_BAG_MENU,
|
||||||
.fieldUseFunc = ItemUseOutOfBattle_CannotUse,
|
.fieldUseFunc = ItemUseOutOfBattle_CannotUse,
|
||||||
@ -4532,7 +4532,7 @@ const struct Item gItems[] =
|
|||||||
.price = 0,
|
.price = 0,
|
||||||
.description = sOldSeaMapDesc,
|
.description = sOldSeaMapDesc,
|
||||||
.importance = 1,
|
.importance = 1,
|
||||||
.unk19 = 1,
|
.registrability = TRUE,
|
||||||
.pocket = POCKET_KEY_ITEMS,
|
.pocket = POCKET_KEY_ITEMS,
|
||||||
.type = ITEM_USE_BAG_MENU,
|
.type = ITEM_USE_BAG_MENU,
|
||||||
.fieldUseFunc = ItemUseOutOfBattle_CannotUse,
|
.fieldUseFunc = ItemUseOutOfBattle_CannotUse,
|
||||||
|
@ -913,9 +913,9 @@ u8 ItemId_GetImportance(u16 itemId)
|
|||||||
}
|
}
|
||||||
|
|
||||||
// unused
|
// unused
|
||||||
u8 ItemId_GetUnknownValue(u16 itemId)
|
u8 ItemId_GetRegistrability(u16 itemId)
|
||||||
{
|
{
|
||||||
return gItems[SanitizeItemId(itemId)].unk19;
|
return gItems[SanitizeItemId(itemId)].registrability;
|
||||||
}
|
}
|
||||||
|
|
||||||
u8 ItemId_GetPocket(u16 itemId)
|
u8 ItemId_GetPocket(u16 itemId)
|
||||||
|
@ -193,10 +193,18 @@ bool8 IsRoamerAt(u8 mapGroup, u8 mapNum)
|
|||||||
|
|
||||||
void CreateRoamerMonInstance(void)
|
void CreateRoamerMonInstance(void)
|
||||||
{
|
{
|
||||||
|
u32 status;
|
||||||
struct Pokemon *mon = &gEnemyParty[0];
|
struct Pokemon *mon = &gEnemyParty[0];
|
||||||
ZeroEnemyPartyMons();
|
ZeroEnemyPartyMons();
|
||||||
CreateMonWithIVsPersonality(mon, ROAMER->species, ROAMER->level, ROAMER->ivs, ROAMER->personality);
|
CreateMonWithIVsPersonality(mon, ROAMER->species, ROAMER->level, ROAMER->ivs, ROAMER->personality);
|
||||||
|
// The roamer's status field is u8, but SetMonData expects status to be u32, so will set the roamer's status
|
||||||
|
// using the status field and the following 3 bytes (cool, beauty, and cute).
|
||||||
|
#ifdef BUGFIX
|
||||||
|
status = ROAMER->status;
|
||||||
|
SetMonData(mon, MON_DATA_STATUS, &status);
|
||||||
|
#else
|
||||||
SetMonData(mon, MON_DATA_STATUS, &ROAMER->status);
|
SetMonData(mon, MON_DATA_STATUS, &ROAMER->status);
|
||||||
|
#endif
|
||||||
SetMonData(mon, MON_DATA_HP, &ROAMER->hp);
|
SetMonData(mon, MON_DATA_HP, &ROAMER->hp);
|
||||||
SetMonData(mon, MON_DATA_COOL, &ROAMER->cool);
|
SetMonData(mon, MON_DATA_COOL, &ROAMER->cool);
|
||||||
SetMonData(mon, MON_DATA_BEAUTY, &ROAMER->beauty);
|
SetMonData(mon, MON_DATA_BEAUTY, &ROAMER->beauty);
|
||||||
|
@ -632,45 +632,45 @@ void InitTilesetAnim_Building(void)
|
|||||||
static void TilesetAnim_General(u16 timer)
|
static void TilesetAnim_General(u16 timer)
|
||||||
{
|
{
|
||||||
if (timer % 16 == 0)
|
if (timer % 16 == 0)
|
||||||
QueueAnimTiles_General_Flower(timer >> 4);
|
QueueAnimTiles_General_Flower(timer / 16);
|
||||||
if (timer % 16 == 1)
|
if (timer % 16 == 1)
|
||||||
QueueAnimTiles_General_Water(timer >> 4);
|
QueueAnimTiles_General_Water(timer / 16);
|
||||||
if (timer % 16 == 2)
|
if (timer % 16 == 2)
|
||||||
QueueAnimTiles_General_SandWaterEdge(timer >> 4);
|
QueueAnimTiles_General_SandWaterEdge(timer / 16);
|
||||||
if (timer % 16 == 3)
|
if (timer % 16 == 3)
|
||||||
QueueAnimTiles_General_Waterfall(timer >> 4);
|
QueueAnimTiles_General_Waterfall(timer / 16);
|
||||||
if (timer % 16 == 4)
|
if (timer % 16 == 4)
|
||||||
QueueAnimTiles_General_LandWaterEdge(timer >> 4);
|
QueueAnimTiles_General_LandWaterEdge(timer / 16);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void TilesetAnim_Building(u16 timer)
|
static void TilesetAnim_Building(u16 timer)
|
||||||
{
|
{
|
||||||
if (timer % 8 == 0)
|
if (timer % 8 == 0)
|
||||||
QueueAnimTiles_Building_TVTurnedOn(timer >> 3);
|
QueueAnimTiles_Building_TVTurnedOn(timer / 8);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void QueueAnimTiles_General_Flower(u16 timer)
|
static void QueueAnimTiles_General_Flower(u16 timer)
|
||||||
{
|
{
|
||||||
u16 i = timer % 4;
|
u16 i = timer % ARRAY_COUNT(gTilesetAnims_General_Flower);
|
||||||
AppendTilesetAnimToBuffer(gTilesetAnims_General_Flower[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(508)), 0x80);
|
AppendTilesetAnimToBuffer(gTilesetAnims_General_Flower[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(508)), 4 * TILE_SIZE_4BPP);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void QueueAnimTiles_General_Water(u16 timer)
|
static void QueueAnimTiles_General_Water(u16 timer)
|
||||||
{
|
{
|
||||||
u8 i = timer % 8;
|
u8 i = timer % ARRAY_COUNT(gTilesetAnims_General_Water);
|
||||||
AppendTilesetAnimToBuffer(gTilesetAnims_General_Water[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(432)), 0x3C0);
|
AppendTilesetAnimToBuffer(gTilesetAnims_General_Water[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(432)), 30 * TILE_SIZE_4BPP);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void QueueAnimTiles_General_SandWaterEdge(u16 timer)
|
static void QueueAnimTiles_General_SandWaterEdge(u16 timer)
|
||||||
{
|
{
|
||||||
u16 i = timer % 8;
|
u16 i = timer % ARRAY_COUNT(gTilesetAnims_General_SandWaterEdge);
|
||||||
AppendTilesetAnimToBuffer(gTilesetAnims_General_SandWaterEdge[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(464)), 0x140);
|
AppendTilesetAnimToBuffer(gTilesetAnims_General_SandWaterEdge[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(464)), 10 * TILE_SIZE_4BPP);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void QueueAnimTiles_General_Waterfall(u16 timer)
|
static void QueueAnimTiles_General_Waterfall(u16 timer)
|
||||||
{
|
{
|
||||||
u16 i = timer % 4;
|
u16 i = timer % ARRAY_COUNT(gTilesetAnims_General_Waterfall);
|
||||||
AppendTilesetAnimToBuffer(gTilesetAnims_General_Waterfall[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(496)), 0xc0);
|
AppendTilesetAnimToBuffer(gTilesetAnims_General_Waterfall[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(496)), 6 * TILE_SIZE_4BPP);
|
||||||
}
|
}
|
||||||
|
|
||||||
void InitTilesetAnim_Petalburg(void)
|
void InitTilesetAnim_Petalburg(void)
|
||||||
@ -838,336 +838,336 @@ static void TilesetAnim_Rustboro(u16 timer)
|
|||||||
{
|
{
|
||||||
if (timer % 8 == 0)
|
if (timer % 8 == 0)
|
||||||
{
|
{
|
||||||
QueueAnimTiles_Rustboro_WindyWater(timer >> 3, 0);
|
QueueAnimTiles_Rustboro_WindyWater(timer / 8, 0);
|
||||||
QueueAnimTiles_Rustboro_Fountain(timer >> 3);
|
QueueAnimTiles_Rustboro_Fountain(timer / 8);
|
||||||
}
|
}
|
||||||
if (timer % 8 == 1)
|
if (timer % 8 == 1)
|
||||||
QueueAnimTiles_Rustboro_WindyWater(timer >> 3, 1);
|
QueueAnimTiles_Rustboro_WindyWater(timer / 8, 1);
|
||||||
if (timer % 8 == 2)
|
if (timer % 8 == 2)
|
||||||
QueueAnimTiles_Rustboro_WindyWater(timer >> 3, 2);
|
QueueAnimTiles_Rustboro_WindyWater(timer / 8, 2);
|
||||||
if (timer % 8 == 3)
|
if (timer % 8 == 3)
|
||||||
QueueAnimTiles_Rustboro_WindyWater(timer >> 3, 3);
|
QueueAnimTiles_Rustboro_WindyWater(timer / 8, 3);
|
||||||
if (timer % 8 == 4)
|
if (timer % 8 == 4)
|
||||||
QueueAnimTiles_Rustboro_WindyWater(timer >> 3, 4);
|
QueueAnimTiles_Rustboro_WindyWater(timer / 8, 4);
|
||||||
if (timer % 8 == 5)
|
if (timer % 8 == 5)
|
||||||
QueueAnimTiles_Rustboro_WindyWater(timer >> 3, 5);
|
QueueAnimTiles_Rustboro_WindyWater(timer / 8, 5);
|
||||||
if (timer % 8 == 6)
|
if (timer % 8 == 6)
|
||||||
QueueAnimTiles_Rustboro_WindyWater(timer >> 3, 6);
|
QueueAnimTiles_Rustboro_WindyWater(timer / 8, 6);
|
||||||
if (timer % 8 == 7)
|
if (timer % 8 == 7)
|
||||||
QueueAnimTiles_Rustboro_WindyWater(timer >> 3, 7);
|
QueueAnimTiles_Rustboro_WindyWater(timer / 8, 7);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void TilesetAnim_Dewford(u16 timer)
|
static void TilesetAnim_Dewford(u16 timer)
|
||||||
{
|
{
|
||||||
if (timer % 8 == 0)
|
if (timer % 8 == 0)
|
||||||
QueueAnimTiles_Dewford_Flag(timer >> 3);
|
QueueAnimTiles_Dewford_Flag(timer / 8);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void TilesetAnim_Slateport(u16 timer)
|
static void TilesetAnim_Slateport(u16 timer)
|
||||||
{
|
{
|
||||||
if (timer % 16 == 0)
|
if (timer % 16 == 0)
|
||||||
QueueAnimTiles_Slateport_Balloons(timer >> 4);
|
QueueAnimTiles_Slateport_Balloons(timer / 16);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void TilesetAnim_Mauville(u16 timer)
|
static void TilesetAnim_Mauville(u16 timer)
|
||||||
{
|
{
|
||||||
if (timer % 8 == 0)
|
if (timer % 8 == 0)
|
||||||
QueueAnimTiles_Mauville_Flowers(timer >> 3, 0);
|
QueueAnimTiles_Mauville_Flowers(timer / 8, 0);
|
||||||
if (timer % 8 == 1)
|
if (timer % 8 == 1)
|
||||||
QueueAnimTiles_Mauville_Flowers(timer >> 3, 1);
|
QueueAnimTiles_Mauville_Flowers(timer / 8, 1);
|
||||||
if (timer % 8 == 2)
|
if (timer % 8 == 2)
|
||||||
QueueAnimTiles_Mauville_Flowers(timer >> 3, 2);
|
QueueAnimTiles_Mauville_Flowers(timer / 8, 2);
|
||||||
if (timer % 8 == 3)
|
if (timer % 8 == 3)
|
||||||
QueueAnimTiles_Mauville_Flowers(timer >> 3, 3);
|
QueueAnimTiles_Mauville_Flowers(timer / 8, 3);
|
||||||
if (timer % 8 == 4)
|
if (timer % 8 == 4)
|
||||||
QueueAnimTiles_Mauville_Flowers(timer >> 3, 4);
|
QueueAnimTiles_Mauville_Flowers(timer / 8, 4);
|
||||||
if (timer % 8 == 5)
|
if (timer % 8 == 5)
|
||||||
QueueAnimTiles_Mauville_Flowers(timer >> 3, 5);
|
QueueAnimTiles_Mauville_Flowers(timer / 8, 5);
|
||||||
if (timer % 8 == 6)
|
if (timer % 8 == 6)
|
||||||
QueueAnimTiles_Mauville_Flowers(timer >> 3, 6);
|
QueueAnimTiles_Mauville_Flowers(timer / 8, 6);
|
||||||
if (timer % 8 == 7)
|
if (timer % 8 == 7)
|
||||||
QueueAnimTiles_Mauville_Flowers(timer >> 3, 7);
|
QueueAnimTiles_Mauville_Flowers(timer / 8, 7);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void TilesetAnim_Lavaridge(u16 timer)
|
static void TilesetAnim_Lavaridge(u16 timer)
|
||||||
{
|
{
|
||||||
if (timer % 16 == 0)
|
if (timer % 16 == 0)
|
||||||
QueueAnimTiles_Lavaridge_Steam(timer >> 4);
|
QueueAnimTiles_Lavaridge_Steam(timer / 16);
|
||||||
if (timer % 16 == 1)
|
if (timer % 16 == 1)
|
||||||
QueueAnimTiles_Lavaridge_Lava(timer >> 4);
|
QueueAnimTiles_Lavaridge_Lava(timer / 16);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void TilesetAnim_EverGrande(u16 timer)
|
static void TilesetAnim_EverGrande(u16 timer)
|
||||||
{
|
{
|
||||||
if (timer % 8 == 0)
|
if (timer % 8 == 0)
|
||||||
QueueAnimTiles_EverGrande_Flowers(timer >> 3, 0);
|
QueueAnimTiles_EverGrande_Flowers(timer / 8, 0);
|
||||||
if (timer % 8 == 1)
|
if (timer % 8 == 1)
|
||||||
QueueAnimTiles_EverGrande_Flowers(timer >> 3, 1);
|
QueueAnimTiles_EverGrande_Flowers(timer / 8, 1);
|
||||||
if (timer % 8 == 2)
|
if (timer % 8 == 2)
|
||||||
QueueAnimTiles_EverGrande_Flowers(timer >> 3, 2);
|
QueueAnimTiles_EverGrande_Flowers(timer / 8, 2);
|
||||||
if (timer % 8 == 3)
|
if (timer % 8 == 3)
|
||||||
QueueAnimTiles_EverGrande_Flowers(timer >> 3, 3);
|
QueueAnimTiles_EverGrande_Flowers(timer / 8, 3);
|
||||||
if (timer % 8 == 4)
|
if (timer % 8 == 4)
|
||||||
QueueAnimTiles_EverGrande_Flowers(timer >> 3, 4);
|
QueueAnimTiles_EverGrande_Flowers(timer / 8, 4);
|
||||||
if (timer % 8 == 5)
|
if (timer % 8 == 5)
|
||||||
QueueAnimTiles_EverGrande_Flowers(timer >> 3, 5);
|
QueueAnimTiles_EverGrande_Flowers(timer / 8, 5);
|
||||||
if (timer % 8 == 6)
|
if (timer % 8 == 6)
|
||||||
QueueAnimTiles_EverGrande_Flowers(timer >> 3, 6);
|
QueueAnimTiles_EverGrande_Flowers(timer / 8, 6);
|
||||||
if (timer % 8 == 7)
|
if (timer % 8 == 7)
|
||||||
QueueAnimTiles_EverGrande_Flowers(timer >> 3, 7);
|
QueueAnimTiles_EverGrande_Flowers(timer / 8, 7);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void TilesetAnim_Pacifidlog(u16 timer)
|
static void TilesetAnim_Pacifidlog(u16 timer)
|
||||||
{
|
{
|
||||||
if (timer % 16 == 0)
|
if (timer % 16 == 0)
|
||||||
QueueAnimTiles_Pacifidlog_LogBridges(timer >> 4);
|
QueueAnimTiles_Pacifidlog_LogBridges(timer / 16);
|
||||||
if (timer % 16 == 1)
|
if (timer % 16 == 1)
|
||||||
QueueAnimTiles_Pacifidlog_WaterCurrents(timer >> 4);
|
QueueAnimTiles_Pacifidlog_WaterCurrents(timer / 16);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void TilesetAnim_Sootopolis(u16 timer)
|
static void TilesetAnim_Sootopolis(u16 timer)
|
||||||
{
|
{
|
||||||
if (timer % 16 == 0)
|
if (timer % 16 == 0)
|
||||||
QueueAnimTiles_Sootopolis_StormyWater(timer >> 4);
|
QueueAnimTiles_Sootopolis_StormyWater(timer / 16);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void TilesetAnim_Underwater(u16 timer)
|
static void TilesetAnim_Underwater(u16 timer)
|
||||||
{
|
{
|
||||||
if (timer % 16 == 0)
|
if (timer % 16 == 0)
|
||||||
QueueAnimTiles_Underwater_Seaweed(timer >> 4);
|
QueueAnimTiles_Underwater_Seaweed(timer / 16);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void TilesetAnim_Cave(u16 timer)
|
static void TilesetAnim_Cave(u16 timer)
|
||||||
{
|
{
|
||||||
if (timer % 16 == 1)
|
if (timer % 16 == 1)
|
||||||
QueueAnimTiles_Cave_Lava(timer >> 4);
|
QueueAnimTiles_Cave_Lava(timer / 16);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void TilesetAnim_BattleFrontierOutsideWest(u16 timer)
|
static void TilesetAnim_BattleFrontierOutsideWest(u16 timer)
|
||||||
{
|
{
|
||||||
if (timer % 8 == 0)
|
if (timer % 8 == 0)
|
||||||
QueueAnimTiles_BattleFrontierOutsideWest_Flag(timer >> 3);
|
QueueAnimTiles_BattleFrontierOutsideWest_Flag(timer / 8);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void TilesetAnim_BattleFrontierOutsideEast(u16 timer)
|
static void TilesetAnim_BattleFrontierOutsideEast(u16 timer)
|
||||||
{
|
{
|
||||||
if (timer % 8 == 0)
|
if (timer % 8 == 0)
|
||||||
QueueAnimTiles_BattleFrontierOutsideEast_Flag(timer >> 3);
|
QueueAnimTiles_BattleFrontierOutsideEast_Flag(timer / 8);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void QueueAnimTiles_General_LandWaterEdge(u16 timer)
|
static void QueueAnimTiles_General_LandWaterEdge(u16 timer)
|
||||||
{
|
{
|
||||||
u16 i = timer % 4;
|
u16 i = timer % ARRAY_COUNT(gTilesetAnims_General_LandWaterEdge);
|
||||||
AppendTilesetAnimToBuffer(gTilesetAnims_General_LandWaterEdge[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(480)), 0x140);
|
AppendTilesetAnimToBuffer(gTilesetAnims_General_LandWaterEdge[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(480)), 10 * TILE_SIZE_4BPP);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void QueueAnimTiles_Lavaridge_Steam(u8 timer)
|
static void QueueAnimTiles_Lavaridge_Steam(u8 timer)
|
||||||
{
|
{
|
||||||
u8 i = timer % 4;
|
u8 i = timer % ARRAY_COUNT(gTilesetAnims_Lavaridge_Steam);
|
||||||
AppendTilesetAnimToBuffer(gTilesetAnims_Lavaridge_Steam[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(NUM_TILES_IN_PRIMARY + 288)), 0x80);
|
AppendTilesetAnimToBuffer(gTilesetAnims_Lavaridge_Steam[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(NUM_TILES_IN_PRIMARY + 288)), 4 * TILE_SIZE_4BPP);
|
||||||
|
|
||||||
i = (timer + 2) % 4;
|
i = (timer + 2) % (int)ARRAY_COUNT(gTilesetAnims_Lavaridge_Steam);
|
||||||
AppendTilesetAnimToBuffer(gTilesetAnims_Lavaridge_Steam[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(NUM_TILES_IN_PRIMARY + 292)), 0x80);
|
AppendTilesetAnimToBuffer(gTilesetAnims_Lavaridge_Steam[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(NUM_TILES_IN_PRIMARY + 292)), 4 * TILE_SIZE_4BPP);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void QueueAnimTiles_Pacifidlog_LogBridges(u8 timer)
|
static void QueueAnimTiles_Pacifidlog_LogBridges(u8 timer)
|
||||||
{
|
{
|
||||||
u8 i = timer % 4;
|
u8 i = timer % ARRAY_COUNT(gTilesetAnims_Pacifidlog_LogBridges);
|
||||||
AppendTilesetAnimToBuffer(gTilesetAnims_Pacifidlog_LogBridges[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(NUM_TILES_IN_PRIMARY + 464)), 0x3C0);
|
AppendTilesetAnimToBuffer(gTilesetAnims_Pacifidlog_LogBridges[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(NUM_TILES_IN_PRIMARY + 464)), 30 * TILE_SIZE_4BPP);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void QueueAnimTiles_Underwater_Seaweed(u8 timer)
|
static void QueueAnimTiles_Underwater_Seaweed(u8 timer)
|
||||||
{
|
{
|
||||||
u8 i = timer % 4;
|
u8 i = timer % ARRAY_COUNT(gTilesetAnims_Underwater_Seaweed);
|
||||||
AppendTilesetAnimToBuffer(gTilesetAnims_Underwater_Seaweed[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(NUM_TILES_IN_PRIMARY + 496)), 0x80);
|
AppendTilesetAnimToBuffer(gTilesetAnims_Underwater_Seaweed[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(NUM_TILES_IN_PRIMARY + 496)), 4 * TILE_SIZE_4BPP);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void QueueAnimTiles_Pacifidlog_WaterCurrents(u8 timer)
|
static void QueueAnimTiles_Pacifidlog_WaterCurrents(u8 timer)
|
||||||
{
|
{
|
||||||
u8 i = timer % 8;
|
u8 i = timer % ARRAY_COUNT(gTilesetAnims_Pacifidlog_WaterCurrents);
|
||||||
AppendTilesetAnimToBuffer(gTilesetAnims_Pacifidlog_WaterCurrents[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(NUM_TILES_IN_PRIMARY + 496)), 0x100);
|
AppendTilesetAnimToBuffer(gTilesetAnims_Pacifidlog_WaterCurrents[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(NUM_TILES_IN_PRIMARY + 496)), 8 * TILE_SIZE_4BPP);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void QueueAnimTiles_Mauville_Flowers(u16 timer_div, u8 timer_mod)
|
static void QueueAnimTiles_Mauville_Flowers(u16 timer_div, u8 timer_mod)
|
||||||
{
|
{
|
||||||
timer_div -= timer_mod;
|
timer_div -= timer_mod;
|
||||||
if (timer_div < 12) // almost certainly a typo
|
if (timer_div < min(ARRAY_COUNT(gTilesetAnims_Mauville_Flower1), ARRAY_COUNT(gTilesetAnims_Mauville_Flower2)))
|
||||||
{
|
{
|
||||||
timer_div %= 12;
|
timer_div %= min(ARRAY_COUNT(gTilesetAnims_Mauville_Flower1), ARRAY_COUNT(gTilesetAnims_Mauville_Flower2));
|
||||||
AppendTilesetAnimToBuffer(gTilesetAnims_Mauville_Flower1[timer_div], gTilesetAnims_Mauville_Flower1_VDests[timer_mod], 0x80);
|
AppendTilesetAnimToBuffer(gTilesetAnims_Mauville_Flower1[timer_div], gTilesetAnims_Mauville_Flower1_VDests[timer_mod], 4 * TILE_SIZE_4BPP);
|
||||||
AppendTilesetAnimToBuffer(gTilesetAnims_Mauville_Flower2[timer_div], gTilesetAnims_Mauville_Flower2_VDests[timer_mod], 0x80);
|
AppendTilesetAnimToBuffer(gTilesetAnims_Mauville_Flower2[timer_div], gTilesetAnims_Mauville_Flower2_VDests[timer_mod], 4 * TILE_SIZE_4BPP);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
timer_div %= 4;
|
timer_div %= min(ARRAY_COUNT(gTilesetAnims_Mauville_Flower1_B), ARRAY_COUNT(gTilesetAnims_Mauville_Flower2_B));
|
||||||
AppendTilesetAnimToBuffer(gTilesetAnims_Mauville_Flower1_B[timer_div], gTilesetAnims_Mauville_Flower1_VDests[timer_mod], 0x80);
|
AppendTilesetAnimToBuffer(gTilesetAnims_Mauville_Flower1_B[timer_div], gTilesetAnims_Mauville_Flower1_VDests[timer_mod], 4 * TILE_SIZE_4BPP);
|
||||||
AppendTilesetAnimToBuffer(gTilesetAnims_Mauville_Flower2_B[timer_div], gTilesetAnims_Mauville_Flower2_VDests[timer_mod], 0x80);
|
AppendTilesetAnimToBuffer(gTilesetAnims_Mauville_Flower2_B[timer_div], gTilesetAnims_Mauville_Flower2_VDests[timer_mod], 4 * TILE_SIZE_4BPP);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void QueueAnimTiles_Rustboro_WindyWater(u16 timer_div, u8 timer_mod)
|
static void QueueAnimTiles_Rustboro_WindyWater(u16 timer_div, u8 timer_mod)
|
||||||
{
|
{
|
||||||
timer_div -= timer_mod;
|
timer_div -= timer_mod;
|
||||||
timer_div %= 8;
|
timer_div %= ARRAY_COUNT(gTilesetAnims_Rustboro_WindyWater);
|
||||||
if (gTilesetAnims_Rustboro_WindyWater[timer_div])
|
if (gTilesetAnims_Rustboro_WindyWater[timer_div])
|
||||||
AppendTilesetAnimToBuffer(gTilesetAnims_Rustboro_WindyWater[timer_div], gTilesetAnims_Rustboro_WindyWater_VDests[timer_mod], 0x80);
|
AppendTilesetAnimToBuffer(gTilesetAnims_Rustboro_WindyWater[timer_div], gTilesetAnims_Rustboro_WindyWater_VDests[timer_mod], 4 * TILE_SIZE_4BPP);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void QueueAnimTiles_Rustboro_Fountain(u16 timer)
|
static void QueueAnimTiles_Rustboro_Fountain(u16 timer)
|
||||||
{
|
{
|
||||||
u16 i = timer % 2;
|
u16 i = timer % ARRAY_COUNT(gTilesetAnims_Rustboro_Fountain);
|
||||||
AppendTilesetAnimToBuffer(gTilesetAnims_Rustboro_Fountain[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(NUM_TILES_IN_PRIMARY + 448)), 0x80);
|
AppendTilesetAnimToBuffer(gTilesetAnims_Rustboro_Fountain[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(NUM_TILES_IN_PRIMARY + 448)), 4 * TILE_SIZE_4BPP);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void QueueAnimTiles_Lavaridge_Lava(u16 timer)
|
static void QueueAnimTiles_Lavaridge_Lava(u16 timer)
|
||||||
{
|
{
|
||||||
u16 i = timer % 4;
|
u16 i = timer % ARRAY_COUNT(gTilesetAnims_Lavaridge_Cave_Lava);
|
||||||
AppendTilesetAnimToBuffer(gTilesetAnims_Lavaridge_Cave_Lava[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(NUM_TILES_IN_PRIMARY + 160)), 0x80);
|
AppendTilesetAnimToBuffer(gTilesetAnims_Lavaridge_Cave_Lava[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(NUM_TILES_IN_PRIMARY + 160)), 4 * TILE_SIZE_4BPP);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void QueueAnimTiles_EverGrande_Flowers(u16 timer_div, u8 timer_mod)
|
static void QueueAnimTiles_EverGrande_Flowers(u16 timer_div, u8 timer_mod)
|
||||||
{
|
{
|
||||||
timer_div -= timer_mod;
|
timer_div -= timer_mod;
|
||||||
timer_div %= 8;
|
timer_div %= ARRAY_COUNT(gTilesetAnims_EverGrande_Flowers);
|
||||||
|
|
||||||
AppendTilesetAnimToBuffer(gTilesetAnims_EverGrande_Flowers[timer_div], gTilesetAnims_EverGrande_VDests[timer_mod], 0x80);
|
AppendTilesetAnimToBuffer(gTilesetAnims_EverGrande_Flowers[timer_div], gTilesetAnims_EverGrande_VDests[timer_mod], 4 * TILE_SIZE_4BPP);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void QueueAnimTiles_Cave_Lava(u16 timer)
|
static void QueueAnimTiles_Cave_Lava(u16 timer)
|
||||||
{
|
{
|
||||||
u16 i = timer % 4;
|
u16 i = timer % ARRAY_COUNT(gTilesetAnims_Lavaridge_Cave_Lava);
|
||||||
AppendTilesetAnimToBuffer(gTilesetAnims_Lavaridge_Cave_Lava[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(NUM_TILES_IN_PRIMARY + 416)), 0x80);
|
AppendTilesetAnimToBuffer(gTilesetAnims_Lavaridge_Cave_Lava[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(NUM_TILES_IN_PRIMARY + 416)), 4 * TILE_SIZE_4BPP);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void QueueAnimTiles_Dewford_Flag(u16 timer)
|
static void QueueAnimTiles_Dewford_Flag(u16 timer)
|
||||||
{
|
{
|
||||||
u16 id = timer % 4;
|
u16 i = timer % ARRAY_COUNT(gTilesetAnims_Dewford_Flag);
|
||||||
AppendTilesetAnimToBuffer(gTilesetAnims_Dewford_Flag[id], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(NUM_TILES_IN_PRIMARY + 170)), 0xC0);
|
AppendTilesetAnimToBuffer(gTilesetAnims_Dewford_Flag[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(NUM_TILES_IN_PRIMARY + 170)), 6 * TILE_SIZE_4BPP);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void QueueAnimTiles_BattleFrontierOutsideWest_Flag(u16 timer)
|
static void QueueAnimTiles_BattleFrontierOutsideWest_Flag(u16 timer)
|
||||||
{
|
{
|
||||||
u16 i = timer % 4;
|
u16 i = timer % ARRAY_COUNT(gTilesetAnims_BattleFrontierOutsideWest_Flag);
|
||||||
AppendTilesetAnimToBuffer(gTilesetAnims_BattleFrontierOutsideWest_Flag[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(NUM_TILES_IN_PRIMARY + 218)), 0xC0);
|
AppendTilesetAnimToBuffer(gTilesetAnims_BattleFrontierOutsideWest_Flag[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(NUM_TILES_IN_PRIMARY + 218)), 6 * TILE_SIZE_4BPP);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void QueueAnimTiles_BattleFrontierOutsideEast_Flag(u16 timer)
|
static void QueueAnimTiles_BattleFrontierOutsideEast_Flag(u16 timer)
|
||||||
{
|
{
|
||||||
u16 i = timer % 4;
|
u16 i = timer % ARRAY_COUNT(gTilesetAnims_BattleFrontierOutsideEast_Flag);
|
||||||
AppendTilesetAnimToBuffer(gTilesetAnims_BattleFrontierOutsideEast_Flag[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(NUM_TILES_IN_PRIMARY + 218)), 0xC0);
|
AppendTilesetAnimToBuffer(gTilesetAnims_BattleFrontierOutsideEast_Flag[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(NUM_TILES_IN_PRIMARY + 218)), 6 * TILE_SIZE_4BPP);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void QueueAnimTiles_Slateport_Balloons(u16 timer)
|
static void QueueAnimTiles_Slateport_Balloons(u16 timer)
|
||||||
{
|
{
|
||||||
u16 i = timer % 4;
|
u16 i = timer % ARRAY_COUNT(gTilesetAnims_Slateport_Balloons);
|
||||||
AppendTilesetAnimToBuffer(gTilesetAnims_Slateport_Balloons[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(NUM_TILES_IN_PRIMARY + 224)), 0x80);
|
AppendTilesetAnimToBuffer(gTilesetAnims_Slateport_Balloons[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(NUM_TILES_IN_PRIMARY + 224)), 4 * TILE_SIZE_4BPP);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void TilesetAnim_MauvilleGym(u16 timer)
|
static void TilesetAnim_MauvilleGym(u16 timer)
|
||||||
{
|
{
|
||||||
if (timer % 2 == 0)
|
if (timer % 2 == 0)
|
||||||
QueueAnimTiles_MauvilleGym_ElectricGates(timer >> 1);
|
QueueAnimTiles_MauvilleGym_ElectricGates(timer / 2);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void TilesetAnim_SootopolisGym(u16 timer)
|
static void TilesetAnim_SootopolisGym(u16 timer)
|
||||||
{
|
{
|
||||||
if (timer % 8 == 0)
|
if (timer % 8 == 0)
|
||||||
QueueAnimTiles_SootopolisGym_Waterfalls(timer >> 3);
|
QueueAnimTiles_SootopolisGym_Waterfalls(timer / 8);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void TilesetAnim_EliteFour(u16 timer)
|
static void TilesetAnim_EliteFour(u16 timer)
|
||||||
{
|
{
|
||||||
if (timer % 64 == 1)
|
if (timer % 64 == 1)
|
||||||
QueueAnimTiles_EliteFour_GroundLights(timer >> 6);
|
QueueAnimTiles_EliteFour_GroundLights(timer / 64);
|
||||||
if (timer % 8 == 1)
|
if (timer % 8 == 1)
|
||||||
QueueAnimTiles_EliteFour_WallLights(timer >> 3);
|
QueueAnimTiles_EliteFour_WallLights(timer / 8);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void TilesetAnim_BikeShop(u16 timer)
|
static void TilesetAnim_BikeShop(u16 timer)
|
||||||
{
|
{
|
||||||
if (timer % 4 == 0)
|
if (timer % 4 == 0)
|
||||||
QueueAnimTiles_BikeShop_BlinkingLights(timer >> 2);
|
QueueAnimTiles_BikeShop_BlinkingLights(timer / 4);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void TilesetAnim_BattlePyramid(u16 timer)
|
static void TilesetAnim_BattlePyramid(u16 timer)
|
||||||
{
|
{
|
||||||
if (timer % 8 == 0)
|
if (timer % 8 == 0)
|
||||||
{
|
{
|
||||||
QueueAnimTiles_BattlePyramid_Torch(timer >> 3);
|
QueueAnimTiles_BattlePyramid_Torch(timer / 8);
|
||||||
QueueAnimTiles_BattlePyramid_StatueShadow(timer >> 3);
|
QueueAnimTiles_BattlePyramid_StatueShadow(timer / 8);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void TilesetAnim_BattleDome(u16 timer)
|
static void TilesetAnim_BattleDome(u16 timer)
|
||||||
{
|
{
|
||||||
if (timer % 4 == 0)
|
if (timer % 4 == 0)
|
||||||
BlendAnimPalette_BattleDome_FloorLights(timer >> 2);
|
BlendAnimPalette_BattleDome_FloorLights(timer / 4);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void TilesetAnim_BattleDome2(u16 timer)
|
static void TilesetAnim_BattleDome2(u16 timer)
|
||||||
{
|
{
|
||||||
if (timer % 4 == 0)
|
if (timer % 4 == 0)
|
||||||
BlendAnimPalette_BattleDome_FloorLightsNoBlend(timer >> 2);
|
BlendAnimPalette_BattleDome_FloorLightsNoBlend(timer / 4);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void QueueAnimTiles_Building_TVTurnedOn(u16 timer)
|
static void QueueAnimTiles_Building_TVTurnedOn(u16 timer)
|
||||||
{
|
{
|
||||||
u16 i = timer % 2;
|
u16 i = timer % ARRAY_COUNT(gTilesetAnims_Building_TvTurnedOn);
|
||||||
AppendTilesetAnimToBuffer(gTilesetAnims_Building_TvTurnedOn[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(496)), 0x80);
|
AppendTilesetAnimToBuffer(gTilesetAnims_Building_TvTurnedOn[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(496)), 4 * TILE_SIZE_4BPP);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void QueueAnimTiles_SootopolisGym_Waterfalls(u16 timer)
|
static void QueueAnimTiles_SootopolisGym_Waterfalls(u16 timer)
|
||||||
{
|
{
|
||||||
u16 i = timer % 3;
|
u16 i = timer % min(ARRAY_COUNT(gTilesetAnims_SootopolisGym_SideWaterfall), ARRAY_COUNT(gTilesetAnims_SootopolisGym_FrontWaterfall));
|
||||||
AppendTilesetAnimToBuffer(gTilesetAnims_SootopolisGym_SideWaterfall[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(NUM_TILES_IN_PRIMARY + 496)), 0x180);
|
AppendTilesetAnimToBuffer(gTilesetAnims_SootopolisGym_SideWaterfall[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(NUM_TILES_IN_PRIMARY + 496)), 12 * TILE_SIZE_4BPP);
|
||||||
AppendTilesetAnimToBuffer(gTilesetAnims_SootopolisGym_FrontWaterfall[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(NUM_TILES_IN_PRIMARY + 464)), 0x280);
|
AppendTilesetAnimToBuffer(gTilesetAnims_SootopolisGym_FrontWaterfall[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(NUM_TILES_IN_PRIMARY + 464)), 20 * TILE_SIZE_4BPP);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void QueueAnimTiles_EliteFour_WallLights(u16 timer)
|
static void QueueAnimTiles_EliteFour_WallLights(u16 timer)
|
||||||
{
|
{
|
||||||
u16 i = timer % 4;
|
u16 i = timer % ARRAY_COUNT(gTilesetAnims_EliteFour_WallLights);
|
||||||
AppendTilesetAnimToBuffer(gTilesetAnims_EliteFour_WallLights[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(NUM_TILES_IN_PRIMARY + 504)), 0x20);
|
AppendTilesetAnimToBuffer(gTilesetAnims_EliteFour_WallLights[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(NUM_TILES_IN_PRIMARY + 504)), 1 * TILE_SIZE_4BPP);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void QueueAnimTiles_EliteFour_GroundLights(u16 timer)
|
static void QueueAnimTiles_EliteFour_GroundLights(u16 timer)
|
||||||
{
|
{
|
||||||
u16 i = timer % 2;
|
u16 i = timer % ARRAY_COUNT(gTilesetAnims_EliteFour_FloorLight);
|
||||||
AppendTilesetAnimToBuffer(gTilesetAnims_EliteFour_FloorLight[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(NUM_TILES_IN_PRIMARY + 480)), 0x80);
|
AppendTilesetAnimToBuffer(gTilesetAnims_EliteFour_FloorLight[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(NUM_TILES_IN_PRIMARY + 480)), 4 * TILE_SIZE_4BPP);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void QueueAnimTiles_MauvilleGym_ElectricGates(u16 timer)
|
static void QueueAnimTiles_MauvilleGym_ElectricGates(u16 timer)
|
||||||
{
|
{
|
||||||
u16 i = timer % 2;
|
u16 i = timer % ARRAY_COUNT(gTilesetAnims_MauvilleGym_ElectricGates);
|
||||||
AppendTilesetAnimToBuffer(gTilesetAnims_MauvilleGym_ElectricGates[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(NUM_TILES_IN_PRIMARY + 144)), 0x200);
|
AppendTilesetAnimToBuffer(gTilesetAnims_MauvilleGym_ElectricGates[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(NUM_TILES_IN_PRIMARY + 144)), 16 * TILE_SIZE_4BPP);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void QueueAnimTiles_BikeShop_BlinkingLights(u16 timer)
|
static void QueueAnimTiles_BikeShop_BlinkingLights(u16 timer)
|
||||||
{
|
{
|
||||||
u16 i = timer % 2;
|
u16 i = timer % ARRAY_COUNT(gTilesetAnims_BikeShop_BlinkingLights);
|
||||||
AppendTilesetAnimToBuffer(gTilesetAnims_BikeShop_BlinkingLights[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(NUM_TILES_IN_PRIMARY + 496)), 0x120);
|
AppendTilesetAnimToBuffer(gTilesetAnims_BikeShop_BlinkingLights[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(NUM_TILES_IN_PRIMARY + 496)), 9 * TILE_SIZE_4BPP);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void QueueAnimTiles_Sootopolis_StormyWater(u16 timer)
|
static void QueueAnimTiles_Sootopolis_StormyWater(u16 timer)
|
||||||
{
|
{
|
||||||
u16 i = timer % 8;
|
u16 i = timer % ARRAY_COUNT(gTilesetAnims_Sootopolis_StormyWater);
|
||||||
AppendTilesetAnimToBuffer(gTilesetAnims_Sootopolis_StormyWater[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(NUM_TILES_IN_PRIMARY + 240)), 0xc00);
|
AppendTilesetAnimToBuffer(gTilesetAnims_Sootopolis_StormyWater[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(NUM_TILES_IN_PRIMARY + 240)), 96 * TILE_SIZE_4BPP);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void QueueAnimTiles_BattlePyramid_Torch(u16 timer)
|
static void QueueAnimTiles_BattlePyramid_Torch(u16 timer)
|
||||||
{
|
{
|
||||||
u16 i = timer % 3;
|
u16 i = timer % ARRAY_COUNT(gTilesetAnims_BattlePyramid_Torch);
|
||||||
AppendTilesetAnimToBuffer(gTilesetAnims_BattlePyramid_Torch[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(NUM_TILES_IN_PRIMARY + 151)), 0x100);
|
AppendTilesetAnimToBuffer(gTilesetAnims_BattlePyramid_Torch[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(NUM_TILES_IN_PRIMARY + 151)), 8 * TILE_SIZE_4BPP);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void QueueAnimTiles_BattlePyramid_StatueShadow(u16 timer)
|
static void QueueAnimTiles_BattlePyramid_StatueShadow(u16 timer)
|
||||||
{
|
{
|
||||||
u16 i = timer % 3;
|
u16 i = timer % ARRAY_COUNT(gTilesetAnims_BattlePyramid_StatueShadow);
|
||||||
AppendTilesetAnimToBuffer(gTilesetAnims_BattlePyramid_StatueShadow[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(NUM_TILES_IN_PRIMARY + 135)), 0x100);
|
AppendTilesetAnimToBuffer(gTilesetAnims_BattlePyramid_StatueShadow[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(NUM_TILES_IN_PRIMARY + 135)), 8 * TILE_SIZE_4BPP);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void BlendAnimPalette_BattleDome_FloorLights(u16 timer)
|
static void BlendAnimPalette_BattleDome_FloorLights(u16 timer)
|
||||||
{
|
{
|
||||||
CpuCopy16(gTilesetAnims_BattleDomeFloorLightPals[timer % 4], gPlttBufferUnfaded + 0x80, 32);
|
CpuCopy16(gTilesetAnims_BattleDomeFloorLightPals[timer % ARRAY_COUNT(gTilesetAnims_BattleDomeFloorLightPals)], &gPlttBufferUnfaded[0x80], 32);
|
||||||
BlendPalette(0x80, 16, gPaletteFade.y, gPaletteFade.blendColor & 0x7FFF);
|
BlendPalette(0x80, 16, gPaletteFade.y, gPaletteFade.blendColor & 0x7FFF);
|
||||||
if ((u8)FindTaskIdByFunc(Task_BattleTransition_Intro) != TASK_NONE)
|
if ((u8)FindTaskIdByFunc(Task_BattleTransition_Intro) != TASK_NONE)
|
||||||
{
|
{
|
||||||
@ -1178,7 +1178,7 @@ static void BlendAnimPalette_BattleDome_FloorLights(u16 timer)
|
|||||||
|
|
||||||
static void BlendAnimPalette_BattleDome_FloorLightsNoBlend(u16 timer)
|
static void BlendAnimPalette_BattleDome_FloorLightsNoBlend(u16 timer)
|
||||||
{
|
{
|
||||||
CpuCopy16(gTilesetAnims_BattleDomeFloorLightPals[timer % 4], gPlttBufferUnfaded + 0x80, 32);
|
CpuCopy16(gTilesetAnims_BattleDomeFloorLightPals[timer % ARRAY_COUNT(gTilesetAnims_BattleDomeFloorLightPals)], &gPlttBufferUnfaded[0x80], 32);
|
||||||
if ((u8)FindTaskIdByFunc(Task_BattleTransition_Intro) == TASK_NONE)
|
if ((u8)FindTaskIdByFunc(Task_BattleTransition_Intro) == TASK_NONE)
|
||||||
{
|
{
|
||||||
BlendPalette(0x80, 16, gPaletteFade.y, gPaletteFade.blendColor & 0x7FFF);
|
BlendPalette(0x80, 16, gPaletteFade.y, gPaletteFade.blendColor & 0x7FFF);
|
||||||
|
@ -4531,7 +4531,8 @@ static void _CreateInGameTradePokemon(u8 whichPlayerMon, u8 whichInGameTrade)
|
|||||||
CalculateMonStats(&gEnemyParty[0]);
|
CalculateMonStats(&gEnemyParty[0]);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void SetInGameTradeMail(struct Mail *mail, const struct InGameTrade *trade) {
|
static void SetInGameTradeMail(struct Mail *mail, const struct InGameTrade *trade)
|
||||||
|
{
|
||||||
s32 i;
|
s32 i;
|
||||||
|
|
||||||
for (i = 0; i < MAIL_WORDS_COUNT; i++)
|
for (i = 0; i < MAIL_WORDS_COUNT; i++)
|
||||||
|