Rename tag offset functions
Fix typo
This commit is contained in:
parent
25f0dac1b5
commit
26a197847a
4 changed files with 119 additions and 111 deletions
42
include/constants/slot_machine.h
Normal file
42
include/constants/slot_machine.h
Normal 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
|
|
@ -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
|
||||||
|
|
|
@ -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"
|
||||||
|
|
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue