Rename tag offset functions

Fix typo
This commit is contained in:
hondew 2020-05-20 16:36:00 -04:00 committed by huderlem
parent 25f0dac1b5
commit 26a197847a
4 changed files with 119 additions and 111 deletions

View file

@ -0,0 +1,42 @@
#ifndef GUARD_CONSTANTS_SLOT_MACHINE_H
#define GUARD_CONSTANTS_SLOT_MACHINE_H
#define NUM_REELS 3
#define REEL_NUM_TAGS 21
#define REEL_TAG_HEIGHT 24
#define SLOT_MACHINE_COUNT 12
// Lucky Flags
#define LUCKY_BIAS_REPLAY (1 << 0)
#define LUCKY_BIAS_CHERRY (1 << 1)
#define LUCKY_BIAS_LOTAD (1 << 2)
#define LUCKY_BIAS_AZURILL (1 << 3)
#define LUCKY_BIAS_POWER (1 << 4)
#define LUCKY_BIAS_REELTIME (1 << 5)
#define LUCKY_BIAS_MIXED_777 (1 << 6)
#define LUCKY_BIAS_777 (1 << 7)
#define SLOT_MACHINE_TAG_7_RED 0
#define SLOT_MACHINE_TAG_7_BLUE 1
#define SLOT_MACHINE_TAG_AZURILL 2
#define SLOT_MACHINE_TAG_LOTAD 3
#define SLOT_MACHINE_TAG_CHERRY 4
#define SLOT_MACHINE_TAG_POWER 5
#define SLOT_MACHINE_TAG_REPLAY 6
#define SLOT_MACHINE_MATCHED_1CHERRY 0
#define SLOT_MACHINE_MATCHED_2CHERRY 1
#define SLOT_MACHINE_MATCHED_REPLAY 2
#define SLOT_MACHINE_MATCHED_LOTAD 3
#define SLOT_MACHINE_MATCHED_AZURILL 4
#define SLOT_MACHINE_MATCHED_POWER 5
#define SLOT_MACHINE_MATCHED_777_MIXED 6
#define SLOT_MACHINE_MATCHED_777_RED 7
#define SLOT_MACHINE_MATCHED_777_BLUE 8
#define SLOT_MACHINE_MATCHED_NONE 9
#define LEFT_REEL 0
#define MIDDLE_REEL 1
#define RIGHT_REEL 2
#endif // GUARD_CONSTANTS_SLOT_MACHINE_H

View file

@ -1,21 +1,6 @@
#ifndef GUARD_SLOT_MACHINE_H #ifndef GUARD_SLOT_MACHINE_H
#define GUARD_SLOT_MACHINE_H #define GUARD_SLOT_MACHINE_H
#define NUM_REELS 3
#define REEL_NUM_TAGS 21
#define REEL_TAG_HEIGHT 24
#define SLOT_MACHINE_COUNT 12
// Lucky Flags
#define LUCKY_BIAS_REPLAY (1 << 0)
#define LUCKY_BIAS_CHERRY (1 << 1)
#define LUCKY_BIAS_LOTAD (1 << 2)
#define LUCKY_BIAS_AZURILL (1 << 3)
#define LUCKY_BIAS_POWER (1 << 4)
#define LUCKY_BIAS_REELTIME (1 << 5)
#define LUCKY_BIAS_MIXED_777 (1 << 6)
#define LUCKY_BIAS_777 (1 << 7)
void PlaySlotMachine(u8, void (callback)(void)); void PlaySlotMachine(u8, void (callback)(void));
#endif // GUARD_SLOT_MACHINE_H #endif // GUARD_SLOT_MACHINE_H

View file

@ -35,7 +35,6 @@
#include "rtc.h" #include "rtc.h"
#include "script.h" #include "script.h"
#include "script_menu.h" #include "script_menu.h"
#include "slot_machine.h"
#include "sound.h" #include "sound.h"
#include "starter_choose.h" #include "starter_choose.h"
#include "string_util.h" #include "string_util.h"
@ -59,6 +58,7 @@
#include "constants/mevent.h" #include "constants/mevent.h"
#include "constants/tv.h" #include "constants/tv.h"
#include "constants/script_menu.h" #include "constants/script_menu.h"
#include "constants/slot_machine.h"
#include "constants/songs.h" #include "constants/songs.h"
#include "constants/species.h" #include "constants/species.h"
#include "constants/moves.h" #include "constants/moves.h"

View file

@ -25,6 +25,7 @@
#include "bg.h" #include "bg.h"
#include "window.h" #include "window.h"
#include "constants/coins.h" #include "constants/coins.h"
#include "constants/slot_machine.h"
// Text // Text
extern const u8 gText_YouDontHaveThreeCoins[]; extern const u8 gText_YouDontHaveThreeCoins[];
@ -33,31 +34,6 @@ extern const u8 gText_YouveGot9999Coins[];
extern const u8 gText_YouveRunOutOfCoins[]; extern const u8 gText_YouveRunOutOfCoins[];
extern const u8 gText_ReelTimeHelp[]; extern const u8 gText_ReelTimeHelp[];
enum
{
SLOT_MACHINE_TAG_7_RED,
SLOT_MACHINE_TAG_7_BLUE,
SLOT_MACHINE_TAG_AZURILL,
SLOT_MACHINE_TAG_LOTAD,
SLOT_MACHINE_TAG_CHERRY,
SLOT_MACHINE_TAG_POWER,
SLOT_MACHINE_TAG_REPLAY
};
enum
{
SLOT_MACHINE_MATCHED_1CHERRY,
SLOT_MACHINE_MATCHED_2CHERRY,
SLOT_MACHINE_MATCHED_REPLAY,
SLOT_MACHINE_MATCHED_LOTAD,
SLOT_MACHINE_MATCHED_AZURILL,
SLOT_MACHINE_MATCHED_POWER,
SLOT_MACHINE_MATCHED_777_MIXED,
SLOT_MACHINE_MATCHED_777_RED,
SLOT_MACHINE_MATCHED_777_BLUE,
SLOT_MACHINE_MATCHED_NONE
};
struct SlotMachineEwramStruct struct SlotMachineEwramStruct
{ {
/*0x00*/ u8 state; /*0x00*/ u8 state;
@ -81,7 +57,7 @@ struct SlotMachineEwramStruct
/*0x1A*/ s16 reelIncrement; // speed of reel /*0x1A*/ s16 reelIncrement; // speed of reel
/*0x1C*/ s16 reelPixelOffsets[3]; /*0x1C*/ s16 reelPixelOffsets[3];
/*0x22*/ u16 reelPixelOffsetsWhileStopping[3]; /*0x22*/ u16 reelPixelOffsetsWhileStopping[3];
/*0x28*/ s16 reelTagOffsets[3]; /*0x28*/ s16 reelPositions[3];
/*0x2E*/ s16 reelExtraTurns[3]; /*0x2E*/ s16 reelExtraTurns[3];
/*0x34*/ s16 winnerRows[3]; /*0x34*/ s16 winnerRows[3];
/*0x3A*/ u8 slotReelTasks[3]; /*0x3A*/ u8 slotReelTasks[3];
@ -184,7 +160,7 @@ static bool8 IsFinalTask_RunAwardPayoutActions(void);
static bool8 AwardPayoutAction0(struct Task *task); static bool8 AwardPayoutAction0(struct Task *task);
static bool8 AwardPayoutAction_GivePayoutToPlayer(struct Task *task); static bool8 AwardPayoutAction_GivePayoutToPlayer(struct Task *task);
static bool8 AwardPayoutAction_FreeTask(struct Task *task); static bool8 AwardPayoutAction_FreeTask(struct Task *task);
static u8 GetNearbyTag_Quantized(u8 x, s16 y); static u8 GetTagAtRest(u8 x, s16 y);
static void GameplayTask_StopSlotReel(void); static void GameplayTask_StopSlotReel(void);
static void ReelTasks_SetUnkTaskData(u8 a0); static void ReelTasks_SetUnkTaskData(u8 a0);
static void sub_8102E1C(u8 a0); static void sub_8102E1C(u8 a0);
@ -890,8 +866,8 @@ static void SlotMachineSetup_0_1(void)
for (i = 0; i < NUM_REELS; i++) for (i = 0; i < NUM_REELS; i++)
{ {
sSlotMachine->reelPixelOffsetsWhileStopping[i] = 0; sSlotMachine->reelPixelOffsetsWhileStopping[i] = 0;
sSlotMachine->reelTagOffsets[i] = gInitialReelPositions[i][sSlotMachine->luckyGame] % REEL_NUM_TAGS; sSlotMachine->reelPositions[i] = gInitialReelPositions[i][sSlotMachine->luckyGame] % REEL_NUM_TAGS;
sSlotMachine->reelPixelOffsets[i] = REEL_NUM_TAGS * REEL_TAG_HEIGHT - sSlotMachine->reelTagOffsets[i] * REEL_TAG_HEIGHT; sSlotMachine->reelPixelOffsets[i] = REEL_NUM_TAGS * REEL_TAG_HEIGHT - sSlotMachine->reelPositions[i] * REEL_TAG_HEIGHT;
sSlotMachine->reelPixelOffsets[i] %= REEL_NUM_TAGS * REEL_TAG_HEIGHT; sSlotMachine->reelPixelOffsets[i] %= REEL_NUM_TAGS * REEL_TAG_HEIGHT;
} }
AlertTVThatPlayerPlayedSlotMachine(GetCoins()); AlertTVThatPlayerPlayedSlotMachine(GetCoins());
@ -1598,9 +1574,9 @@ static void CheckMatch_CenterRow(void)
{ {
u8 c1, c2, c3, match; u8 c1, c2, c3, match;
c1 = GetNearbyTag_Quantized(0, 2); c1 = GetTagAtRest(LEFT_REEL, 2);
c2 = GetNearbyTag_Quantized(1, 2); c2 = GetTagAtRest(MIDDLE_REEL, 2);
c3 = GetNearbyTag_Quantized(2, 2); c3 = GetTagAtRest(RIGHT_REEL, 2);
match = GetMatchFromSymbolsInRow(c1, c2, c3); match = GetMatchFromSymbolsInRow(c1, c2, c3);
if (match != SLOT_MACHINE_MATCHED_NONE) if (match != SLOT_MACHINE_MATCHED_NONE)
{ {
@ -1614,9 +1590,9 @@ static void CheckMatch_TopAndBottom(void)
{ {
u8 c1, c2, c3, match; u8 c1, c2, c3, match;
c1 = GetNearbyTag_Quantized(0, 1); c1 = GetTagAtRest(LEFT_REEL, 1);
c2 = GetNearbyTag_Quantized(1, 1); c2 = GetTagAtRest(MIDDLE_REEL, 1);
c3 = GetNearbyTag_Quantized(2, 1); c3 = GetTagAtRest(RIGHT_REEL, 1);
match = GetMatchFromSymbolsInRow(c1, c2, c3); match = GetMatchFromSymbolsInRow(c1, c2, c3);
if (match != SLOT_MACHINE_MATCHED_NONE) if (match != SLOT_MACHINE_MATCHED_NONE)
{ {
@ -1626,9 +1602,9 @@ static void CheckMatch_TopAndBottom(void)
sSlotMachine->matchedSymbols |= gSlotMatchFlags[match]; sSlotMachine->matchedSymbols |= gSlotMatchFlags[match];
sub_8103E04(1); sub_8103E04(1);
} }
c1 = GetNearbyTag_Quantized(0, 3); c1 = GetTagAtRest(LEFT_REEL, 3);
c2 = GetNearbyTag_Quantized(1, 3); c2 = GetTagAtRest(MIDDLE_REEL, 3);
c3 = GetNearbyTag_Quantized(2, 3); c3 = GetTagAtRest(RIGHT_REEL, 3);
match = GetMatchFromSymbolsInRow(c1, c2, c3); match = GetMatchFromSymbolsInRow(c1, c2, c3);
if (match != SLOT_MACHINE_MATCHED_NONE) if (match != SLOT_MACHINE_MATCHED_NONE)
{ {
@ -1644,9 +1620,9 @@ static void CheckMatch_Diagonals(void)
{ {
u8 c1, c2, c3, match; u8 c1, c2, c3, match;
c1 = GetNearbyTag_Quantized(0, 1); c1 = GetTagAtRest(LEFT_REEL, 1);
c2 = GetNearbyTag_Quantized(1, 2); c2 = GetTagAtRest(MIDDLE_REEL, 2);
c3 = GetNearbyTag_Quantized(2, 3); c3 = GetTagAtRest(RIGHT_REEL, 3);
match = GetMatchFromSymbolsInRow(c1, c2, c3); match = GetMatchFromSymbolsInRow(c1, c2, c3);
if (match != SLOT_MACHINE_MATCHED_NONE) if (match != SLOT_MACHINE_MATCHED_NONE)
{ {
@ -1657,9 +1633,9 @@ static void CheckMatch_Diagonals(void)
} }
sub_8103E04(3); sub_8103E04(3);
} }
c1 = GetNearbyTag_Quantized(0, 3); c1 = GetTagAtRest(LEFT_REEL, 3);
c2 = GetNearbyTag_Quantized(1, 2); c2 = GetTagAtRest(MIDDLE_REEL, 2);
c3 = GetNearbyTag_Quantized(2, 1); c3 = GetTagAtRest(RIGHT_REEL, 1);
match = GetMatchFromSymbolsInRow(c1, c2, c3); match = GetMatchFromSymbolsInRow(c1, c2, c3);
if (match != SLOT_MACHINE_MATCHED_NONE) if (match != SLOT_MACHINE_MATCHED_NONE)
{ {
@ -1751,25 +1727,30 @@ static bool8 AwardPayoutAction_FreeTask(struct Task *task)
return FALSE; return FALSE;
} }
// Get the tag at position `offset` below the top of the reel window
// Returns the tag that is posOffset below the tag at the top of reelIndex's tape // .-----------------.
static u8 GetNearbyTag_Quantized(u8 reelIndex, s16 posOffset) // | 7RD | 7RD | 7RD | <- offset = 0
// /-----|-----|-----\
// screen -> | CHY | CHY | POW | <- offset = 1
// | AZU | REP | 7BL | <- offset = 2
// | REP | LOT | REP | <- offset = 3
// \-----|-----|-----/
static u8 GetTagAtRest(u8 reel, s16 offset)
{ {
s16 tagIndex = (sSlotMachine->reelTagOffsets[reelIndex] + posOffset) % REEL_NUM_TAGS; s16 pos = (sSlotMachine->reelPositions[reel] + offset) % REEL_NUM_TAGS;
if (tagIndex < 0) if (pos < 0)
tagIndex += REEL_NUM_TAGS; pos += REEL_NUM_TAGS;
return gReelSymbols[reelIndex][tagIndex]; return gReelSymbols[reel][pos];
} }
// Calculates GetTagAtRest as if the reel were snapped downwards into place.
// Calculates GetNearbyTag_Quantized as if the reel was snapped downwards into place static u8 GetTag(u8 reel, s16 offset)
static u8 GetNearbyTag(u8 reelIndex, s16 posOffset)
{ {
s16 tagOffset = 0; s16 inc = 0;
s16 result = sSlotMachine->reelPixelOffsets[reelIndex] % 24; s16 pixelOffset = sSlotMachine->reelPixelOffsets[reel] % REEL_TAG_HEIGHT;
if (result != 0) if (pixelOffset != 0)
tagOffset = -1; inc = -1;
return GetNearbyTag_Quantized(reelIndex, posOffset + tagOffset); return GetTagAtRest(reel, offset + inc);
} }
static u8 GetNearbyReelTimeTag(s16 n) static u8 GetNearbyReelTimeTag(s16 n)
@ -1784,7 +1765,7 @@ static void AdvanceSlotReel(u8 reelIndex, s16 value)
{ {
sSlotMachine->reelPixelOffsets[reelIndex] += value; sSlotMachine->reelPixelOffsets[reelIndex] += value;
sSlotMachine->reelPixelOffsets[reelIndex] %= 504; sSlotMachine->reelPixelOffsets[reelIndex] %= 504;
sSlotMachine->reelTagOffsets[reelIndex] = REEL_NUM_TAGS - sSlotMachine->reelPixelOffsets[reelIndex] / 24; sSlotMachine->reelPositions[reelIndex] = REEL_NUM_TAGS - sSlotMachine->reelPixelOffsets[reelIndex] / 24;
} }
s16 AdvanceSlotReelToNextTag(u8 reelIndex, s16 value) s16 AdvanceSlotReelToNextTag(u8 reelIndex, s16 value)
@ -1940,7 +1921,7 @@ static bool8 DecideReelTurns_BiasTag_Reel1(void)
static bool8 AreTagsAtPosition_Reel1(s16 pos, u8 tag1, u8 tag2) static bool8 AreTagsAtPosition_Reel1(s16 pos, u8 tag1, u8 tag2)
{ {
u8 tag = GetNearbyTag(0, pos); u8 tag = GetTag(LEFT_REEL, pos);
if (tag == tag1 || tag == tag2) if (tag == tag1 || tag == tag2)
{ {
sSlotMachine->biasTag = tag; sSlotMachine->biasTag = tag;
@ -1951,7 +1932,7 @@ static bool8 AreTagsAtPosition_Reel1(s16 pos, u8 tag1, u8 tag2)
static bool8 AreCherriesOnScreen_Reel1(s16 offsetFromCenter) static bool8 AreCherriesOnScreen_Reel1(s16 offsetFromCenter)
{ {
if (GetNearbyTag(0, 1 - offsetFromCenter) == SLOT_MACHINE_TAG_CHERRY || GetNearbyTag(0, 2 - offsetFromCenter) == SLOT_MACHINE_TAG_CHERRY || GetNearbyTag(0, 3 - offsetFromCenter) == SLOT_MACHINE_TAG_CHERRY) if (GetTag(LEFT_REEL, 1 - offsetFromCenter) == SLOT_MACHINE_TAG_CHERRY || GetTag(LEFT_REEL, 2 - offsetFromCenter) == SLOT_MACHINE_TAG_CHERRY || GetTag(LEFT_REEL, 3 - offsetFromCenter) == SLOT_MACHINE_TAG_CHERRY)
return TRUE; return TRUE;
else else
return FALSE; return FALSE;
@ -2046,7 +2027,7 @@ static bool8 DecideReelTurns_BiasTag_Reel2_Bet1or2(void)
for (i = 0; i < 5; i++) for (i = 0; i < 5; i++)
{ {
// if biasTag appears in the same row within 4 turns // if biasTag appears in the same row within 4 turns
if (GetNearbyTag(1, biasTagLocation_Reel1 - i) == sSlotMachine->biasTag) if (GetTag(MIDDLE_REEL, biasTagLocation_Reel1 - i) == sSlotMachine->biasTag)
{ {
sSlotMachine->winnerRows[1] = biasTagLocation_Reel1; sSlotMachine->winnerRows[1] = biasTagLocation_Reel1;
sSlotMachine->reelExtraTurns[1] = i; sSlotMachine->reelExtraTurns[1] = i;
@ -2068,7 +2049,7 @@ static bool8 DecideReelTurns_BiasTag_Reel2_Bet3(void)
for (i = 0; i < 5; i++) for (i = 0; i < 5; i++)
{ {
//...and if the bias tag will appear in the middle row within 4 turns //...and if the bias tag will appear in the middle row within 4 turns
if (GetNearbyTag(1, 2 - i) == sSlotMachine->biasTag) if (GetTag(MIDDLE_REEL, 2 - i) == sSlotMachine->biasTag)
{ {
sSlotMachine->winnerRows[1] = 2; sSlotMachine->winnerRows[1] = 2;
sSlotMachine->reelExtraTurns[1] = i; sSlotMachine->reelExtraTurns[1] = i;
@ -2084,7 +2065,7 @@ static bool8 DecideReelTurns_BiasTag_Reel2_Bet3(void)
for (i = 0; i < 5; i++) for (i = 0; i < 5; i++)
{ {
//...and if the biasTag will appear in the center row of reel 2 within 4 turns //...and if the biasTag will appear in the center row of reel 2 within 4 turns
if (GetNearbyTag(1, 2 - i) == sSlotMachine->biasTag) if (GetTag(MIDDLE_REEL, 2 - i) == sSlotMachine->biasTag)
{ {
sSlotMachine->winnerRows[1] = 2; sSlotMachine->winnerRows[1] = 2;
sSlotMachine->reelExtraTurns[1] = i; sSlotMachine->reelExtraTurns[1] = i;
@ -2117,7 +2098,7 @@ static bool8 DecideReelTurns_BiasTag_Reel3_Bet1or2(u8 biasTag)
for (i = 0; i < 5; i++) for (i = 0; i < 5; i++)
{ {
// if the biasTag appears in the same row as in reel 2 within 4 turns // if the biasTag appears in the same row as in reel 2 within 4 turns
if (GetNearbyTag(2, biasTagLocation_Reel2 - i) == biasTag) if (GetTag(RIGHT_REEL, biasTagLocation_Reel2 - i) == biasTag)
{ {
sSlotMachine->winnerRows[2] = biasTagLocation_Reel2; sSlotMachine->winnerRows[2] = biasTagLocation_Reel2;
sSlotMachine->reelExtraTurns[2] = i; sSlotMachine->reelExtraTurns[2] = i;
@ -2143,7 +2124,7 @@ static bool8 DecideReelTurns_BiasTag_Reel3_Bet3(u8 biasTag)
for (i = 0; i < 5; i++) for (i = 0; i < 5; i++)
{ {
// if the biasTag lands in that position within 4 turns // if the biasTag lands in that position within 4 turns
if (GetNearbyTag(2, biasTagFinalPos - i) == biasTag) if (GetTag(RIGHT_REEL, biasTagFinalPos - i) == biasTag)
{ {
sSlotMachine->reelExtraTurns[2] = i; sSlotMachine->reelExtraTurns[2] = i;
sSlotMachine->winnerRows[2] = biasTagFinalPos; sSlotMachine->winnerRows[2] = biasTagFinalPos;
@ -2189,7 +2170,7 @@ static void DecideReelTurns_NoBiasTag_Reel2_Bet1(void)
{ {
if (sSlotMachine->winnerRows[0] != 0 && sSlotMachine->luckyFlags & LUCKY_BIAS_777) if (sSlotMachine->winnerRows[0] != 0 && sSlotMachine->luckyFlags & LUCKY_BIAS_777)
{ {
u8 biasTag = GetNearbyTag(0, 2 - sSlotMachine->reelExtraTurns[0]); u8 biasTag = GetTag(LEFT_REEL, 2 - sSlotMachine->reelExtraTurns[0]);
//...and if biasTag is one of the 7's... //...and if biasTag is one of the 7's...
if (IsBiasTag777_SwitchColor(&biasTag)) if (IsBiasTag777_SwitchColor(&biasTag))
//...swap color of biasTag... //...swap color of biasTag...
@ -2198,7 +2179,7 @@ static void DecideReelTurns_NoBiasTag_Reel2_Bet1(void)
for (i = 0; i < 5; i++) for (i = 0; i < 5; i++)
{ {
//...and if the biasTag appears within 4 turns //...and if the biasTag appears within 4 turns
if (biasTag == GetNearbyTag(1, 2 - i)) if (biasTag == GetTag(MIDDLE_REEL, 2 - i))
{ {
sSlotMachine->winnerRows[1] = 2; sSlotMachine->winnerRows[1] = 2;
sSlotMachine->reelExtraTurns[1] = i; sSlotMachine->reelExtraTurns[1] = i;
@ -2213,7 +2194,7 @@ static void DecideReelTurns_NoBiasTag_Reel2_Bet2(void)
{ {
if (sSlotMachine->winnerRows[0] != 0 && sSlotMachine->luckyFlags & LUCKY_BIAS_777) if (sSlotMachine->winnerRows[0] != 0 && sSlotMachine->luckyFlags & LUCKY_BIAS_777)
{ {
u8 biasTag = GetNearbyTag(0, sSlotMachine->winnerRows[0] - sSlotMachine->reelExtraTurns[0]); u8 biasTag = GetTag(LEFT_REEL, sSlotMachine->winnerRows[0] - sSlotMachine->reelExtraTurns[0]);
//...and if biasTag is one of the 7's... //...and if biasTag is one of the 7's...
if (IsBiasTag777_SwitchColor(&biasTag)) if (IsBiasTag777_SwitchColor(&biasTag))
//...swap color of biasTag... //...swap color of biasTag...
@ -2222,7 +2203,7 @@ static void DecideReelTurns_NoBiasTag_Reel2_Bet2(void)
for (i = 0; i < 5; i++) for (i = 0; i < 5; i++)
{ {
//...and if the biasTag appears in same row in reel 2 within 4 turns //...and if the biasTag appears in same row in reel 2 within 4 turns
if (biasTag == GetNearbyTag(1, sSlotMachine->winnerRows[0] - i)) if (biasTag == GetTag(MIDDLE_REEL, sSlotMachine->winnerRows[0] - i))
{ {
sSlotMachine->winnerRows[1] = sSlotMachine->winnerRows[0]; sSlotMachine->winnerRows[1] = sSlotMachine->winnerRows[0];
sSlotMachine->reelExtraTurns[1] = i; sSlotMachine->reelExtraTurns[1] = i;
@ -2247,7 +2228,7 @@ static void DecideReelTurns_NoBiasTag_Reel2_Bet3(void)
} }
else else
{ {
u8 biasTag = GetNearbyTag(0, sSlotMachine->winnerRows[0] - sSlotMachine->reelExtraTurns[0]); u8 biasTag = GetTag(LEFT_REEL, sSlotMachine->winnerRows[0] - sSlotMachine->reelExtraTurns[0]);
//...and if biasTag is one of the 7's... //...and if biasTag is one of the 7's...
if (IsBiasTag777_SwitchColor(&biasTag)) if (IsBiasTag777_SwitchColor(&biasTag))
//...swap the color of the 7... //...swap the color of the 7...
@ -2257,7 +2238,7 @@ static void DecideReelTurns_NoBiasTag_Reel2_Bet3(void)
j = 3; j = 3;
for (i = 0; i < 2; i++, j--) for (i = 0; i < 2; i++, j--)
{ {
if (biasTag == GetNearbyTag(1, j)) if (biasTag == GetTag(MIDDLE_REEL, j))
{ {
sSlotMachine->winnerRows[1] = j; sSlotMachine->winnerRows[1] = j;
sSlotMachine->reelExtraTurns[1] = 0; sSlotMachine->reelExtraTurns[1] = 0;
@ -2266,7 +2247,7 @@ static void DecideReelTurns_NoBiasTag_Reel2_Bet3(void)
} }
for (j = 1; j < 5; j++) for (j = 1; j < 5; j++)
{ {
if (biasTag == GetNearbyTag(1, sSlotMachine->winnerRows[0] - j)) if (biasTag == GetTag(MIDDLE_REEL, sSlotMachine->winnerRows[0] - j))
{ {
if (sSlotMachine->winnerRows[0] == 1) if (sSlotMachine->winnerRows[0] == 1)
{ {
@ -2340,8 +2321,8 @@ static void DecideReelTurns_NoBiasTag_Reel3(void)
static void DecideReelTurns_NoBiasTag_Reel3_Bet1(void) static void DecideReelTurns_NoBiasTag_Reel3_Bet1(void)
{ {
s16 i = 0; s16 i = 0;
u8 tag1 = GetNearbyTag(0, 2 - sSlotMachine->reelExtraTurns[0]); u8 tag1 = GetTag(LEFT_REEL, 2 - sSlotMachine->reelExtraTurns[0]);
u8 tag2 = GetNearbyTag(1, 2 - sSlotMachine->reelExtraTurns[1]); u8 tag2 = GetTag(MIDDLE_REEL, 2 - sSlotMachine->reelExtraTurns[1]);
// if tags match in first 2 reels... // if tags match in first 2 reels...
if (tag1 == tag2) if (tag1 == tag2)
{ {
@ -2349,7 +2330,7 @@ static void DecideReelTurns_NoBiasTag_Reel3_Bet1(void)
while (1) while (1)
{ {
u8 tag3; u8 tag3;
if (!(tag1 == (tag3 = GetNearbyTag(2, 2 - i)) || (tag1 == SLOT_MACHINE_TAG_7_RED && tag3 == SLOT_MACHINE_TAG_7_BLUE) || (tag1 == SLOT_MACHINE_TAG_7_BLUE && tag3 == SLOT_MACHINE_TAG_7_RED))) if (!(tag1 == (tag3 = GetTag(RIGHT_REEL, 2 - i)) || (tag1 == SLOT_MACHINE_TAG_7_RED && tag3 == SLOT_MACHINE_TAG_7_BLUE) || (tag1 == SLOT_MACHINE_TAG_7_BLUE && tag3 == SLOT_MACHINE_TAG_7_RED)))
break; break;
i++; i++;
} }
@ -2361,7 +2342,7 @@ static void DecideReelTurns_NoBiasTag_Reel3_Bet1(void)
//...see if you can match with reel 1 within 4 turns //...see if you can match with reel 1 within 4 turns
for (i = 0; i < 5; i++) for (i = 0; i < 5; i++)
{ {
if (tag1 == GetNearbyTag(2, 2 - i)) if (tag1 == GetTag(RIGHT_REEL, 2 - i))
{ {
sSlotMachine->reelExtraTurns[2] = i; sSlotMachine->reelExtraTurns[2] = i;
return; return;
@ -2372,7 +2353,7 @@ static void DecideReelTurns_NoBiasTag_Reel3_Bet1(void)
i = 0; i = 0;
while (1) while (1)
{ {
if (tag1 != GetNearbyTag(2, 2 - i)) if (tag1 != GetTag(RIGHT_REEL, 2 - i))
break; break;
i++; i++;
} }
@ -2389,15 +2370,15 @@ static void DecideReelTurns_NoBiasTag_Reel3_Bet2(void)
u8 tag3; u8 tag3;
if (sSlotMachine->winnerRows[1] != 0 && sSlotMachine->winnerRows[0] == sSlotMachine->winnerRows[1] && sSlotMachine->luckyFlags & LUCKY_BIAS_777) if (sSlotMachine->winnerRows[1] != 0 && sSlotMachine->winnerRows[0] == sSlotMachine->winnerRows[1] && sSlotMachine->luckyFlags & LUCKY_BIAS_777)
{ {
tag1 = GetNearbyTag(0, sSlotMachine->winnerRows[0] - sSlotMachine->reelExtraTurns[0]); tag1 = GetTag(LEFT_REEL, sSlotMachine->winnerRows[0] - sSlotMachine->reelExtraTurns[0]);
tag2 = GetNearbyTag(1, sSlotMachine->winnerRows[1] - sSlotMachine->reelExtraTurns[1]); tag2 = GetTag(MIDDLE_REEL, sSlotMachine->winnerRows[1] - sSlotMachine->reelExtraTurns[1]);
//...and if tags are mixed 7s... //...and if tags are mixed 7s...
if (AreTagsMixed77(tag1, tag2)) if (AreTagsMixed77(tag1, tag2))
{ {
//...try to match with reel 1 within 4 turns //...try to match with reel 1 within 4 turns
for (i = 0; i < 5; i++) for (i = 0; i < 5; i++)
{ {
tag3 = GetNearbyTag(2, sSlotMachine->winnerRows[1] - i); tag3 = GetTag(RIGHT_REEL, sSlotMachine->winnerRows[1] - i);
if (tag1 == tag3) if (tag1 == tag3)
{ {
extraTurns = i; extraTurns = i;
@ -2412,9 +2393,9 @@ static void DecideReelTurns_NoBiasTag_Reel3_Bet2(void)
s16 loopExit; s16 loopExit;
for (i = 1, loopExit = 0; i < 4; i++) for (i = 1, loopExit = 0; i < 4; i++)
{ {
tag1 = GetNearbyTag(0, i - sSlotMachine->reelExtraTurns[0]); // why does this update with i tag1 = GetTag(LEFT_REEL, i - sSlotMachine->reelExtraTurns[0]); // why does this update with i
tag2 = GetNearbyTag(1, i - sSlotMachine->reelExtraTurns[1]); tag2 = GetTag(MIDDLE_REEL, i - sSlotMachine->reelExtraTurns[1]);
tag3 = GetNearbyTag(2, i - extraTurns); tag3 = GetTag(RIGHT_REEL, i - extraTurns);
// if bit 7 of luckyFlags is unset... // if bit 7 of luckyFlags is unset...
//...and if all 3 tags match and they're not mixed 7s //...and if all 3 tags match and they're not mixed 7s
if (!TagsDontMatchOrHaveAny7s(tag1, tag2, tag3) && (!AreTagsMixed777(tag1, tag2, tag3) || !(sSlotMachine->luckyFlags & LUCKY_BIAS_777))) if (!TagsDontMatchOrHaveAny7s(tag1, tag2, tag3) && (!AreTagsMixed777(tag1, tag2, tag3) || !(sSlotMachine->luckyFlags & LUCKY_BIAS_777)))
@ -2441,8 +2422,8 @@ static void DecideReelTurns_NoBiasTag_Reel3_Bet3(void)
DecideReelTurns_NoBiasTag_Reel3_Bet2(); DecideReelTurns_NoBiasTag_Reel3_Bet2();
if (sSlotMachine->winnerRows[1] != 0 && sSlotMachine->winnerRows[0] != sSlotMachine->winnerRows[1] && sSlotMachine->luckyFlags & LUCKY_BIAS_777) if (sSlotMachine->winnerRows[1] != 0 && sSlotMachine->winnerRows[0] != sSlotMachine->winnerRows[1] && sSlotMachine->luckyFlags & LUCKY_BIAS_777)
{ {
tag1 = GetNearbyTag(0, sSlotMachine->winnerRows[0] - sSlotMachine->reelExtraTurns[0]); tag1 = GetTag(LEFT_REEL, sSlotMachine->winnerRows[0] - sSlotMachine->reelExtraTurns[0]);
tag2 = GetNearbyTag(1, sSlotMachine->winnerRows[1] - sSlotMachine->reelExtraTurns[1]); tag2 = GetTag(MIDDLE_REEL, sSlotMachine->winnerRows[1] - sSlotMachine->reelExtraTurns[1]);
//..and if tags are mixed 7s... //..and if tags are mixed 7s...
if (AreTagsMixed77(tag1, tag2)) if (AreTagsMixed77(tag1, tag2))
{ {
@ -2451,7 +2432,7 @@ static void DecideReelTurns_NoBiasTag_Reel3_Bet3(void)
j = 3; j = 3;
for (i = 0; i < 5; i++) for (i = 0; i < 5; i++)
{ {
tag3 = GetNearbyTag(2, j - (sSlotMachine->reelExtraTurns[2] + i)); tag3 = GetTag(RIGHT_REEL, j - (sSlotMachine->reelExtraTurns[2] + i));
if (tag1 == tag3) if (tag1 == tag3)
{ {
sSlotMachine->reelExtraTurns[2] += i; sSlotMachine->reelExtraTurns[2] += i;
@ -2462,18 +2443,18 @@ static void DecideReelTurns_NoBiasTag_Reel3_Bet3(void)
} }
while (1) while (1)
{ {
tag1 = GetNearbyTag(0, 1 - sSlotMachine->reelExtraTurns[0]); tag1 = GetTag(LEFT_REEL, 1 - sSlotMachine->reelExtraTurns[0]);
tag2 = GetNearbyTag(1, 2 - sSlotMachine->reelExtraTurns[1]); tag2 = GetTag(MIDDLE_REEL, 2 - sSlotMachine->reelExtraTurns[1]);
tag3 = GetNearbyTag(2, 3 - sSlotMachine->reelExtraTurns[2]); tag3 = GetTag(RIGHT_REEL, 3 - sSlotMachine->reelExtraTurns[2]);
if (TagsDontMatchOrHaveAny7s(tag1, tag2, tag3) || (AreTagsMixed777(tag1, tag2, tag3) && sSlotMachine->luckyFlags & LUCKY_BIAS_777)) if (TagsDontMatchOrHaveAny7s(tag1, tag2, tag3) || (AreTagsMixed777(tag1, tag2, tag3) && sSlotMachine->luckyFlags & LUCKY_BIAS_777))
break; break;
sSlotMachine->reelExtraTurns[2]++; sSlotMachine->reelExtraTurns[2]++;
} }
while (1) while (1)
{ {
tag1 = GetNearbyTag(0, 3 - sSlotMachine->reelExtraTurns[0]); tag1 = GetTag(LEFT_REEL, 3 - sSlotMachine->reelExtraTurns[0]);
tag2 = GetNearbyTag(1, 2 - sSlotMachine->reelExtraTurns[1]); tag2 = GetTag(MIDDLE_REEL, 2 - sSlotMachine->reelExtraTurns[1]);
tag3 = GetNearbyTag(2, 1 - sSlotMachine->reelExtraTurns[2]); tag3 = GetTag(RIGHT_REEL, 1 - sSlotMachine->reelExtraTurns[2]);
if (TagsDontMatchOrHaveAny7s(tag1, tag2, tag3) || (AreTagsMixed777(tag1, tag2, tag3) && sSlotMachine->luckyFlags & LUCKY_BIAS_777)) if (TagsDontMatchOrHaveAny7s(tag1, tag2, tag3) || (AreTagsMixed777(tag1, tag2, tag3) && sSlotMachine->luckyFlags & LUCKY_BIAS_777))
break; break;
sSlotMachine->reelExtraTurns[2]++; sSlotMachine->reelExtraTurns[2]++;
@ -3314,7 +3295,7 @@ static void sub_8104F18(struct Sprite *sprite)
sprite->data[2] = sSlotMachine->reelPixelOffsets[sprite->data[0]] + sprite->data[1]; sprite->data[2] = sSlotMachine->reelPixelOffsets[sprite->data[0]] + sprite->data[1];
sprite->data[2] %= 120; sprite->data[2] %= 120;
sprite->pos1.y = sSlotMachine->reelPixelOffsetsWhileStopping[sprite->data[0]] + 28 + sprite->data[2]; sprite->pos1.y = sSlotMachine->reelPixelOffsetsWhileStopping[sprite->data[0]] + 28 + sprite->data[2];
sprite->sheetTileStart = GetSpriteTileStartByTag(GetNearbyTag_Quantized(sprite->data[0], sprite->data[2] / 24)); sprite->sheetTileStart = GetSpriteTileStartByTag(GetTagAtRest(sprite->data[0], sprite->data[2] / 24));
SetSpriteSheetFrameTileNum(sprite); SetSpriteSheetFrameTileNum(sprite);
} }