Merge branch 'master' into data_dump
This commit is contained in:
+1
-1
@@ -1384,7 +1384,7 @@ static void Task_SellBerries_PlaySfxAndRemoveBerries(u8 taskId)
|
||||
PlaySE(SE_SHOP);
|
||||
RemoveBagItem(gSpecialVar_ItemId, data[8]);
|
||||
AddMoney(&gSaveBlock1Ptr->money, itemid_get_market_price(gSpecialVar_ItemId) / 2 * data[8]);
|
||||
sub_809C09C(gSpecialVar_ItemId, data[8], 2);
|
||||
RecordItemPurchase(gSpecialVar_ItemId, data[8], 2);
|
||||
DestroyListMenuTask(data[0], &sStaticCnt.listMenuScrollOffset, &sStaticCnt.listMenuSelectedRow);
|
||||
SortAndCountBerries();
|
||||
SanitizeListMenuSelectionParams();
|
||||
|
||||
@@ -177,14 +177,14 @@ void BuyMenuDrawMoneyBox(void)
|
||||
PrintMoneyAmountInMoneyBoxWithBorder(0, 0xA, 0xF, GetMoney(&gSaveBlock1Ptr->money));
|
||||
}
|
||||
|
||||
void BuyMenuPrint(u8 windowId, u8 font, const u8 *text, u8 x, u8 y, u8 letterSpacing, u8 lineSpacing, s8 speed, u8 color)
|
||||
void BuyMenuPrint(u8 windowId, u8 font, const u8 *text, u8 x, u8 y, u8 letterSpacing, u8 lineSpacing, u8 speed, u8 color)
|
||||
{
|
||||
AddTextPrinterParameterized4(windowId, font, x, y, letterSpacing, lineSpacing, sShopBuyMenuTextColors[color], speed, text);
|
||||
}
|
||||
|
||||
void BuyMenuDisplayMessage(u8 taskId, const u8 *text, TaskFunc callback)
|
||||
{
|
||||
DisplayMessageAndContinueTask(taskId, 2, 0x13, 0xE, sub_809B56C(), GetTextSpeedSetting(), text, callback);
|
||||
DisplayMessageAndContinueTask(taskId, 2, 0x13, 0xE, GetMartUnk16_4(), GetTextSpeedSetting(), text, callback);
|
||||
ScheduleBgCopyTilemapToVram(0);
|
||||
}
|
||||
|
||||
|
||||
+1
-1
@@ -463,7 +463,7 @@ u32 MapGridGetMetatileBehaviorAt(s32 x, s32 y)
|
||||
return sub_8058F48(x, y, 0);
|
||||
}
|
||||
|
||||
u8 MapGridGetMetatileLayerTypeAt(s32 x, s32 y)
|
||||
u8 MapGridGetMetatileLayerTypeAt(s16 x, s16 y)
|
||||
{
|
||||
return sub_8058F48(x, y, 6);
|
||||
}
|
||||
|
||||
+1275
File diff suppressed because it is too large
Load Diff
@@ -0,0 +1,264 @@
|
||||
#include "global.h"
|
||||
#include "event_data.h"
|
||||
#include "task.h"
|
||||
#include "menu.h"
|
||||
#include "field_player_avatar.h"
|
||||
#include "fieldmap.h"
|
||||
#include "field_map_obj.h"
|
||||
#include "field_camera.h"
|
||||
|
||||
static EWRAM_DATA u8 gUnknown_2039984 = 0;
|
||||
|
||||
static void sub_809C1D8(u8 taskId, const s16 *a1, u16 a2);
|
||||
static void sub_809C334(u8 taskId);
|
||||
static void sub_809C500(u8 taskId);
|
||||
static void sub_809C640(u8 taskId);
|
||||
|
||||
static const u16 gUnknown_83DF0D4[] = {0x0308, 0x030a, 0x02d0};
|
||||
static const u16 gUnknown_83DF0DA[] = {0x0309, 0x030b, 0x02d1};
|
||||
static const u16 gUnknown_83DF0E0[] = {0x0310, 0x0312, 0x02d8};
|
||||
static const u16 gUnknown_83DF0E6[] = {0x0311, 0x0313, 0x02d9};
|
||||
static const u16 gUnknown_83DF0EC[] = {0x02e3, 0x0316, 0x0314};
|
||||
static const u16 gUnknown_83DF0F2[] = {0x02e4, 0x0317, 0x0315};
|
||||
static const u16 gUnknown_83DF0F8[] = {0x02eb, 0x031e, 0x031c};
|
||||
|
||||
// Functions
|
||||
static void sub_809C1D8(u8 taskId, const s16 *a1, u16 a2)
|
||||
{
|
||||
s16 r5, r3, r4;
|
||||
s16 i, j;
|
||||
|
||||
r5 = gTasks[taskId].data[4] - 1;
|
||||
r3 = gTasks[taskId].data[5] - 1;
|
||||
r4 = gTasks[taskId].data[1];
|
||||
|
||||
if (gTasks[taskId].data[2] == 0)
|
||||
{
|
||||
for (i = 0; i < 3; i++)
|
||||
{
|
||||
for (j = 0; j < 3; j++)
|
||||
{
|
||||
s32 id = MapGridGetMetatileIdAt(r5 + j, r3 + i);
|
||||
|
||||
if (a1[r4] == (s16)id)
|
||||
{
|
||||
if (r4 != 2)
|
||||
MapGridSetMetatileIdAt(r5 + j, r3 + i, a2 | a1[r4 + 1]);
|
||||
else
|
||||
MapGridSetMetatileIdAt(r5 + j, r3 + i, a2 | a1[0]);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
for (i = 0; i < 3; i++)
|
||||
{
|
||||
for (j = 0; j < 3; j++)
|
||||
{
|
||||
s32 id = MapGridGetMetatileIdAt(r5 + j, r3 + i);
|
||||
|
||||
if (a1[2 - r4] == (s16)id)
|
||||
{
|
||||
if (r4 != 2)
|
||||
MapGridSetMetatileIdAt(r5 + j, r3 + i, a2 | a1[1 - r4]);
|
||||
else
|
||||
MapGridSetMetatileIdAt(r5 + j, r3 + i, a2 | a1[2]);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
static void sub_809C334(u8 taskId)
|
||||
{
|
||||
s16 *data = gTasks[taskId].data;
|
||||
u16 v1;
|
||||
|
||||
data[3] = 1;
|
||||
switch (data[0])
|
||||
{
|
||||
case 0:
|
||||
sub_809C1D8(taskId, gUnknown_83DF0D4, 0);
|
||||
break;
|
||||
case 1:
|
||||
sub_809C1D8(taskId, gUnknown_83DF0DA, 0);
|
||||
break;
|
||||
case 2:
|
||||
sub_809C1D8(taskId, gUnknown_83DF0E0, 0xC00);
|
||||
break;
|
||||
case 3:
|
||||
sub_809C1D8(taskId, gUnknown_83DF0E6, 0);
|
||||
break;
|
||||
case 4:
|
||||
sub_809C1D8(taskId, gUnknown_83DF0EC, 0xC00);
|
||||
break;
|
||||
case 5:
|
||||
sub_809C1D8(taskId, gUnknown_83DF0F2, 0);
|
||||
break;
|
||||
case 6:
|
||||
sub_809C1D8(taskId, gUnknown_83DF0F8, 0);
|
||||
default:
|
||||
break;
|
||||
}
|
||||
|
||||
data[0] = (data[0] + 1) & 7;
|
||||
v1 = data[0] & 7;
|
||||
if (v1 == 0)
|
||||
{
|
||||
DrawWholeMapView();
|
||||
data[1] = (data[1] + 1) % 3;
|
||||
data[3] = v1;
|
||||
}
|
||||
}
|
||||
|
||||
static u8 sub_809C3FC(u16 a0)
|
||||
{
|
||||
u8 taskId;
|
||||
s16 *data;
|
||||
|
||||
taskId = CreateTask(sub_809C334, 0);
|
||||
data = gTasks[taskId].data;
|
||||
PlayerGetDestCoords(&data[4], &data[5]);
|
||||
data[0] = 0;
|
||||
data[1] = 0;
|
||||
data[2] = a0;
|
||||
sub_809C334(taskId);
|
||||
return taskId;
|
||||
}
|
||||
|
||||
void sub_809C448(u8 a0)
|
||||
{
|
||||
u8 taskId;
|
||||
|
||||
taskId = sub_809C3FC(a0);
|
||||
gUnknown_2039984 = taskId;
|
||||
}
|
||||
|
||||
void sub_809C460(void)
|
||||
{
|
||||
DestroyTask(gUnknown_2039984);
|
||||
}
|
||||
|
||||
bool8 sub_809C474(void)
|
||||
{
|
||||
if (gTasks[gUnknown_2039984].data[3] == 0)
|
||||
{
|
||||
if (gTasks[gUnknown_2039984].data[1] != 2)
|
||||
return TRUE;
|
||||
return FALSE;
|
||||
}
|
||||
else
|
||||
{
|
||||
return TRUE;
|
||||
}
|
||||
}
|
||||
|
||||
// special 0x1b5 - creates a tile animaiton one block left two-four up the player
|
||||
void sub_809C4A8(void)
|
||||
{
|
||||
u8 taskId;
|
||||
s16 *data;
|
||||
|
||||
taskId = CreateTask(sub_809C500, 0);
|
||||
gTasks[taskId].data[0] = 0;
|
||||
gTasks[taskId].data[1] = 0;
|
||||
data = gTasks[taskId].data;
|
||||
PlayerGetDestCoords(&data[2], &data[3]);
|
||||
if (gSpecialVar_0x8004 == 0)
|
||||
{
|
||||
gTasks[taskId].data[2] += 6;
|
||||
gTasks[taskId].data[3] -= 5;
|
||||
}
|
||||
else
|
||||
{
|
||||
gTasks[taskId].data[2]--;
|
||||
gTasks[taskId].data[3] -= 5;
|
||||
}
|
||||
}
|
||||
|
||||
static void sub_809C500(u8 taskId)
|
||||
{
|
||||
s16 *data = gTasks[taskId].data;
|
||||
|
||||
if (data[0] == 0)
|
||||
{
|
||||
if ((data[1] & 1) == 0)
|
||||
{
|
||||
MapGridSetMetatileIdAt(data[2], data[3], 0xEB5);
|
||||
MapGridSetMetatileIdAt(data[2], data[3] + 2, 0xEB7);
|
||||
}
|
||||
else
|
||||
{
|
||||
MapGridSetMetatileIdAt(data[2], data[3], 0xEB6);
|
||||
MapGridSetMetatileIdAt(data[2], data[3] + 2, 0xEB8);
|
||||
}
|
||||
CurrentMapDrawMetatileAt(data[2], data[3]);
|
||||
CurrentMapDrawMetatileAt(data[2], data[3] + 2);
|
||||
}
|
||||
|
||||
data[0]++;
|
||||
if (data[0] != 0x10)
|
||||
return;
|
||||
|
||||
data[0] = 0;
|
||||
data[1]++;
|
||||
if (data[1] != 0xD)
|
||||
return;
|
||||
|
||||
MapGridSetMetatileIdAt(data[2], data[3], 0xE8A);
|
||||
MapGridSetMetatileIdAt(data[2], data[3] + 2, 0xE96);
|
||||
CurrentMapDrawMetatileAt(data[2], data[3]);
|
||||
CurrentMapDrawMetatileAt(data[2], data[3] + 2);
|
||||
DestroyTask(taskId);
|
||||
}
|
||||
|
||||
// special 0x1B7 - creates a tile animation two-six blocks right from the top-left corner of the screen
|
||||
void sub_809C5FC(void)
|
||||
{
|
||||
u8 taskId;
|
||||
s16 *data;
|
||||
|
||||
taskId = CreateTask(sub_809C640, 0);
|
||||
gTasks[taskId].data[0] = 0;
|
||||
gTasks[taskId].data[1] = 0;
|
||||
data = gTasks[taskId].data;
|
||||
PlayerGetDestCoords(&data[2], &data[3]);
|
||||
gTasks[taskId].data[2] += 4;
|
||||
gTasks[taskId].data[3] -= 5;
|
||||
}
|
||||
|
||||
static void sub_809C640(u8 taskId)
|
||||
{
|
||||
s16 *data = gTasks[taskId].data;
|
||||
|
||||
if (data[0] == 0)
|
||||
{
|
||||
if (data[1] != 0)
|
||||
{
|
||||
MapGridSetMetatileIdAt(data[2], data[3], 0xE85);
|
||||
MapGridSetMetatileIdAt(data[2], data[3] + 1, 0xEB4);
|
||||
CurrentMapDrawMetatileAt(data[2], data[3]);
|
||||
CurrentMapDrawMetatileAt(data[2], data[3] + 1);
|
||||
if (data[1] == 4)
|
||||
{
|
||||
DestroyTask(taskId);
|
||||
return;
|
||||
}
|
||||
|
||||
data[2]--;
|
||||
}
|
||||
MapGridSetMetatileIdAt(data[2], data[3], 0xEB9);
|
||||
MapGridSetMetatileIdAt(data[2], data[3] + 1, 0xEBA);
|
||||
CurrentMapDrawMetatileAt(data[2], data[3]);
|
||||
CurrentMapDrawMetatileAt(data[2], data[3] + 1);
|
||||
}
|
||||
|
||||
data[0]++;
|
||||
if (data[0] == 4)
|
||||
{
|
||||
data[0] = 0;
|
||||
data[1]++;
|
||||
}
|
||||
}
|
||||
|
||||
+1161
File diff suppressed because it is too large
Load Diff
+1
-1
@@ -1107,7 +1107,7 @@ static void Task_DoSaleOfTMs(u8 taskId)
|
||||
PlaySE(SE_SHOP);
|
||||
RemoveBagItem(gSpecialVar_ItemId, data[8]);
|
||||
AddMoney(&gSaveBlock1Ptr->money, itemid_get_market_price(gSpecialVar_ItemId) / 2 * data[8]);
|
||||
sub_809C09C(gSpecialVar_ItemId, data[8], 2);
|
||||
RecordItemPurchase(gSpecialVar_ItemId, data[8], 2);
|
||||
DestroyListMenuTask(data[0], &sTMCaseStaticResources.scrollOffset, &sTMCaseStaticResources.selectedRow);
|
||||
TMCaseSetup_GetTMCount();
|
||||
TMCaseSetup_InitListMenuPositions();
|
||||
|
||||
Reference in New Issue
Block a user