Merge pull request #1159 from AsparagusEduardo/Doc-itemMenu
Partially document item_menu
This commit is contained in:
commit
1e6655b298
4 changed files with 116 additions and 112 deletions
|
@ -8,6 +8,12 @@
|
|||
#define MENU_NOTHING_CHOSEN -2
|
||||
#define MENU_B_PRESSED -1
|
||||
|
||||
#define MENU_CURSOR_DELTA_NONE 0
|
||||
#define MENU_CURSOR_DELTA_UP -1
|
||||
#define MENU_CURSOR_DELTA_DOWN 1
|
||||
#define MENU_CURSOR_DELTA_LEFT -1
|
||||
#define MENU_CURSOR_DELTA_RIGHT 1
|
||||
|
||||
enum
|
||||
{
|
||||
SAVE_MENU_NAME,
|
||||
|
@ -77,7 +83,7 @@ void AddTextPrinterForMessage(bool8 allowSkippingDelayWithButtonPress);
|
|||
void AddItemMenuActionTextPrinters(u8 windowId, u8 fontId, u8 left, u8 top, u8 letterSpacing, u8 lineHeight, u8 itemCount, const struct MenuAction *strs, const u8 *a8);
|
||||
void sub_8198DBC(u8 windowId, u8 fontId, u8 left, u8 top, u8 a4, u8 itemCount, u8 itemCount2, const struct MenuAction *strs, const u8 *a8);
|
||||
u8 sub_8199944(u8 windowId, u8 optionWidth, u8 columns, u8 rows, u8 initialCursorPos);
|
||||
u8 sub_8199134(s8, s8);
|
||||
u8 ChangeListMenuCursorPosition(s8 deltaX, s8 deltaY);
|
||||
u8 GetStartMenuWindowId(void);
|
||||
void ListMenuLoadStdPalAt(u8, u8);
|
||||
u8 Menu_MoveCursor(s8 cursorDelta);
|
||||
|
|
|
@ -970,7 +970,7 @@ static void HandleMenuActionInput(u8 taskId)
|
|||
if (id > 0 && IsValidMenuAction(id - 2))
|
||||
{
|
||||
PlaySE(SE_SELECT);
|
||||
sub_8199134(0, -1);
|
||||
ChangeListMenuCursorPosition(MENU_CURSOR_DELTA_NONE, MENU_CURSOR_DELTA_UP);
|
||||
}
|
||||
}
|
||||
else if (gMain.newKeys & DPAD_DOWN)
|
||||
|
@ -978,7 +978,7 @@ static void HandleMenuActionInput(u8 taskId)
|
|||
if (id < gPyramidBagResources->menuActionsCount - 2 && IsValidMenuAction(id + 2))
|
||||
{
|
||||
PlaySE(SE_SELECT);
|
||||
sub_8199134(0, 1);
|
||||
ChangeListMenuCursorPosition(MENU_CURSOR_DELTA_NONE, MENU_CURSOR_DELTA_DOWN);
|
||||
}
|
||||
}
|
||||
else if (gMain.newKeys & DPAD_LEFT || GetLRKeysPressed() == MENU_L_PRESSED)
|
||||
|
@ -986,7 +986,7 @@ static void HandleMenuActionInput(u8 taskId)
|
|||
if (id & 1 && IsValidMenuAction(id - 1))
|
||||
{
|
||||
PlaySE(SE_SELECT);
|
||||
sub_8199134(-1, 0);
|
||||
ChangeListMenuCursorPosition(MENU_CURSOR_DELTA_LEFT, MENU_CURSOR_DELTA_NONE);
|
||||
}
|
||||
}
|
||||
else if (gMain.newKeys & DPAD_RIGHT || GetLRKeysPressed() == MENU_R_PRESSED)
|
||||
|
@ -994,7 +994,7 @@ static void HandleMenuActionInput(u8 taskId)
|
|||
if (!(id & 1) && IsValidMenuAction(id + 1))
|
||||
{
|
||||
PlaySE(SE_SELECT);
|
||||
sub_8199134(1, 0);
|
||||
ChangeListMenuCursorPosition(MENU_CURSOR_DELTA_RIGHT, MENU_CURSOR_DELTA_NONE);
|
||||
}
|
||||
}
|
||||
else if (gMain.newKeys & A_BUTTON)
|
||||
|
|
156
src/item_menu.c
156
src/item_menu.c
|
@ -52,6 +52,13 @@
|
|||
#include "battle_pike.h"
|
||||
#include "constants/rgb.h"
|
||||
|
||||
enum
|
||||
{
|
||||
SWITCH_POCKET_NONE,
|
||||
SWITCH_POCKET_LEFT,
|
||||
SWITCH_POCKET_RIGHT
|
||||
};
|
||||
|
||||
void GoToBagMenu(u8 bagMenuType, u8 pocketId, void (*postExitMenuMainCallback2)());
|
||||
void CB2_Bag(void);
|
||||
bool8 SetupBagMenu(void);
|
||||
|
@ -62,7 +69,7 @@ void AllocateBagItemListBuffers(void);
|
|||
void LoadBagItemListBuffers(u8);
|
||||
void BagMenu_PrintPocketNames(const u8*, const u8*);
|
||||
void BagMenu_CopyPocketNameToWindow(u32);
|
||||
void BagMenu_DrawPocketIndicatorSquare(u8, u8);
|
||||
static void DrawPocketIndicatorSquare(u8 x, bool8 isCurrentPocket);
|
||||
void CreatePocketScrollArrowPair(void);
|
||||
void CreatePocketSwitchArrowPair(void);
|
||||
void BagMenu_PrepareTMHMMoveWindow(void);
|
||||
|
@ -80,16 +87,16 @@ u16 BagGetQuantityByPocketPosition(u8, u16);
|
|||
void BagDestroyPocketSwitchArrowPair(void);
|
||||
void TaskCloseBagMenu_2(u8);
|
||||
u8 AddItemMessageWindow(u8);
|
||||
void bag_menu_RemoveBagItem_message_window(u8);
|
||||
void BagMenu_RemoveBagItemMessageindow(u8);
|
||||
void set_callback3_to_bag(u8);
|
||||
void PrintItemDepositAmount(u8, s16);
|
||||
u8 BagMenu_AddWindow(u8);
|
||||
u8 GetSwitchBagPocketDirection(void);
|
||||
void SwitchBagPocket(u8, s16, u16);
|
||||
bool8 sub_81AC2C0(void);
|
||||
void BagMenu_SwapItems(u8);
|
||||
void sub_81AC10C(u8);
|
||||
void sub_81AC3C0(u8);
|
||||
static u8 BagMenu_AddWindow(u8);
|
||||
static u8 GetSwitchBagPocketDirection(void);
|
||||
static void SwitchBagPocket(u8, s16, u16);
|
||||
static bool8 CanSwapItems(void);
|
||||
static void BagMenu_SwapItems(u8 taskId);
|
||||
static void sub_81AC10C(u8);
|
||||
static void Task_HandleSwappingItemsInput(u8);
|
||||
void sub_81AC498(u8);
|
||||
void sub_81AC590(u8);
|
||||
void PrintTMHMMoveData(u16);
|
||||
|
@ -106,19 +113,18 @@ void BagMenu_YesNo(u8, u8, const struct YesNoFuncTable*);
|
|||
void Task_ActuallyToss(u8);
|
||||
void ItemMenu_Cancel(u8);
|
||||
void sub_81AD350(u8);
|
||||
void BagMenu_PrintItemCantBeHeld(u8);
|
||||
void DisplayCurrentMoneyWindow(void);
|
||||
void DisplaySellItemPriceAndConfirm(u8);
|
||||
static void BagMenu_PrintItemCantBeHeld(u8);
|
||||
static void DisplayCurrentMoneyWindow(void);
|
||||
static void DisplaySellItemPriceAndConfirm(u8);
|
||||
void sub_81AD730(u8);
|
||||
void sub_81AD6E4(u8);
|
||||
void bag_menu_remove_money_window(void);
|
||||
void bag_menu_RemoveBagItem_message_window(u8);
|
||||
void Task_BuyHowManyDialogueHandleInput(u8);
|
||||
void sub_81AD8C8(u8);
|
||||
void sub_81AD9C0(u8);
|
||||
void sub_81ADB14(u8);
|
||||
void sub_81ADA7C(u8);
|
||||
void sub_81ADC0C(u8);
|
||||
static void RemoveMoneyWindow(void);
|
||||
static void Task_SellHowManyDialogueHandleInput(u8);
|
||||
static void BagMenu_Sell_UpdateItemListAndMoney(u8);
|
||||
static void BagMenu_Sell_WaitForABPress(u8);
|
||||
static void BagMenu_TryDepositItem(u8);
|
||||
static void Task_ChooseHowManyToDeposit(u8 taskId);
|
||||
static void BagMenu_Deposit_WaitForABPress(u8);
|
||||
void CB2_ApprenticeExitBagMenu(void);
|
||||
void CB2_FavorLadyExitBagMenu(void);
|
||||
void CB2_QuizLadyExitBagMenu(void);
|
||||
|
@ -686,7 +692,7 @@ bool8 SetupBagMenu(void)
|
|||
case 13:
|
||||
BagMenu_PrintPocketNames(gPocketNamesStringsTable[gBagPositionStruct.pocket], 0);
|
||||
BagMenu_CopyPocketNameToWindow(0);
|
||||
BagMenu_DrawPocketIndicatorSquare(gBagPositionStruct.pocket, 1);
|
||||
DrawPocketIndicatorSquare(gBagPositionStruct.pocket, TRUE);
|
||||
gMain.state++;
|
||||
break;
|
||||
case 14:
|
||||
|
@ -1109,7 +1115,7 @@ void BagMenu_InitListsMenu(u8 taskId)
|
|||
s16* data = gTasks[taskId].data;
|
||||
u16* scrollPos = &gBagPositionStruct.scrollPosition[gBagPositionStruct.pocket];
|
||||
u16* cursorPos = &gBagPositionStruct.cursorPosition[gBagPositionStruct.pocket];
|
||||
bag_menu_RemoveBagItem_message_window(4);
|
||||
BagMenu_RemoveBagItemMessageindow(4);
|
||||
DestroyListMenuTask(data[0], scrollPos, cursorPos);
|
||||
UpdatePocketItemList(gBagPositionStruct.pocket);
|
||||
SetInitialScrollAndCursorPositions(gBagPositionStruct.pocket);
|
||||
|
@ -1152,16 +1158,16 @@ void Task_BagMenu_HandleInput(u8 taskId)
|
|||
{
|
||||
switch (GetSwitchBagPocketDirection())
|
||||
{
|
||||
case 1:
|
||||
SwitchBagPocket(taskId, -1, 0);
|
||||
case SWITCH_POCKET_LEFT:
|
||||
SwitchBagPocket(taskId, MENU_CURSOR_DELTA_LEFT, 0);
|
||||
return;
|
||||
case 2:
|
||||
SwitchBagPocket(taskId, 1, 0);
|
||||
case SWITCH_POCKET_RIGHT:
|
||||
SwitchBagPocket(taskId, MENU_CURSOR_DELTA_RIGHT, 0);
|
||||
return;
|
||||
default:
|
||||
if (gMain.newKeys & SELECT_BUTTON)
|
||||
{
|
||||
if (sub_81AC2C0() == 1)
|
||||
if (CanSwapItems() == TRUE)
|
||||
{
|
||||
ListMenuGetScrollAndRow(data[0], scrollPos, cursorPos);
|
||||
if ((*scrollPos + *cursorPos) != gBagMenu->numItemStacks[gBagPositionStruct.pocket] - 1)
|
||||
|
@ -1215,26 +1221,26 @@ void set_callback3_to_bag(u8 taskId)
|
|||
gTasks[taskId].func = Task_BagMenu_HandleInput;
|
||||
}
|
||||
|
||||
u8 GetSwitchBagPocketDirection(void)
|
||||
static u8 GetSwitchBagPocketDirection(void)
|
||||
{
|
||||
u8 LRKeys;
|
||||
if (gBagMenu->pocketSwitchDisabled)
|
||||
return 0;
|
||||
return SWITCH_POCKET_NONE;
|
||||
LRKeys = GetLRKeysPressed();
|
||||
if ((gMain.newKeys & DPAD_LEFT) || LRKeys == MENU_L_PRESSED)
|
||||
{
|
||||
PlaySE(SE_SELECT);
|
||||
return 1;
|
||||
return SWITCH_POCKET_LEFT;
|
||||
}
|
||||
if ((gMain.newKeys & DPAD_RIGHT) || LRKeys == MENU_R_PRESSED)
|
||||
{
|
||||
PlaySE(SE_SELECT);
|
||||
return 2;
|
||||
return SWITCH_POCKET_RIGHT;
|
||||
}
|
||||
return 0;
|
||||
return SWITCH_POCKET_NONE;
|
||||
}
|
||||
|
||||
void ChangeBagPocketId(u8 *bagPocketId, s8 deltaBagPocketId)
|
||||
static void ChangeBagPocketId(u8 *bagPocketId, s8 deltaBagPocketId)
|
||||
{
|
||||
if (deltaBagPocketId == 1 && *bagPocketId == POCKETS_COUNT - 1)
|
||||
*bagPocketId = 0;
|
||||
|
@ -1244,7 +1250,7 @@ void ChangeBagPocketId(u8 *bagPocketId, s8 deltaBagPocketId)
|
|||
*bagPocketId += deltaBagPocketId;
|
||||
}
|
||||
|
||||
void SwitchBagPocket(u8 taskId, s16 deltaBagPocketId, u16 a3)
|
||||
static void SwitchBagPocket(u8 taskId, s16 deltaBagPocketId, u16 a3)
|
||||
{
|
||||
s16* data = gTasks[taskId].data;
|
||||
u8 pocketId;
|
||||
|
@ -1263,7 +1269,7 @@ void SwitchBagPocket(u8 taskId, s16 deltaBagPocketId, u16 a3)
|
|||
}
|
||||
pocketId = gBagPositionStruct.pocket;
|
||||
ChangeBagPocketId(&pocketId, deltaBagPocketId);
|
||||
if (deltaBagPocketId == 1)
|
||||
if (deltaBagPocketId == MENU_CURSOR_DELTA_RIGHT)
|
||||
{
|
||||
BagMenu_PrintPocketNames(gPocketNamesStringsTable[gBagPositionStruct.pocket], gPocketNamesStringsTable[pocketId]);
|
||||
BagMenu_CopyPocketNameToWindow(0);
|
||||
|
@ -1273,8 +1279,8 @@ void SwitchBagPocket(u8 taskId, s16 deltaBagPocketId, u16 a3)
|
|||
BagMenu_PrintPocketNames(gPocketNamesStringsTable[pocketId], gPocketNamesStringsTable[gBagPositionStruct.pocket]);
|
||||
BagMenu_CopyPocketNameToWindow(8);
|
||||
}
|
||||
BagMenu_DrawPocketIndicatorSquare(gBagPositionStruct.pocket, 0);
|
||||
BagMenu_DrawPocketIndicatorSquare(pocketId, 1);
|
||||
DrawPocketIndicatorSquare(gBagPositionStruct.pocket, FALSE);
|
||||
DrawPocketIndicatorSquare(pocketId, TRUE);
|
||||
FillBgTilemapBufferRect_Palette0(2, 11, 14, 2, 15, 16);
|
||||
ScheduleBgCopyTilemapToVram(2);
|
||||
SetBagVisualPocketId(pocketId, 1);
|
||||
|
@ -1291,15 +1297,15 @@ void sub_81AC10C(u8 taskId)
|
|||
{
|
||||
switch (GetSwitchBagPocketDirection())
|
||||
{
|
||||
case 1:
|
||||
case SWITCH_POCKET_LEFT:
|
||||
ChangeBagPocketId(&gBagPositionStruct.pocket, data[11]);
|
||||
SwitchTaskToFollowupFunc(taskId);
|
||||
SwitchBagPocket(taskId, -1, 1);
|
||||
SwitchBagPocket(taskId, MENU_CURSOR_DELTA_LEFT, 1);
|
||||
return;
|
||||
case 2:
|
||||
case SWITCH_POCKET_RIGHT:
|
||||
ChangeBagPocketId(&gBagPositionStruct.pocket, data[11]);
|
||||
SwitchTaskToFollowupFunc(taskId);
|
||||
SwitchBagPocket(taskId, 1, 1);
|
||||
SwitchBagPocket(taskId, MENU_CURSOR_DELTA_RIGHT, 1);
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
@ -1336,16 +1342,16 @@ void sub_81AC23C(u8 a)
|
|||
ScheduleBgCopyTilemapToVram(2);
|
||||
}
|
||||
|
||||
void BagMenu_DrawPocketIndicatorSquare(u8 x, u8 is_current_bag)
|
||||
static void DrawPocketIndicatorSquare(u8 x, bool8 isCurrentPocket)
|
||||
{
|
||||
if (is_current_bag == 0)
|
||||
if (!isCurrentPocket)
|
||||
FillBgTilemapBufferRect_Palette0(2, 0x1017, x + 5, 3, 1, 1);
|
||||
else
|
||||
FillBgTilemapBufferRect_Palette0(2, 0x102B, x + 5, 3, 1, 1);
|
||||
ScheduleBgCopyTilemapToVram(2);
|
||||
}
|
||||
|
||||
bool8 sub_81AC2C0(void)
|
||||
static bool8 CanSwapItems(void)
|
||||
{
|
||||
if (gBagPositionStruct.location <= ITEMMENULOCATION_BATTLE)
|
||||
{
|
||||
|
@ -1370,10 +1376,10 @@ void BagMenu_SwapItems(u8 taskId)
|
|||
sub_80D4FEC(data[1]);
|
||||
BagDestroyPocketSwitchArrowPair();
|
||||
BagMenu_PrintCursor_(data[0], 2);
|
||||
gTasks[taskId].func = sub_81AC3C0;
|
||||
gTasks[taskId].func = Task_HandleSwappingItemsInput;
|
||||
}
|
||||
|
||||
void sub_81AC3C0(u8 taskId)
|
||||
static void Task_HandleSwappingItemsInput(u8 taskId)
|
||||
{
|
||||
s16* data = gTasks[taskId].data;
|
||||
int input;
|
||||
|
@ -1642,7 +1648,7 @@ void Task_HandleOutOfBattleItemMenuInput(u8 taskId)
|
|||
if (cursorPos > 0 && sub_81ACDFC(cursorPos - 2))
|
||||
{
|
||||
PlaySE(SE_SELECT);
|
||||
sub_8199134(0, -1);
|
||||
ChangeListMenuCursorPosition(MENU_CURSOR_DELTA_NONE, MENU_CURSOR_DELTA_UP);
|
||||
}
|
||||
}
|
||||
else if (gMain.newKeys & DPAD_DOWN)
|
||||
|
@ -1650,7 +1656,7 @@ void Task_HandleOutOfBattleItemMenuInput(u8 taskId)
|
|||
if (cursorPos < (gBagMenu->contextMenuNumItems - 2) && sub_81ACDFC(cursorPos + 2))
|
||||
{
|
||||
PlaySE(SE_SELECT);
|
||||
sub_8199134(0, 1);
|
||||
ChangeListMenuCursorPosition(MENU_CURSOR_DELTA_NONE, MENU_CURSOR_DELTA_DOWN);
|
||||
}
|
||||
}
|
||||
else if ((gMain.newKeys & DPAD_LEFT) || GetLRKeysPressed() == MENU_L_PRESSED)
|
||||
|
@ -1658,7 +1664,7 @@ void Task_HandleOutOfBattleItemMenuInput(u8 taskId)
|
|||
if ((cursorPos & 1) && sub_81ACDFC(cursorPos - 1))
|
||||
{
|
||||
PlaySE(SE_SELECT);
|
||||
sub_8199134(-1, 0);
|
||||
ChangeListMenuCursorPosition(MENU_CURSOR_DELTA_LEFT, MENU_CURSOR_DELTA_NONE);
|
||||
}
|
||||
}
|
||||
else if ((gMain.newKeys & DPAD_RIGHT) || GetLRKeysPressed() == MENU_R_PRESSED)
|
||||
|
@ -1666,7 +1672,7 @@ void Task_HandleOutOfBattleItemMenuInput(u8 taskId)
|
|||
if (!(cursorPos & 1) && sub_81ACDFC(cursorPos + 1))
|
||||
{
|
||||
PlaySE(SE_SELECT);
|
||||
sub_8199134(1, 0);
|
||||
ChangeListMenuCursorPosition(MENU_CURSOR_DELTA_RIGHT, MENU_CURSOR_DELTA_NONE);
|
||||
}
|
||||
}
|
||||
else if (gMain.newKeys & A_BUTTON)
|
||||
|
@ -1869,7 +1875,7 @@ void BagMenu_PrintThereIsNoPokemon(u8 taskId)
|
|||
DisplayItemMessage(taskId, 1, gText_NoPokemon, sub_81AD350);
|
||||
}
|
||||
|
||||
void BagMenu_PrintItemCantBeHeld(u8 taskId)
|
||||
static void BagMenu_PrintItemCantBeHeld(u8 taskId)
|
||||
{
|
||||
CopyItemName(gSpecialVar_ItemId, gStringVar1);
|
||||
StringExpandPlaceholders(gStringVar4, gText_Var1CantBeHeld);
|
||||
|
@ -2010,7 +2016,7 @@ void Task_ItemContext_Sell(u8 taskId)
|
|||
}
|
||||
}
|
||||
|
||||
void DisplaySellItemPriceAndConfirm(u8 taskId)
|
||||
static void DisplaySellItemPriceAndConfirm(u8 taskId)
|
||||
{
|
||||
s16* data = gTasks[taskId].data;
|
||||
|
||||
|
@ -2028,8 +2034,8 @@ void BagMenu_CancelSell(u8 taskId)
|
|||
{
|
||||
s16* data = gTasks[taskId].data;
|
||||
|
||||
bag_menu_remove_money_window();
|
||||
bag_menu_RemoveBagItem_message_window(4);
|
||||
RemoveMoneyWindow();
|
||||
BagMenu_RemoveBagItemMessageindow(4);
|
||||
BagMenu_PrintCursor_(data[0], 0);
|
||||
set_callback3_to_bag(taskId);
|
||||
}
|
||||
|
@ -2041,10 +2047,10 @@ void sub_81AD730(u8 taskId)
|
|||
|
||||
PrintItemSoldAmount(windowId, 1, (ItemId_GetPrice(gSpecialVar_ItemId) / 2) * tItemCount);
|
||||
DisplayCurrentMoneyWindow();
|
||||
gTasks[taskId].func = Task_BuyHowManyDialogueHandleInput;
|
||||
gTasks[taskId].func = Task_SellHowManyDialogueHandleInput;
|
||||
}
|
||||
|
||||
void Task_BuyHowManyDialogueHandleInput(u8 taskId)
|
||||
static void Task_SellHowManyDialogueHandleInput(u8 taskId)
|
||||
{
|
||||
s16* data = gTasks[taskId].data;
|
||||
|
||||
|
@ -2062,9 +2068,9 @@ void Task_BuyHowManyDialogueHandleInput(u8 taskId)
|
|||
{
|
||||
PlaySE(SE_SELECT);
|
||||
BagMenu_PrintCursor_(data[0], 0);
|
||||
bag_menu_remove_money_window();
|
||||
RemoveMoneyWindow();
|
||||
BagMenu_RemoveWindow(8);
|
||||
bag_menu_RemoveBagItem_message_window(4);
|
||||
BagMenu_RemoveBagItemMessageindow(4);
|
||||
set_callback3_to_bag(taskId);
|
||||
}
|
||||
}
|
||||
|
@ -2076,10 +2082,10 @@ void BagMenu_ConfirmSell(u8 taskId)
|
|||
CopyItemName(gSpecialVar_ItemId, gStringVar2);
|
||||
ConvertIntToDecimalStringN(gStringVar1, (ItemId_GetPrice(gSpecialVar_ItemId) / 2) * tItemCount, STR_CONV_MODE_LEFT_ALIGN, 6);
|
||||
StringExpandPlaceholders(gStringVar4, gText_TurnedOverVar1ForVar2);
|
||||
DisplayItemMessage(taskId, 1, gStringVar4, sub_81AD8C8);
|
||||
DisplayItemMessage(taskId, 1, gStringVar4, BagMenu_Sell_UpdateItemListAndMoney);
|
||||
}
|
||||
|
||||
void sub_81AD8C8(u8 taskId)
|
||||
static void BagMenu_Sell_UpdateItemListAndMoney(u8 taskId)
|
||||
{
|
||||
s16* data = gTasks[taskId].data;
|
||||
u16* scrollPos = &gBagPositionStruct.scrollPosition[gBagPositionStruct.pocket];
|
||||
|
@ -2095,15 +2101,15 @@ void sub_81AD8C8(u8 taskId)
|
|||
data[0] = ListMenuInit(&gMultiuseListMenuTemplate, *scrollPos, *cursorPos);
|
||||
BagMenu_PrintCursor_(data[0], 2);
|
||||
PrintMoneyAmountInMoneyBox(gBagMenu->windowPointers[9], GetMoney(&gSaveBlock1Ptr->money), 0);
|
||||
gTasks[taskId].func = sub_81AD9C0;
|
||||
gTasks[taskId].func = BagMenu_Sell_WaitForABPress;
|
||||
}
|
||||
|
||||
void sub_81AD9C0(u8 taskId)
|
||||
static void BagMenu_Sell_WaitForABPress(u8 taskId)
|
||||
{
|
||||
if (gMain.newKeys & (A_BUTTON | B_BUTTON))
|
||||
{
|
||||
PlaySE(SE_SELECT);
|
||||
bag_menu_remove_money_window();
|
||||
RemoveMoneyWindow();
|
||||
BagMenu_InitListsMenu(taskId);
|
||||
}
|
||||
}
|
||||
|
@ -2115,7 +2121,7 @@ void Task_ItemContext_Deposit(u8 taskId)
|
|||
tItemCount = 1;
|
||||
if (data[2] == 1)
|
||||
{
|
||||
sub_81ADB14(taskId);
|
||||
BagMenu_TryDepositItem(taskId);
|
||||
}
|
||||
else
|
||||
{
|
||||
|
@ -2124,11 +2130,11 @@ void Task_ItemContext_Deposit(u8 taskId)
|
|||
FillWindowPixelBuffer(1, PIXEL_FILL(0));
|
||||
BagMenu_Print(1, 1, gStringVar4, 3, 1, 0, 0, 0, 0);
|
||||
sub_81ABC3C(7);
|
||||
gTasks[taskId].func = sub_81ADA7C;
|
||||
gTasks[taskId].func = Task_ChooseHowManyToDeposit;
|
||||
}
|
||||
}
|
||||
|
||||
void sub_81ADA7C(u8 taskId)
|
||||
static void Task_ChooseHowManyToDeposit(u8 taskId)
|
||||
{
|
||||
s16* data = gTasks[taskId].data;
|
||||
|
||||
|
@ -2140,7 +2146,7 @@ void sub_81ADA7C(u8 taskId)
|
|||
{
|
||||
PlaySE(SE_SELECT);
|
||||
BagMenu_RemoveWindow(7);
|
||||
sub_81ADB14(taskId);
|
||||
BagMenu_TryDepositItem(taskId);
|
||||
}
|
||||
else if (gMain.newKeys & B_BUTTON)
|
||||
{
|
||||
|
@ -2152,7 +2158,7 @@ void sub_81ADA7C(u8 taskId)
|
|||
}
|
||||
}
|
||||
|
||||
void sub_81ADB14(u8 taskId)
|
||||
static void BagMenu_TryDepositItem(u8 taskId)
|
||||
{
|
||||
s16* data = gTasks[taskId].data;
|
||||
|
||||
|
@ -2160,7 +2166,7 @@ void sub_81ADB14(u8 taskId)
|
|||
if (ItemId_GetImportance(gSpecialVar_ItemId))
|
||||
{
|
||||
BagMenu_Print(1, 1, gText_CantStoreImportantItems, 3, 1, 0, 0, 0, 0);
|
||||
gTasks[taskId].func = sub_81ADC0C;
|
||||
gTasks[taskId].func = BagMenu_Deposit_WaitForABPress;
|
||||
}
|
||||
else if (AddPCItem(gSpecialVar_ItemId, tItemCount) == TRUE)
|
||||
{
|
||||
|
@ -2173,11 +2179,11 @@ void sub_81ADB14(u8 taskId)
|
|||
else
|
||||
{
|
||||
BagMenu_Print(1, 1, gText_NoRoomForItems, 3, 1, 0, 0, 0, 0);
|
||||
gTasks[taskId].func = sub_81ADC0C;
|
||||
gTasks[taskId].func = BagMenu_Deposit_WaitForABPress;
|
||||
}
|
||||
}
|
||||
|
||||
void sub_81ADC0C(u8 taskId)
|
||||
static void BagMenu_Deposit_WaitForABPress(u8 taskId)
|
||||
{
|
||||
s16* data = gTasks[taskId].data;
|
||||
|
||||
|
@ -2248,7 +2254,7 @@ void Task_WallyTutorialBagMenu(u8 taskId)
|
|||
{
|
||||
case 0x66:
|
||||
PlaySE(SE_SELECT);
|
||||
SwitchBagPocket(taskId, 1, 0);
|
||||
SwitchBagPocket(taskId, MENU_CURSOR_DELTA_RIGHT, 0);
|
||||
data[8]++;
|
||||
break;
|
||||
case 0xCC:
|
||||
|
@ -2414,7 +2420,7 @@ u8 AddItemMessageWindow(u8 which)
|
|||
return *ptr;
|
||||
}
|
||||
|
||||
void bag_menu_RemoveBagItem_message_window(u8 which)
|
||||
void BagMenu_RemoveBagItemMessageindow(u8 which)
|
||||
{
|
||||
u8 *ptr = &gBagMenu->windowPointers[which];
|
||||
if (*ptr != 0xFF)
|
||||
|
@ -2433,14 +2439,14 @@ void BagMenu_YesNo(u8 a, u8 b, const struct YesNoFuncTable *funcTable)
|
|||
CreateYesNoMenuWithCallbacks(a, &sContextMenuWindowTemplates[b], 1, 0, 2, 1, 14, funcTable);
|
||||
}
|
||||
|
||||
void DisplayCurrentMoneyWindow(void)
|
||||
static void DisplayCurrentMoneyWindow(void)
|
||||
{
|
||||
u8 windowId = BagMenu_AddWindow(9);
|
||||
PrintMoneyAmountInMoneyBoxWithBorder(windowId, 1, 14, GetMoney(&gSaveBlock1Ptr->money));
|
||||
AddMoneyLabelObject(19, 11);
|
||||
}
|
||||
|
||||
void bag_menu_remove_money_window(void)
|
||||
static void RemoveMoneyWindow(void)
|
||||
{
|
||||
BagMenu_RemoveWindow(9);
|
||||
RemoveMoneyLabelObject();
|
||||
|
|
56
src/menu.c
56
src/menu.c
|
@ -1299,10 +1299,12 @@ u8 sub_8198F58(u8 windowId, u8 fontId, u8 left, u8 top, u8 a4, u8 cursorHeight,
|
|||
else
|
||||
sMenu.cursorPos = pos;
|
||||
|
||||
sub_8199134(0, 0);
|
||||
// Why call this when it's not gonna move?
|
||||
ChangeListMenuCursorPosition(MENU_CURSOR_DELTA_NONE, MENU_CURSOR_DELTA_NONE);
|
||||
return sMenu.cursorPos;
|
||||
}
|
||||
|
||||
// Unused
|
||||
u8 sub_8198FD4(u8 windowId, u8 fontId, u8 left, u8 top, u8 a4, u8 a5, u8 a6, u8 a7)
|
||||
{
|
||||
u8 cursorHeight = GetMenuCursorDimensionByFont(fontId, 1);
|
||||
|
@ -1333,41 +1335,29 @@ void sub_8199060(u8 oldCursorPos, u8 newCursorPos)
|
|||
0);
|
||||
}
|
||||
|
||||
u8 sub_8199134(s8 deltaX, s8 deltaY)
|
||||
u8 ChangeListMenuCursorPosition(s8 deltaX, s8 deltaY)
|
||||
{
|
||||
u8 oldPos = sMenu.cursorPos;
|
||||
|
||||
if (deltaX != 0)
|
||||
{
|
||||
if ((sMenu.cursorPos % sMenu.columns) + deltaX < 0)
|
||||
{
|
||||
sMenu.cursorPos += sMenu.columns - 1;
|
||||
}
|
||||
else if ((sMenu.cursorPos % sMenu.columns) + deltaX >= sMenu.columns)
|
||||
{
|
||||
sMenu.cursorPos = (sMenu.cursorPos / sMenu.columns) * sMenu.columns;
|
||||
}
|
||||
else
|
||||
{
|
||||
sMenu.cursorPos += deltaX;
|
||||
}
|
||||
}
|
||||
|
||||
if (deltaY != 0)
|
||||
{
|
||||
if ((sMenu.cursorPos / sMenu.columns) + deltaY < 0)
|
||||
{
|
||||
sMenu.cursorPos += sMenu.columns * (sMenu.rows - 1);
|
||||
}
|
||||
else if ((sMenu.cursorPos / sMenu.columns) + deltaY >= sMenu.rows)
|
||||
{
|
||||
sMenu.cursorPos -= sMenu.columns * (sMenu.rows - 1);
|
||||
}
|
||||
else
|
||||
{
|
||||
sMenu.cursorPos += (sMenu.columns * deltaY);
|
||||
}
|
||||
}
|
||||
|
||||
if (sMenu.cursorPos > sMenu.maxCursorPos)
|
||||
{
|
||||
|
@ -1381,7 +1371,7 @@ u8 sub_8199134(s8 deltaX, s8 deltaY)
|
|||
}
|
||||
}
|
||||
|
||||
u8 sub_81991F8(s8 deltaX, s8 deltaY)
|
||||
u8 ChangeGridMenuCursorPosition(s8 deltaX, s8 deltaY)
|
||||
{
|
||||
u8 oldPos = sMenu.cursorPos;
|
||||
|
||||
|
@ -1429,25 +1419,25 @@ s8 sub_8199284(void)
|
|||
else if (gMain.newKeys & DPAD_UP)
|
||||
{
|
||||
PlaySE(SE_SELECT);
|
||||
sub_8199134(0, -1);
|
||||
ChangeListMenuCursorPosition(MENU_CURSOR_DELTA_NONE, MENU_CURSOR_DELTA_UP);
|
||||
return MENU_NOTHING_CHOSEN;
|
||||
}
|
||||
else if (gMain.newKeys & DPAD_DOWN)
|
||||
{
|
||||
PlaySE(SE_SELECT);
|
||||
sub_8199134(0, 1);
|
||||
ChangeListMenuCursorPosition(MENU_CURSOR_DELTA_NONE, MENU_CURSOR_DELTA_DOWN);
|
||||
return MENU_NOTHING_CHOSEN;
|
||||
}
|
||||
else if (gMain.newKeys & DPAD_LEFT || GetLRKeysPressed() == MENU_L_PRESSED)
|
||||
{
|
||||
PlaySE(SE_SELECT);
|
||||
sub_8199134(-1, 0);
|
||||
ChangeListMenuCursorPosition(MENU_CURSOR_DELTA_LEFT, MENU_CURSOR_DELTA_NONE);
|
||||
return MENU_NOTHING_CHOSEN;
|
||||
}
|
||||
else if (gMain.newKeys & DPAD_RIGHT || GetLRKeysPressed() == MENU_R_PRESSED)
|
||||
{
|
||||
PlaySE(SE_SELECT);
|
||||
sub_8199134(1, 0);
|
||||
ChangeListMenuCursorPosition(MENU_CURSOR_DELTA_RIGHT, MENU_CURSOR_DELTA_NONE);
|
||||
return MENU_NOTHING_CHOSEN;
|
||||
}
|
||||
|
||||
|
@ -1469,25 +1459,25 @@ s8 Menu_ProcessInputGridLayout(void)
|
|||
}
|
||||
else if (gMain.newKeys & DPAD_UP)
|
||||
{
|
||||
if (oldPos != sub_81991F8(0, -1))
|
||||
if (oldPos != ChangeGridMenuCursorPosition(0, -1))
|
||||
PlaySE(SE_SELECT);
|
||||
return MENU_NOTHING_CHOSEN;
|
||||
}
|
||||
else if (gMain.newKeys & DPAD_DOWN)
|
||||
{
|
||||
if (oldPos != sub_81991F8(0, 1))
|
||||
if (oldPos != ChangeGridMenuCursorPosition(0, 1))
|
||||
PlaySE(SE_SELECT);
|
||||
return MENU_NOTHING_CHOSEN;
|
||||
}
|
||||
else if (gMain.newKeys & DPAD_LEFT || GetLRKeysPressed() == MENU_L_PRESSED)
|
||||
{
|
||||
if (oldPos != sub_81991F8(-1, 0))
|
||||
if (oldPos != ChangeGridMenuCursorPosition(-1, 0))
|
||||
PlaySE(SE_SELECT);
|
||||
return MENU_NOTHING_CHOSEN;
|
||||
}
|
||||
else if (gMain.newKeys & DPAD_RIGHT || GetLRKeysPressed() == MENU_R_PRESSED)
|
||||
{
|
||||
if (oldPos != sub_81991F8(1, 0))
|
||||
if (oldPos != ChangeGridMenuCursorPosition(1, 0))
|
||||
PlaySE(SE_SELECT);
|
||||
return MENU_NOTHING_CHOSEN;
|
||||
}
|
||||
|
@ -1509,31 +1499,32 @@ s8 sub_81993D8(void)
|
|||
else if ((gMain.newAndRepeatedKeys & DPAD_ANY) == DPAD_UP)
|
||||
{
|
||||
PlaySE(SE_SELECT);
|
||||
sub_8199134(0, -1);
|
||||
ChangeListMenuCursorPosition(MENU_CURSOR_DELTA_NONE, MENU_CURSOR_DELTA_UP);
|
||||
return MENU_NOTHING_CHOSEN;
|
||||
}
|
||||
else if ((gMain.newAndRepeatedKeys & DPAD_ANY) == DPAD_DOWN)
|
||||
{
|
||||
PlaySE(SE_SELECT);
|
||||
sub_8199134(0, 1);
|
||||
ChangeListMenuCursorPosition(MENU_CURSOR_DELTA_NONE, MENU_CURSOR_DELTA_DOWN);
|
||||
return MENU_NOTHING_CHOSEN;
|
||||
}
|
||||
else if ((gMain.newAndRepeatedKeys & DPAD_ANY) == DPAD_LEFT || GetLRKeysPressedAndHeld() == MENU_L_PRESSED)
|
||||
{
|
||||
PlaySE(SE_SELECT);
|
||||
sub_8199134(-1, 0);
|
||||
ChangeListMenuCursorPosition(MENU_CURSOR_DELTA_LEFT, MENU_CURSOR_DELTA_NONE);
|
||||
return MENU_NOTHING_CHOSEN;
|
||||
}
|
||||
else if ((gMain.newAndRepeatedKeys & DPAD_ANY) == DPAD_RIGHT || GetLRKeysPressedAndHeld() == MENU_R_PRESSED)
|
||||
{
|
||||
PlaySE(SE_SELECT);
|
||||
sub_8199134(1, 0);
|
||||
ChangeListMenuCursorPosition(MENU_CURSOR_DELTA_RIGHT, MENU_CURSOR_DELTA_NONE);
|
||||
return MENU_NOTHING_CHOSEN;
|
||||
}
|
||||
|
||||
return MENU_NOTHING_CHOSEN;
|
||||
}
|
||||
|
||||
//Unused
|
||||
s8 sub_8199484(void)
|
||||
{
|
||||
u8 oldPos = sMenu.cursorPos;
|
||||
|
@ -1549,25 +1540,25 @@ s8 sub_8199484(void)
|
|||
}
|
||||
else if ((gMain.newAndRepeatedKeys & DPAD_ANY) == DPAD_UP)
|
||||
{
|
||||
if (oldPos != sub_81991F8(0, -1))
|
||||
if (oldPos != ChangeGridMenuCursorPosition(0, -1))
|
||||
PlaySE(SE_SELECT);
|
||||
return MENU_NOTHING_CHOSEN;
|
||||
}
|
||||
else if ((gMain.newAndRepeatedKeys & DPAD_ANY) == DPAD_DOWN)
|
||||
{
|
||||
if (oldPos != sub_81991F8(0, 1))
|
||||
if (oldPos != ChangeGridMenuCursorPosition(0, 1))
|
||||
PlaySE(SE_SELECT);
|
||||
return MENU_NOTHING_CHOSEN;
|
||||
}
|
||||
else if ((gMain.newAndRepeatedKeys & DPAD_ANY) == DPAD_LEFT || GetLRKeysPressedAndHeld() == MENU_L_PRESSED)
|
||||
{
|
||||
if (oldPos != sub_81991F8(-1, 0))
|
||||
if (oldPos != ChangeGridMenuCursorPosition(-1, 0))
|
||||
PlaySE(SE_SELECT);
|
||||
return MENU_NOTHING_CHOSEN;
|
||||
}
|
||||
else if ((gMain.newAndRepeatedKeys & DPAD_ANY) == DPAD_RIGHT || GetLRKeysPressedAndHeld() == MENU_R_PRESSED)
|
||||
{
|
||||
if (oldPos != sub_81991F8(1, 0))
|
||||
if (oldPos != ChangeGridMenuCursorPosition(1, 0))
|
||||
PlaySE(SE_SELECT);
|
||||
return MENU_NOTHING_CHOSEN;
|
||||
}
|
||||
|
@ -1732,7 +1723,8 @@ u8 sub_8199944(u8 windowId, u8 optionWidth, u8 columns, u8 rows, u8 initialCurso
|
|||
else
|
||||
sMenu.cursorPos = pos;
|
||||
|
||||
sub_8199134(0, 0);
|
||||
// Why call this when it's not gonna move?
|
||||
ChangeListMenuCursorPosition(MENU_CURSOR_DELTA_NONE, MENU_CURSOR_DELTA_NONE);
|
||||
return sMenu.cursorPos;
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue