Fix https://github.com/jeffman/Mother2GbaTranslation/issues/69 and make sure the equip menu looks like the EB one
This commit is contained in:
parent
f2f99d0408
commit
ffe72262e9
|
@ -9,10 +9,10 @@ void printTargetOfAttack(short a, short target)
|
||||||
WINDOW *window = getWindow(3);
|
WINDOW *window = getWindow(3);
|
||||||
m2_setupwindow(window, 0x9, 0x3, 0x14, 0x2);
|
m2_setupwindow(window, 0x9, 0x3, 0x14, 0x2);
|
||||||
initWindow_buffer(window, NULL, 0);
|
initWindow_buffer(window, NULL, 0);
|
||||||
printstr_buffer(window, &m12_battle_commands_str11, 0, 0, false); //To
|
printstr_buffer(window, m12_battle_commands_str11, 0, 0, false); //To
|
||||||
if(target != -1)
|
if(target != -1)
|
||||||
{
|
{
|
||||||
printstr_hlight_buffer(window, &m12_battle_commands_str14, 8, 0, false);// " "
|
printstr_hlight_buffer(window, m12_battle_commands_str14, 8, 0, false);// " "
|
||||||
short *pointer = (short*)(0x20248E0 + 0x83E);
|
short *pointer = (short*)(0x20248E0 + 0x83E);
|
||||||
byte *pointer2 = (byte*)(pointer);
|
byte *pointer2 = (byte*)(pointer);
|
||||||
short value = *pointer;
|
short value = *pointer;
|
||||||
|
@ -39,9 +39,9 @@ void printTargetOfAttack(short a, short target)
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if(a == 0) //a is the row here
|
if(a == 0) //a is the row here
|
||||||
printstr_buffer(window, &m12_battle_commands_str12, 2, 0, false); //the Front Row
|
printstr_buffer(window, m12_battle_commands_str12, 2, 0, false); //the Front Row
|
||||||
else
|
else
|
||||||
printstr_buffer(window, &m12_battle_commands_str13, 2, 0, false); //the Back Row
|
printstr_buffer(window, m12_battle_commands_str13, 2, 0, false); //the Back Row
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -59,12 +59,12 @@ void printBattleMenu(byte validXs, byte validYs, byte highlighted)
|
||||||
if((*drawValue) == 2)
|
if((*drawValue) == 2)
|
||||||
{
|
{
|
||||||
print_blankstr_buffer(7,1,5,(int*)(OVERWORLD_BUFFER - 0x2000));
|
print_blankstr_buffer(7,1,5,(int*)(OVERWORLD_BUFFER - 0x2000));
|
||||||
str = &m12_battle_commands_str10; //Do Nothing
|
str = m12_battle_commands_str10; //Do Nothing
|
||||||
}
|
}
|
||||||
else if((*drawValue) == 1)
|
else if((*drawValue) == 1)
|
||||||
str = &m12_battle_commands_str6; //Shoot
|
str = m12_battle_commands_str6; //Shoot
|
||||||
else
|
else
|
||||||
str = &m12_battle_commands_str0; //Bash
|
str = m12_battle_commands_str0; //Bash
|
||||||
printstr_hlight_buffer(window, str, 1, 0, highlighted & 1);
|
printstr_hlight_buffer(window, str, 1, 0, highlighted & 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -72,9 +72,9 @@ void printBattleMenu(byte validXs, byte validYs, byte highlighted)
|
||||||
{
|
{
|
||||||
print_blankstr_buffer(2,3,5,(int*)(OVERWORLD_BUFFER - 0x2000));
|
print_blankstr_buffer(2,3,5,(int*)(OVERWORLD_BUFFER - 0x2000));
|
||||||
if((*active_window_party_member) != 2)
|
if((*active_window_party_member) != 2)
|
||||||
printstr_hlight_buffer(window, &m12_battle_commands_str3, 1, 1, highlighted & 2); //PSI
|
printstr_hlight_buffer(window, m12_battle_commands_str3, 1, 1, highlighted & 2); //PSI
|
||||||
else
|
else
|
||||||
printstr_hlight_buffer(window, &m12_battle_commands_str7, 1, 1, highlighted & 2); //Spy
|
printstr_hlight_buffer(window, m12_battle_commands_str7, 1, 1, highlighted & 2); //Spy
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -85,7 +85,7 @@ void printBattleMenu(byte validXs, byte validYs, byte highlighted)
|
||||||
if((*drawValue) != 2)
|
if((*drawValue) != 2)
|
||||||
{
|
{
|
||||||
print_blankstr_buffer(7,1,5,(int*)(OVERWORLD_BUFFER - 0x2000));
|
print_blankstr_buffer(7,1,5,(int*)(OVERWORLD_BUFFER - 0x2000));
|
||||||
printstr_hlight_buffer(window, &m12_battle_commands_str1, 6, 0, highlighted & 4); //Goods
|
printstr_hlight_buffer(window, m12_battle_commands_str1, 6, 0, highlighted & 4); //Goods
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -94,7 +94,7 @@ void printBattleMenu(byte validXs, byte validYs, byte highlighted)
|
||||||
print_blankstr_buffer(7,3,5,(int*)(OVERWORLD_BUFFER - 0x2000));
|
print_blankstr_buffer(7,3,5,(int*)(OVERWORLD_BUFFER - 0x2000));
|
||||||
if((*drawValue) != 2)
|
if((*drawValue) != 2)
|
||||||
{
|
{
|
||||||
printstr_hlight_buffer(window, &m12_battle_commands_str4, 6, 1, highlighted & 8); //Defend
|
printstr_hlight_buffer(window, m12_battle_commands_str4, 6, 1, highlighted & 8); //Defend
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -6,16 +6,16 @@
|
||||||
void printTargetOfAttack(short a, short target);
|
void printTargetOfAttack(short a, short target);
|
||||||
void printBattleMenu(byte validXs, byte validYs, byte highlighted);
|
void printBattleMenu(byte validXs, byte validYs, byte highlighted);
|
||||||
|
|
||||||
extern byte m12_battle_commands_str0;
|
extern byte m12_battle_commands_str0[];
|
||||||
extern byte m12_battle_commands_str1;
|
extern byte m12_battle_commands_str1[];
|
||||||
extern byte m12_battle_commands_str3;
|
extern byte m12_battle_commands_str3[];
|
||||||
extern byte m12_battle_commands_str4;
|
extern byte m12_battle_commands_str4[];
|
||||||
extern byte m12_battle_commands_str6;
|
extern byte m12_battle_commands_str6[];
|
||||||
extern byte m12_battle_commands_str7;
|
extern byte m12_battle_commands_str7[];
|
||||||
extern byte m12_battle_commands_str10;
|
extern byte m12_battle_commands_str10[];
|
||||||
extern byte m12_battle_commands_str11;
|
extern byte m12_battle_commands_str11[];
|
||||||
extern byte m12_battle_commands_str12;
|
extern byte m12_battle_commands_str12[];
|
||||||
extern byte m12_battle_commands_str13;
|
extern byte m12_battle_commands_str13[];
|
||||||
extern byte m12_battle_commands_str14;
|
extern byte m12_battle_commands_str14[];
|
||||||
|
|
||||||
#endif
|
#endif
|
133
src/c/equip.c
133
src/c/equip.c
|
@ -4,7 +4,7 @@
|
||||||
#include "locs.h"
|
#include "locs.h"
|
||||||
|
|
||||||
|
|
||||||
int equipReadInput(WINDOW* window) //Returns the character whose window we're going in, ACTION_NONE if nothing happens or ACTION_STEPOUT if going out og this window
|
int equipReadInput(WINDOW* window) //Returns the character whose window we're going in, ACTION_NONE if nothing happens or ACTION_STEPOUT if going out of this window
|
||||||
{
|
{
|
||||||
unsigned short previousCharacter = *active_window_party_member;
|
unsigned short previousCharacter = *active_window_party_member;
|
||||||
int currentCharacter = previousCharacter;
|
int currentCharacter = previousCharacter;
|
||||||
|
@ -177,16 +177,16 @@ void equippablePrint(WINDOW* window) //Prints equippable items (The innermost eq
|
||||||
switch(val)
|
switch(val)
|
||||||
{
|
{
|
||||||
case 3:
|
case 3:
|
||||||
str = &m12_other_str9; //->Weapons
|
str = m12_other_str9; //->Weapons
|
||||||
break;
|
break;
|
||||||
case 4:
|
case 4:
|
||||||
str = &m12_other_str10; //->Body
|
str = m12_other_str10; //->Body
|
||||||
break;
|
break;
|
||||||
case 5:
|
case 5:
|
||||||
str = &m12_other_str11; //->Arms
|
str = m12_other_str11; //->Arms
|
||||||
break;
|
break;
|
||||||
case 6:
|
case 6:
|
||||||
str = &m12_other_str12; //->Other
|
str = m12_other_str12; //->Other
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
|
@ -325,9 +325,9 @@ int equippableReadInput(WINDOW* window) //Manages input in equipment-choice inne
|
||||||
if((state.a || state.l) && !printed) //Avoid sound issues when going into the window
|
if((state.a || state.l) && !printed) //Avoid sound issues when going into the window
|
||||||
{
|
{
|
||||||
window->counter = 0xFFFF;
|
window->counter = 0xFFFF;
|
||||||
m2_soundeffect(0x12D);
|
|
||||||
if(freeSpace[window->cursor_y] == 0xFE)
|
if(freeSpace[window->cursor_y] == 0xFE)
|
||||||
{
|
{
|
||||||
|
m2_soundeffect(0x12D); //Do the sound only if we're changing the page. Otherwise the original code will do the appropriate sound
|
||||||
window->counter = 0;
|
window->counter = 0;
|
||||||
window->cursor_x_base++;
|
window->cursor_x_base++;
|
||||||
if(m2_div(window->cursor_x, 5) < window->cursor_x_base)
|
if(m2_div(window->cursor_x, 5) < window->cursor_x_base)
|
||||||
|
@ -359,6 +359,100 @@ int equippableReadInput(WINDOW* window) //Manages input in equipment-choice inne
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//Simplified inner equip routine (The original routine had a pointer to a table of valid cursor positions as a parameter)
|
||||||
|
int innerEquipInput(WINDOW* window)
|
||||||
|
{
|
||||||
|
bool printing = !window->vwf_skip;
|
||||||
|
window->vwf_skip = true;
|
||||||
|
|
||||||
|
PAD_STATE state = *pad_state;
|
||||||
|
PAD_STATE state_shadow = *pad_state_shadow;
|
||||||
|
|
||||||
|
short previousY = window->cursor_y;
|
||||||
|
short currentY = window->cursor_y;
|
||||||
|
|
||||||
|
// Clear cursor tiles
|
||||||
|
map_tile(0x1FF, window->window_x, window->window_y + window->cursor_y * 2);
|
||||||
|
map_tile(0x1FF, window->window_x, window->window_y + window->cursor_y * 2 + 1);
|
||||||
|
|
||||||
|
if(state.up) //This has been simplified
|
||||||
|
{
|
||||||
|
currentY--;
|
||||||
|
if(currentY < 0)
|
||||||
|
{
|
||||||
|
if(window->hold)
|
||||||
|
currentY = 0;
|
||||||
|
else
|
||||||
|
currentY = 3;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if(state.down) //This has been simplified
|
||||||
|
{
|
||||||
|
currentY++;
|
||||||
|
if(currentY >= 4)
|
||||||
|
{
|
||||||
|
if(window->hold)
|
||||||
|
currentY = 3;
|
||||||
|
else
|
||||||
|
currentY = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//The game does stuff when pressing left or right, however for the equipment window this is not needed
|
||||||
|
if(state.right) //This routine in particular did both the main overworld window and the inner equip window
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
if(state.left)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
if(state_shadow.up || state_shadow.down)
|
||||||
|
{
|
||||||
|
window->counter = 0;
|
||||||
|
if(previousY != currentY)
|
||||||
|
m2_soundeffect(0x12F);
|
||||||
|
window->hold = true;
|
||||||
|
window->cursor_y = currentY;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
window->hold = false;
|
||||||
|
|
||||||
|
if((state.b || state.select) && (!printing))
|
||||||
|
{
|
||||||
|
window->counter = 0;
|
||||||
|
m2_soundeffect(0x12E);
|
||||||
|
window->vwf_skip = false;
|
||||||
|
return ACTION_STEPOUT;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
if((state.a || state.l) && (!printing))
|
||||||
|
{
|
||||||
|
window->counter = 0xFFFF;
|
||||||
|
m2_soundeffect(0x12D);
|
||||||
|
window->vwf_skip = false;
|
||||||
|
return (window->cursor_y << 1) + ACTION_STEPIN;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (window->counter != 0xFFFF)
|
||||||
|
{
|
||||||
|
window->counter++;
|
||||||
|
|
||||||
|
// Draw cursor
|
||||||
|
map_special_character((window->counter <= 7) ? 0x99 : 0x9A,
|
||||||
|
window->window_x,
|
||||||
|
window->window_y + window->cursor_y * 2);
|
||||||
|
|
||||||
|
if (window->counter > 0x10)
|
||||||
|
window->counter = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
return ACTION_NONE;
|
||||||
|
}
|
||||||
|
|
||||||
void equipPrint(WINDOW* window) //Prints equipment
|
void equipPrint(WINDOW* window) //Prints equipment
|
||||||
{
|
{
|
||||||
m2_hpwindow_up(*active_window_party_member);
|
m2_hpwindow_up(*active_window_party_member);
|
||||||
|
@ -425,4 +519,29 @@ void equipPrint(WINDOW* window) //Prints equipment
|
||||||
map_special_character(0x1DE,(window->window_x + 7), 0x7); //Print the E
|
map_special_character(0x1DE,(window->window_x + 7), 0x7); //Print the E
|
||||||
printstr_buffer(window, item, 8, 3, false);
|
printstr_buffer(window, item, 8, 3, false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//Prints the numbers in the window in a formatted way
|
||||||
|
void printNumberEquip(WINDOW* window, byte* str, unsigned short x, unsigned short y, bool highlight)
|
||||||
|
{
|
||||||
|
while((*str) == 0x50)
|
||||||
|
{
|
||||||
|
x += 6;
|
||||||
|
str++;
|
||||||
|
}
|
||||||
|
printstr_hlight_pixels_buffer(window, str, x, y, highlight);
|
||||||
|
}
|
||||||
|
|
||||||
|
//Prints Offense: and Defense:
|
||||||
|
void printEquipWindowNumberText(WINDOW* window)
|
||||||
|
{
|
||||||
|
handle_first_window_buffer(window, (int*)(OVERWORLD_BUFFER - ((*tile_offset) * 32)));
|
||||||
|
printstr_hlight_pixels_buffer(window, window->text_start, 0, 3, false);
|
||||||
|
}
|
||||||
|
|
||||||
|
//Prints the arrow for the numbers in the Offense/Defense menu
|
||||||
|
void printEquipNumbersArrow(WINDOW* window)
|
||||||
|
{
|
||||||
|
printTinyArrow((window->window_x + 9) << 3, (window->window_y + 0) << 3);
|
||||||
|
printTinyArrow((window->window_x + 9) << 3, (window->window_y + 2) << 3);
|
||||||
|
}
|
||||||
|
|
|
@ -7,11 +7,14 @@ void equipPrint(WINDOW* window);
|
||||||
int equipReadInput(WINDOW* window);
|
int equipReadInput(WINDOW* window);
|
||||||
void equippablePrint(WINDOW* window);
|
void equippablePrint(WINDOW* window);
|
||||||
int equippableReadInput(WINDOW* window);
|
int equippableReadInput(WINDOW* window);
|
||||||
|
int innerEquipInput(WINDOW* window);
|
||||||
|
void printEquipWindowNumberText(WINDOW* window);
|
||||||
|
void printEquipNumbersArrow(WINDOW* window);
|
||||||
|
|
||||||
|
|
||||||
extern byte m12_other_str9;
|
extern byte m12_other_str9[];
|
||||||
extern byte m12_other_str10;
|
extern byte m12_other_str10[];
|
||||||
extern byte m12_other_str11;
|
extern byte m12_other_str11[];
|
||||||
extern byte m12_other_str12;
|
extern byte m12_other_str12[];
|
||||||
|
|
||||||
#endif
|
#endif
|
39
src/c/vwf.c
39
src/c/vwf.c
|
@ -181,21 +181,18 @@ void print_special_character(int tile, int x, int y)
|
||||||
cpufastset(&vram[(sourceTileIndex + 32) * 8], &vram[(destTileIndex + 32) * 8], 8);
|
cpufastset(&vram[(sourceTileIndex + 32) * 8], &vram[(destTileIndex + 32) * 8], 8);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Prints a special tile. Pixels are copied to the VWF buffer. Prints in the buffer
|
// Prints a special tile. Pixels are not copied.
|
||||||
// x, y in pixels
|
// x, y in pixels
|
||||||
void print_special_character_buffer(int tile, int x, int y, int *dest)
|
void print_special_character_buffer(int tile, int x, int y)
|
||||||
{
|
{
|
||||||
// Special graphics must be tile-aligned
|
// Special graphics must be tile-aligned
|
||||||
x >>= 3;
|
x >>= 3;
|
||||||
y >>= 3;
|
y >>= 3;
|
||||||
unsigned short sourceTileIndex = tile + *tile_offset;
|
unsigned short sourceTileIndex = tile + *tile_offset;
|
||||||
unsigned short destTileIndex = get_tile_number(x, y) + *tile_offset;
|
|
||||||
|
|
||||||
(*tilemap_pointer)[x + (y * 32)] = destTileIndex | *palette_mask;
|
(*tilemap_pointer)[x + (y * 32)] = sourceTileIndex | *palette_mask;
|
||||||
(*tilemap_pointer)[x + ((y + 1) * 32)] = (destTileIndex + 32) | *palette_mask;
|
(*tilemap_pointer)[x + ((y + 1) * 32)] = (sourceTileIndex + 32) | *palette_mask;
|
||||||
|
|
||||||
cpufastset(&dest[sourceTileIndex * 8], &dest[destTileIndex * 8], 8);
|
|
||||||
cpufastset(&dest[(sourceTileIndex + 32) * 8], &dest[(destTileIndex + 32) * 8], 8);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Maps a special character to the given tile coordinates. Only the tilemap is changed.
|
// Maps a special character to the given tile coordinates. Only the tilemap is changed.
|
||||||
|
@ -1189,15 +1186,15 @@ byte print_character_formatted_buffer(byte chr, int x, int y, int font, int fore
|
||||||
// 0x64 to 0x6C (inclusive) is YOU WON
|
// 0x64 to 0x6C (inclusive) is YOU WON
|
||||||
if ((chr >= YOUWON_START) && (chr <= YOUWON_END))
|
if ((chr >= YOUWON_START) && (chr <= YOUWON_END))
|
||||||
{
|
{
|
||||||
print_special_character_buffer(chr + 0xF0, x, y, dest);
|
print_special_character_buffer(chr + 0xF0, x, y);
|
||||||
return 8;
|
return 8;
|
||||||
}
|
}
|
||||||
|
|
||||||
// 0x6D is an arrow ->
|
// 0x6D is an arrow ->
|
||||||
if (chr == ARROW)
|
if (chr == ARROW)
|
||||||
{
|
{
|
||||||
print_special_character_buffer(ARROW + 0x30, x, y, dest);
|
print_special_character_buffer(ARROW + 0x30, x, y);
|
||||||
return 8;
|
return 9;
|
||||||
}
|
}
|
||||||
|
|
||||||
return print_character_with_callback(chr, x, y, font, foreground, dest, &get_tile_number_with_offset, *tilemap_pointer, 32, 0xC);
|
return print_character_with_callback(chr, x, y, font, foreground, dest, &get_tile_number_with_offset, *tilemap_pointer, 32, 0xC);
|
||||||
|
@ -1258,10 +1255,21 @@ int print_string_in_buffer(byte *str, int x, int y, int *dest)
|
||||||
int initial_x = x;
|
int initial_x = x;
|
||||||
int charCount = 0;
|
int charCount = 0;
|
||||||
|
|
||||||
while (str[1] != 0xFF)
|
while (str[1] != 0xFF || str[0] != 0)
|
||||||
{
|
{
|
||||||
x += print_character_formatted_buffer(decode_character(*str++), x, y, 0, 0xF, dest);
|
if(str[1] == 0xFF && str[0] == 1)
|
||||||
charCount++;
|
{
|
||||||
|
x = initial_x;
|
||||||
|
str += 2;
|
||||||
|
y+= 0x10;
|
||||||
|
}
|
||||||
|
else if(str[1] != 0xFF)
|
||||||
|
{
|
||||||
|
x += print_character_formatted_buffer(decode_character(*str++), x, y, 0, 0xF, dest);
|
||||||
|
charCount++;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
int totalWidth = x - initial_x;
|
int totalWidth = x - initial_x;
|
||||||
|
@ -1545,6 +1553,11 @@ unsigned short ailmentTileSetup(byte *ailmentBase, unsigned short defaultVal)
|
||||||
return (*(returnValues + (value * 7) + flagValue - 1));
|
return (*(returnValues + (value * 7) + flagValue - 1));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void printTinyArrow(int x, int y)
|
||||||
|
{
|
||||||
|
print_special_character_buffer(0x9F, x, y);
|
||||||
|
}
|
||||||
|
|
||||||
void printCashWindow()
|
void printCashWindow()
|
||||||
{
|
{
|
||||||
(*window_flags) |= 2;
|
(*window_flags) |= 2;
|
||||||
|
|
|
@ -103,6 +103,7 @@ int setNumber_getLength(int value, byte *str, int maxLength);
|
||||||
int print_string_in_buffer(byte *str, int x, int y, int *dest);
|
int print_string_in_buffer(byte *str, int x, int y, int *dest);
|
||||||
void printCashWindow();
|
void printCashWindow();
|
||||||
WINDOW* getWindow(int index);
|
WINDOW* getWindow(int index);
|
||||||
|
void printTinyArrow(int x, int y);
|
||||||
int printstr_buffer(WINDOW* window, byte* str, unsigned short x, unsigned short y, bool highlight);
|
int printstr_buffer(WINDOW* window, byte* str, unsigned short x, unsigned short y, bool highlight);
|
||||||
unsigned short printstr_hlight_buffer(WINDOW* window, byte* str, unsigned short x, unsigned short y, bool highlight);
|
unsigned short printstr_hlight_buffer(WINDOW* window, byte* str, unsigned short x, unsigned short y, bool highlight);
|
||||||
unsigned short printstr_hlight_pixels_buffer(WINDOW* window, byte* str, unsigned short x, unsigned short y, bool highlight);
|
unsigned short printstr_hlight_pixels_buffer(WINDOW* window, byte* str, unsigned short x, unsigned short y, bool highlight);
|
||||||
|
@ -123,6 +124,7 @@ extern byte m2_cstm_last_printed[];
|
||||||
extern byte *m2_script_readability;
|
extern byte *m2_script_readability;
|
||||||
extern int overworld_buffer;
|
extern int overworld_buffer;
|
||||||
extern PC m2_ness_data[];
|
extern PC m2_ness_data[];
|
||||||
|
extern int m2_arrow_tile[];
|
||||||
|
|
||||||
extern bool m2_isequipped(int item_index);
|
extern bool m2_isequipped(int item_index);
|
||||||
extern void cpufastset(void *source, void *dest, int mode);
|
extern void cpufastset(void *source, void *dest, int mode);
|
||||||
|
|
|
@ -167,15 +167,16 @@ mov r3,6
|
||||||
// Equip window generic hacks
|
// Equip window generic hacks
|
||||||
//---------------------------------------------------------
|
//---------------------------------------------------------
|
||||||
|
|
||||||
|
.org 0x80BB02C :: bl innerEquipInput
|
||||||
.org 0x80B8066 :: bl printstr_hlight_buffer
|
.org 0x80B8066 :: bl printstr_hlight_buffer
|
||||||
.org 0x80B8074 :: mov r3,#0x12
|
.org 0x80B8074 :: mov r3,#0x12
|
||||||
.org 0x80B80A6 :: mov r3,#0x0D
|
.org 0x80B80A6 :: mov r3,#0x0D
|
||||||
.org 0x80B8092 :: bl initWindow_buffer //Initialize equipment window
|
.org 0x80B8092 :: bl initWindow_buffer //Initialize equipment window
|
||||||
.org 0x80B8098 :: bl print_window_with_buffer
|
.org 0x80B8098 :: bl print_window_with_buffer
|
||||||
.org 0x80B80BE :: bl initWindow_buffer
|
.org 0x80B80BE :: bl initWindow_buffer
|
||||||
.org 0x80B80C4 :: bl print_window_with_buffer
|
.org 0x80B80C4 :: bl printEquipWindowNumberText
|
||||||
.org 0x80B80EA :: mov r2,#6 :: mov r3,#0 :: bl printstr_buffer //Offense Number
|
.org 0x80B80EA :: mov r2,#0x37 :: mov r3,#3 :: bl printNumberEquip //Offense Number
|
||||||
.org 0x80B8112 :: mov r2,#6 :: mov r3,#1 :: bl printstr_buffer //Defense Number
|
.org 0x80B8112 :: mov r2,#0x37 :: mov r3,#0x13 :: bl printNumberEquip //Defense Number
|
||||||
.org 0x80B8138 :: bl initWindow_buffer
|
.org 0x80B8138 :: bl initWindow_buffer
|
||||||
.org 0x80B813E :: bl print_window_with_buffer
|
.org 0x80B813E :: bl print_window_with_buffer
|
||||||
.org 0x80B814A :: bl equipPrint
|
.org 0x80B814A :: bl equipPrint
|
||||||
|
@ -185,14 +186,14 @@ mov r3,6
|
||||||
.org 0x80B81CC :: bl store_pixels_overworld
|
.org 0x80B81CC :: bl store_pixels_overworld
|
||||||
.org 0x80BAF96 :: bl initWindow_buffer //Go to inner window from outer window
|
.org 0x80BAF96 :: bl initWindow_buffer //Go to inner window from outer window
|
||||||
.org 0x80BAF9C :: bl baf9c_print_window_store_buffer
|
.org 0x80BAF9C :: bl baf9c_print_window_store_buffer
|
||||||
.org 0x80BAFE6 :: mov r2,#6 :: mov r3,#0 :: bl printstr_buffer //Offense Number
|
.org 0x80BAFE6 :: mov r2,#0x37 :: mov r3,#3 :: bl printNumberEquip //Offense Number
|
||||||
.org 0x80BB00C :: mov r2,#6
|
.org 0x80BB00C :: mov r2,#0x37
|
||||||
.org 0x80BB17C :: bl equippableReadInput
|
.org 0x80BB17C :: bl equippableReadInput
|
||||||
.org 0x80BB198 :: mov r2,#9 :: mov r3,#0 :: bl printstr_buffer //Offense Number
|
.org 0x80BB198 :: bl printEquipNumbersArrow :: bl store_pixels_overworld :: b 0x80BB1AE //Offense Number
|
||||||
.org 0x80BB1A6 :: mov r2,#9 :: mov r3,#1 :: bl bb1aa_printstr_store //Defense Number
|
.org 0x80BB1A6 :: mov r2,#0x4C :: mov r3,#0x13 :: bl bb1aa_printnumberequip_store //Defense Number
|
||||||
.org 0x80BB05E :: bl initWindow_buffer
|
.org 0x80BB05E :: bl initWindow_buffer
|
||||||
.org 0x80BB066 :: bl print_window_with_buffer
|
.org 0x80BB066 :: bl print_window_with_buffer
|
||||||
.org 0x80BB08A :: bl printstr_buffer
|
.org 0x80BB08A :: nop :: nop //Remove highlighting
|
||||||
.org 0x80BB0A8 :: bl initWindow_buffer
|
.org 0x80BB0A8 :: bl initWindow_buffer
|
||||||
.org 0x80BB24C :: bl initWindow_buffer //Go back to outer window - Also does going back to inner (not innermost) window from weapons - not touched equipment
|
.org 0x80BB24C :: bl initWindow_buffer //Go back to outer window - Also does going back to inner (not innermost) window from weapons - not touched equipment
|
||||||
.org 0x80BB254 :: bl print_window_with_buffer
|
.org 0x80BB254 :: bl print_window_with_buffer
|
||||||
|
@ -201,65 +202,59 @@ mov r3,6
|
||||||
.org 0x80BB2E0 :: bl initWindow_buffer
|
.org 0x80BB2E0 :: bl initWindow_buffer
|
||||||
.org 0x80BB2E8 :: bl print_window_with_buffer
|
.org 0x80BB2E8 :: bl print_window_with_buffer
|
||||||
.org 0x80BB2F6 :: bl equipPrint
|
.org 0x80BB2F6 :: bl equipPrint
|
||||||
.org 0x80BB33C :: mov r2,#6
|
.org 0x80BB300 :: bl innerEquipInput
|
||||||
.org 0x80BB340 :: bl printstr_buffer
|
.org 0x80BB33C :: mov r2,#0x37 :: mov r3,#3 :: bl printNumberEquip
|
||||||
.org 0x80BB36C :: mov r2,#6
|
.org 0x80BB36C :: mov r2,#0x37 :: mov r3,#0x13 :: bl printNumberEquip
|
||||||
.org 0x80BB370 :: bl printstr_buffer
|
|
||||||
.org 0x80BB3FC :: bl initWindow_buffer //Go back to inner (not innermost) window from weapons - removed equipment
|
.org 0x80BB3FC :: bl initWindow_buffer //Go back to inner (not innermost) window from weapons - removed equipment
|
||||||
.org 0x80BB404 :: bl print_window_with_buffer
|
.org 0x80BB404 :: bl print_window_with_buffer
|
||||||
.org 0x80BB41A :: bl initWindow_buffer
|
.org 0x80BB41A :: bl initWindow_buffer
|
||||||
.org 0x80BB422 :: bl print_window_with_buffer
|
.org 0x80BB422 :: bl print_window_with_buffer
|
||||||
.org 0x80BB430 :: bl equipPrint
|
.org 0x80BB430 :: bl equipPrint
|
||||||
.org 0x80BB476 :: mov r2,#6
|
.org 0x80BB43A :: bl innerEquipInput
|
||||||
.org 0x80BB47A :: bl printstr_buffer
|
.org 0x80BB476 :: mov r2,#0x37 :: mov r3,#3 :: bl printNumberEquip
|
||||||
.org 0x80BB4A6 :: mov r2,#6
|
.org 0x80BB4A6 :: mov r2,#0x37 :: mov r3,#0x13 :: bl printNumberEquip
|
||||||
.org 0x80BB4AA :: bl printstr_buffer
|
|
||||||
.org 0x80BB532 :: bl initWindow_buffer //Go back to inner (not innermost) window from weapons - equipped a weapon
|
.org 0x80BB532 :: bl initWindow_buffer //Go back to inner (not innermost) window from weapons - equipped a weapon
|
||||||
.org 0x80BB53A :: bl print_window_with_buffer
|
.org 0x80BB53A :: bl print_window_with_buffer
|
||||||
.org 0x80BB550 :: bl initWindow_buffer
|
.org 0x80BB550 :: bl initWindow_buffer
|
||||||
.org 0x80BB558 :: bl print_window_with_buffer
|
.org 0x80BB558 :: bl print_window_with_buffer
|
||||||
.org 0x80BB566 :: bl equipPrint
|
.org 0x80BB566 :: bl equipPrint
|
||||||
.org 0x80BB5AC :: mov r2,#6
|
.org 0x80BB570 :: bl innerEquipInput
|
||||||
.org 0x80BB5B0 :: bl printstr_buffer
|
.org 0x80BB5AC :: mov r2,#0x37 :: mov r3,#3 :: bl printNumberEquip
|
||||||
.org 0x80BB5DC :: mov r2,#6
|
.org 0x80BB5DC :: mov r2,#0x37 :: mov r3,#0x13 :: bl printNumberEquip
|
||||||
.org 0x80BB5E0 :: bl printstr_buffer
|
|
||||||
.org 0x80BB9E4 :: bl initWindow_buffer //Go back to inner (not innermost) window from defensive equipment - not touched equipment
|
.org 0x80BB9E4 :: bl initWindow_buffer //Go back to inner (not innermost) window from defensive equipment - not touched equipment
|
||||||
.org 0x80BB9EC :: bl print_window_with_buffer
|
.org 0x80BB9EC :: bl print_window_with_buffer
|
||||||
.org 0x80BBA02 :: bl initWindow_buffer
|
.org 0x80BBA02 :: bl initWindow_buffer
|
||||||
.org 0x80BBA0A :: bl print_window_with_buffer
|
.org 0x80BBA0A :: bl print_window_with_buffer
|
||||||
.org 0x80BBA18 :: bl equipPrint
|
.org 0x80BBA18 :: bl equipPrint
|
||||||
.org 0x80BBA5E :: mov r2,#6
|
.org 0x80BBA22 :: bl innerEquipInput
|
||||||
.org 0x80BBA62 :: bl printstr_buffer
|
.org 0x80BBA5E :: mov r2,#0x37 :: mov r3,#3 :: bl printNumberEquip
|
||||||
.org 0x80BBA8E :: mov r2,#6
|
.org 0x80BBA8E :: mov r2,#0x37 :: mov r3,#0x13 :: bl printNumberEquip
|
||||||
.org 0x80BBA92 :: bl printstr_buffer
|
|
||||||
.org 0x80BBB2C :: bl initWindow_buffer //Go back to inner (not innermost) window from defensive equipment - removed equipment
|
.org 0x80BBB2C :: bl initWindow_buffer //Go back to inner (not innermost) window from defensive equipment - removed equipment
|
||||||
.org 0x80BBB34 :: bl print_window_with_buffer
|
.org 0x80BBB34 :: bl print_window_with_buffer
|
||||||
.org 0x80BBB4A :: bl initWindow_buffer
|
.org 0x80BBB4A :: bl initWindow_buffer
|
||||||
.org 0x80BBB52 :: bl print_window_with_buffer
|
.org 0x80BBB52 :: bl print_window_with_buffer
|
||||||
.org 0x80BBB60 :: bl equipPrint
|
.org 0x80BBB60 :: bl equipPrint
|
||||||
.org 0x80BBBA6 :: mov r2,#6
|
.org 0x80BBB6A :: bl innerEquipInput
|
||||||
.org 0x80BBBAA :: bl printstr_buffer
|
.org 0x80BBBA6 :: mov r2,#0x37 :: mov r3,#3 :: bl printNumberEquip
|
||||||
.org 0x80BBBD6 :: mov r2,#6
|
.org 0x80BBBD6 :: mov r2,#0x37 :: mov r3,#0x13 :: bl printNumberEquip
|
||||||
.org 0x80BBBDA :: bl printstr_buffer
|
|
||||||
.org 0x80BBC8A :: bl initWindow_buffer //Go back to inner (not innermost) window from defensive equipment - equipped something
|
.org 0x80BBC8A :: bl initWindow_buffer //Go back to inner (not innermost) window from defensive equipment - equipped something
|
||||||
.org 0x80BBC92 :: bl print_window_with_buffer
|
.org 0x80BBC92 :: bl print_window_with_buffer
|
||||||
.org 0x80BBCA8 :: bl initWindow_buffer
|
.org 0x80BBCA8 :: bl initWindow_buffer
|
||||||
.org 0x80BBCB0 :: bl print_window_with_buffer
|
.org 0x80BBCB0 :: bl print_window_with_buffer
|
||||||
.org 0x80BBCBE :: bl equipPrint
|
.org 0x80BBCBE :: bl equipPrint
|
||||||
.org 0x80BBD04 :: mov r2,#6
|
.org 0x80BBCC8 :: bl innerEquipInput
|
||||||
.org 0x80BBD08 :: bl printstr_buffer
|
.org 0x80BBD04 :: mov r2,#0x37 :: mov r3,#3 :: bl printNumberEquip
|
||||||
.org 0x80BBD34 :: mov r2,#6
|
.org 0x80BBD34 :: mov r2,#0x37 :: mov r3,#0x13 :: bl printNumberEquip
|
||||||
.org 0x80BBD38 :: bl printstr_buffer
|
|
||||||
//When first entering the innermost menu
|
//When first entering the innermost menu
|
||||||
.org 0x80BB6E0 :: mov r2,#0xA :: mov r3,#0 :: bl printstr_buffer //Change second offense number's position - Weapon
|
.org 0x80BB6E0 :: mov r2,#0x54 :: mov r3,#3 :: bl printNumberEquip //Change second offense number's position - Weapon
|
||||||
.org 0x80BB710 :: mov r2,#0xA :: mov r3,#1 :: bl bb1aa_printstr_store //Change second defense number's position - Weapon
|
.org 0x80BB710 :: mov r2,#0x54 :: mov r3,#0x13 :: bl bb1aa_printnumberequip_store //Change second defense number's position - Weapon
|
||||||
.org 0x80BB820 :: mov r2,#0xA :: mov r3,#1 :: bl printstr_buffer //Change second defense number's position - Body
|
.org 0x80BB820 :: mov r2,#0x54 :: mov r3,#0x13 :: bl printNumberEquip //Change second defense number's position - Body
|
||||||
.org 0x80BB950 :: mov r2,#0xA :: mov r3,#1 :: bl printstr_buffer //Change second defense number's position - Arms
|
.org 0x80BB950 :: mov r2,#0x54 :: mov r3,#0x13 :: bl printNumberEquip //Change second defense number's position - Arms
|
||||||
.org 0x80BBE8E :: mov r2,#0xA :: mov r3,#1 :: bl printstr_buffer //Change second defense number's position - Other
|
.org 0x80BBE8E :: mov r2,#0x54 :: mov r3,#0x13 :: bl printNumberEquip //Change second defense number's position - Other
|
||||||
.org 0x80BBEBE :: mov r2,#0xA :: mov r3,#0 :: bl bb1aa_printstr_store //Change second offense number's position - Other
|
.org 0x80BBEBE :: mov r2,#0x54 :: mov r3,#3 :: bl bb1aa_printnumberequip_store //Change second offense number's position - Other
|
||||||
//When changing selection in the innermost menu
|
//When changing selection in the innermost menu
|
||||||
.org 0x80BBDF0 :: mov r2,#0xA :: mov r3,#1 :: bl printstr_buffer //Change second defense number's position - Defensive Equipment
|
.org 0x80BBDF0 :: mov r2,#0x54 :: mov r3,#0x13 :: bl printNumberEquip //Change second defense number's position - Defensive Equipment
|
||||||
.org 0x80BBE20 :: mov r2,#0xA :: mov r3,#0 :: bl bb1aa_printstr_store //Change second offense number's position - Defensive Equipment
|
.org 0x80BBE20 :: mov r2,#0x54 :: mov r3,#3 :: bl bb1aa_printnumberequip_store //Change second offense number's position - Defensive Equipment
|
||||||
|
|
||||||
|
|
||||||
//---------------------------------------------------------
|
//---------------------------------------------------------
|
||||||
|
|
|
@ -2538,13 +2538,13 @@ bx r0
|
||||||
|
|
||||||
//==============================================================================
|
//==============================================================================
|
||||||
//Prints defense number and then sotres the buffer
|
//Prints defense number and then sotres the buffer
|
||||||
bb1aa_printstr_store:
|
bb1aa_printnumberequip_store:
|
||||||
push {r4,lr}
|
push {r4,lr}
|
||||||
mov r4,r3
|
mov r4,r3
|
||||||
mov r3,#0
|
mov r3,#0
|
||||||
push {r3}
|
push {r3}
|
||||||
mov r3,r4
|
mov r3,r4
|
||||||
bl printstr_buffer
|
bl printNumberEquip
|
||||||
bl store_pixels_overworld
|
bl store_pixels_overworld
|
||||||
pop {r3}
|
pop {r3}
|
||||||
pop {r4,pc}
|
pop {r4,pc}
|
||||||
|
|
Loading…
Reference in New Issue