VASTLY improved how I generate tiles and tiledata
This commit is contained in:
@@ -1,69 +1,69 @@
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#include "fade.h"
|
||||
|
||||
inline void conversationFadeToBlack() {
|
||||
TIME_FUTURE = TIME_CURRENT;
|
||||
TIME_FUTURE_TYPE = TIME_FUTURE_TYPE_FADE_TO_BLACK;
|
||||
}
|
||||
|
||||
inline void conversationFadeFromBlack() {
|
||||
TIME_FUTURE = TIME_CURRENT;
|
||||
TIME_FUTURE_TYPE = TIME_FUTURE_TYPE_FADE_FROM_BLACK;
|
||||
}
|
||||
|
||||
inline void conversationFadeToWhite() {
|
||||
TIME_FUTURE = TIME_CURRENT;
|
||||
TIME_FUTURE_TYPE = TIME_FUTURE_TYPE_FADE_TO_WHITE;
|
||||
}
|
||||
|
||||
inline void conversationFadeFromWhite() {
|
||||
TIME_FUTURE = TIME_CURRENT;
|
||||
TIME_FUTURE_TYPE = TIME_FUTURE_TYPE_FADE_FROM_WHITE;
|
||||
}
|
||||
|
||||
void conversationFadeUpdate() {
|
||||
uint16_t diff;
|
||||
|
||||
if(
|
||||
TIME_FUTURE_TYPE < TIME_FUTURE_TYPE_FADE_TO_BLACK ||
|
||||
TIME_FUTURE_TYPE > TIME_FUTURE_TYPE_FADE_FROM_WHITE
|
||||
) return;
|
||||
|
||||
diff = TIME_CURRENT - TIME_FUTURE;
|
||||
|
||||
// Now we work out the steps. Time is measured in steps which are made of
|
||||
// parts of a second. This code assumes that the screen STARTS at the correct
|
||||
// shade.
|
||||
if(diff == FADE_STEP) {
|
||||
// First step
|
||||
BGP_REG = (
|
||||
TIME_FUTURE_TYPE == TIME_FUTURE_TYPE_FADE_TO_BLACK ? COMMON_SHADE_DARK :
|
||||
TIME_FUTURE_TYPE == TIME_FUTURE_TYPE_FADE_TO_WHITE ? COMMON_SHADE_BRIGHT :
|
||||
TIME_FUTURE_TYPE == TIME_FUTURE_TYPE_FADE_FROM_BLACK ? COMMON_SHADE_DARKER :
|
||||
COMMON_SHADE_BRIGHTER
|
||||
);
|
||||
} else if(diff == FADE_STEP * 2) {
|
||||
// Second step
|
||||
BGP_REG = (
|
||||
TIME_FUTURE_TYPE == TIME_FUTURE_TYPE_FADE_TO_BLACK ? COMMON_SHADE_DARKER :
|
||||
TIME_FUTURE_TYPE == TIME_FUTURE_TYPE_FADE_TO_WHITE ? COMMON_SHADE_BRIGHTER :
|
||||
TIME_FUTURE_TYPE == TIME_FUTURE_TYPE_FADE_FROM_BLACK ? COMMON_SHADE_DARK :
|
||||
COMMON_SHADE_BRIGHT
|
||||
);
|
||||
} else if(diff == FADE_STEP * 3) {
|
||||
// Third step
|
||||
BGP_REG = (
|
||||
TIME_FUTURE_TYPE == TIME_FUTURE_TYPE_FADE_TO_BLACK ? COMMON_SHADE_BLACK :
|
||||
TIME_FUTURE_TYPE == TIME_FUTURE_TYPE_FADE_TO_WHITE ? COMMON_SHADE_WHITE :
|
||||
COMMON_SHADE_NORMAL
|
||||
);
|
||||
TIME_FUTURE_TYPE = TIME_FUTURE_TYPE_NULL;
|
||||
conversationQueueNext();
|
||||
}
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#include "fade.h"
|
||||
|
||||
inline void conversationFadeToBlack() {
|
||||
TIME_FUTURE = TIME_CURRENT;
|
||||
TIME_FUTURE_TYPE = TIME_FUTURE_TYPE_FADE_TO_BLACK;
|
||||
}
|
||||
|
||||
inline void conversationFadeFromBlack() {
|
||||
TIME_FUTURE = TIME_CURRENT;
|
||||
TIME_FUTURE_TYPE = TIME_FUTURE_TYPE_FADE_FROM_BLACK;
|
||||
}
|
||||
|
||||
inline void conversationFadeToWhite() {
|
||||
TIME_FUTURE = TIME_CURRENT;
|
||||
TIME_FUTURE_TYPE = TIME_FUTURE_TYPE_FADE_TO_WHITE;
|
||||
}
|
||||
|
||||
inline void conversationFadeFromWhite() {
|
||||
TIME_FUTURE = TIME_CURRENT;
|
||||
TIME_FUTURE_TYPE = TIME_FUTURE_TYPE_FADE_FROM_WHITE;
|
||||
}
|
||||
|
||||
void conversationFadeUpdate() {
|
||||
uint16_t diff;
|
||||
|
||||
if(
|
||||
TIME_FUTURE_TYPE < TIME_FUTURE_TYPE_FADE_TO_BLACK ||
|
||||
TIME_FUTURE_TYPE > TIME_FUTURE_TYPE_FADE_FROM_WHITE
|
||||
) return;
|
||||
|
||||
diff = TIME_CURRENT - TIME_FUTURE;
|
||||
|
||||
// Now we work out the steps. Time is measured in steps which are made of
|
||||
// parts of a second. This code assumes that the screen STARTS at the correct
|
||||
// shade.
|
||||
if(diff == FADE_STEP) {
|
||||
// First step
|
||||
BGP_REG = (
|
||||
TIME_FUTURE_TYPE == TIME_FUTURE_TYPE_FADE_TO_BLACK ? TILESET_SHADE_DARK :
|
||||
TIME_FUTURE_TYPE == TIME_FUTURE_TYPE_FADE_TO_WHITE ? TILESET_SHADE_BRIGHT :
|
||||
TIME_FUTURE_TYPE == TIME_FUTURE_TYPE_FADE_FROM_BLACK ? TILESET_SHADE_DARKER :
|
||||
TILESET_SHADE_BRIGHTER
|
||||
);
|
||||
} else if(diff == FADE_STEP * 2) {
|
||||
// Second step
|
||||
BGP_REG = (
|
||||
TIME_FUTURE_TYPE == TIME_FUTURE_TYPE_FADE_TO_BLACK ? TILESET_SHADE_DARKER :
|
||||
TIME_FUTURE_TYPE == TIME_FUTURE_TYPE_FADE_TO_WHITE ? TILESET_SHADE_BRIGHTER :
|
||||
TIME_FUTURE_TYPE == TIME_FUTURE_TYPE_FADE_FROM_BLACK ? TILESET_SHADE_DARK :
|
||||
TILESET_SHADE_BRIGHT
|
||||
);
|
||||
} else if(diff == FADE_STEP * 3) {
|
||||
// Third step
|
||||
BGP_REG = (
|
||||
TIME_FUTURE_TYPE == TIME_FUTURE_TYPE_FADE_TO_BLACK ? TILESET_SHADE_BLACK :
|
||||
TIME_FUTURE_TYPE == TIME_FUTURE_TYPE_FADE_TO_WHITE ? TILESET_SHADE_WHITE :
|
||||
TILESET_SHADE_NORMAL
|
||||
);
|
||||
TIME_FUTURE_TYPE = TIME_FUTURE_TYPE_NULL;
|
||||
conversationQueueNext();
|
||||
}
|
||||
}
|
@@ -1,21 +1,21 @@
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
#include "../libs.h"
|
||||
#include "queue.h"
|
||||
#include "pause.h"
|
||||
#include "../display/common.h"
|
||||
|
||||
// This is how many frames it takes to change each shade.
|
||||
#define FADE_STEP 20
|
||||
|
||||
inline void conversationFadeToBlack();
|
||||
inline void conversationFadeFromBlack();
|
||||
inline void conversationFadeToWhite();
|
||||
inline void conversationFadeFromWhite();
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
#include "../libs.h"
|
||||
#include "queue.h"
|
||||
#include "pause.h"
|
||||
#include "../sprites/spritetileset.h"
|
||||
|
||||
// This is how many frames it takes to change each shade.
|
||||
#define FADE_STEP 20
|
||||
|
||||
inline void conversationFadeToBlack();
|
||||
inline void conversationFadeFromBlack();
|
||||
inline void conversationFadeToWhite();
|
||||
inline void conversationFadeFromWhite();
|
||||
void conversationFadeUpdate();
|
@@ -1,40 +0,0 @@
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#include "frame.h"
|
||||
|
||||
inline void frameBuffer(
|
||||
uint8_t buffer[],
|
||||
uint8_t bufferWidth, uint8_t bufferHeight,
|
||||
uint8_t fill
|
||||
) {
|
||||
uint8_t i, j, max;
|
||||
max = bufferWidth * bufferHeight;
|
||||
|
||||
// Corners
|
||||
buffer[0] = BORDER_TILE_TOP_LEFT;
|
||||
buffer[bufferWidth-1] = BORDER_TILE_TOP_RIGHT;
|
||||
buffer[max-1] = BORDER_TILE_BOTTOM_RIGHT;
|
||||
buffer[max-bufferWidth] = BORDER_TILE_BOTTOM_LEFT;
|
||||
|
||||
// Edges
|
||||
for(i = 1; i < bufferWidth-1; i++) {
|
||||
buffer[i] = BORDER_TILE_TOP_CENTER;
|
||||
buffer[max - 1 - i] = BORDER_TILE_BOTTOM_CENTER;
|
||||
}
|
||||
for(i = 1; i < bufferHeight - 1; i++) {
|
||||
buffer[bufferWidth * i] = BORDER_TILE_CENTER_LEFT;
|
||||
buffer[bufferWidth * (i+1) - 1] = BORDER_TILE_CENTER_RIGHT;
|
||||
}
|
||||
|
||||
// Inner
|
||||
for(j = 1; j < bufferHeight-1; j++) {
|
||||
for(i = 1; i < bufferWidth-1; i++) {
|
||||
buffer[i + (j * bufferWidth)] = fill;
|
||||
}
|
||||
}
|
||||
}
|
@@ -1,28 +0,0 @@
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
#include "../libs.h"
|
||||
#include "../util.h"
|
||||
#include "../display/common.h"
|
||||
#include "../display/tilemap.h"
|
||||
|
||||
#define BORDER_TILE_TOP_LEFT BORDER_DATA_POSITION
|
||||
#define BORDER_TILE_TOP_CENTER BORDER_TILE_TOP_LEFT + 1
|
||||
#define BORDER_TILE_TOP_RIGHT BORDER_TILE_TOP_CENTER + 1
|
||||
#define BORDER_TILE_CENTER_LEFT BORDER_TILE_TOP_RIGHT + 1
|
||||
#define BORDER_TILE_CENTER BORDER_TILE_CENTER_LEFT + 1
|
||||
#define BORDER_TILE_CENTER_RIGHT BORDER_TILE_CENTER + 1
|
||||
#define BORDER_TILE_BOTTOM_LEFT BORDER_TILE_CENTER_RIGHT + 1
|
||||
#define BORDER_TILE_BOTTOM_CENTER BORDER_TILE_BOTTOM_LEFT + 1
|
||||
#define BORDER_TILE_BOTTOM_RIGHT BORDER_TILE_BOTTOM_CENTER + 1
|
||||
|
||||
inline void frameBuffer(
|
||||
uint8_t buffer[],
|
||||
uint8_t bufferWidth, uint8_t bufferHeight,
|
||||
uint8_t fill
|
||||
);
|
@@ -1,22 +1,22 @@
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#include "pause.h"
|
||||
|
||||
inline void conversationPause(uint16_t duration) {
|
||||
TIME_FUTURE = TIME_CURRENT + (duration * TIME_PER_SECOND);
|
||||
TIME_FUTURE_TYPE = TIME_FUTURE_TYPE_PAUSE;
|
||||
}
|
||||
|
||||
inline void conversationPauseUpdate() {
|
||||
if(TIME_FUTURE_TYPE != TIME_FUTURE_TYPE_PAUSE || TIME_CURRENT != TIME_FUTURE) {
|
||||
return;
|
||||
}
|
||||
|
||||
TIME_FUTURE_TYPE = TIME_FUTURE_TYPE_NULL;
|
||||
conversationQueueNext();
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#include "pause.h"
|
||||
|
||||
inline void conversationPause(uint16_t duration) {
|
||||
TIME_FUTURE = TIME_CURRENT + (duration * TIME_PER_SECOND);
|
||||
TIME_FUTURE_TYPE = TIME_FUTURE_TYPE_PAUSE;
|
||||
}
|
||||
|
||||
inline void conversationPauseUpdate() {
|
||||
if(TIME_FUTURE_TYPE != TIME_FUTURE_TYPE_PAUSE || TIME_CURRENT != TIME_FUTURE) {
|
||||
return;
|
||||
}
|
||||
|
||||
TIME_FUTURE_TYPE = TIME_FUTURE_TYPE_NULL;
|
||||
conversationQueueNext();
|
||||
}
|
@@ -1,14 +1,14 @@
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
#include "../libs.h"
|
||||
#include "../time.h"
|
||||
#include "queue.h"
|
||||
|
||||
inline void conversationPause(uint16_t duration);
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
#include "../libs.h"
|
||||
#include "../time.h"
|
||||
#include "queue.h"
|
||||
|
||||
inline void conversationPause(uint16_t duration);
|
||||
inline void conversationPauseUpdate();
|
@@ -1,87 +1,87 @@
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#include "questionbox.h"
|
||||
|
||||
uint8_t QUESTION_BOX_OPTION_COUNT;
|
||||
uint8_t QUESTION_BOX_OPTION_CURRENT;
|
||||
|
||||
void questionBoxSetOptions(char *title, char **options, uint8_t count) {
|
||||
uint8_t i, j;
|
||||
char buffer[TEXTBOX_CHARS_MAX + 1];
|
||||
char spaces[QUESTION_BOX_QUESTION_SPACES];
|
||||
sprintf(buffer, title);
|
||||
|
||||
i = 0;
|
||||
QUESTION_BOX_OPTION_CURRENT = 0;
|
||||
QUESTION_BOX_OPTION_COUNT = count;
|
||||
|
||||
for(i = 0; i < QUESTION_BOX_QUESTION_SPACES; i++) {
|
||||
spaces[i] = ' ';
|
||||
}
|
||||
|
||||
// For each row...
|
||||
for(i = 0; i < count; i++) {
|
||||
if((i & 1) == 0) {
|
||||
j = strlen(options[i]);
|
||||
sprintf(buffer, "%s\n %s", buffer, options[i]);
|
||||
} else {
|
||||
j = QUESTION_BOX_QUESTION_SPACES - j;
|
||||
spaces[j + 1] = '\0';
|
||||
sprintf(buffer, "%s%s%s", buffer, spaces, options[i]);
|
||||
spaces[j + 1] = ' ';
|
||||
}
|
||||
}
|
||||
|
||||
conversationTextboxSetText(buffer);
|
||||
|
||||
// Modify the textbox state
|
||||
TEXTBOX_STATE |= TEXTBOX_STATE_IS_QUESTION;
|
||||
|
||||
// Repurpose old array and draw arrow
|
||||
spaces[0] = QUESTION_BOX_CURSOR - TEXTBOX_FONT_START + FONT_DATA_POSITION;
|
||||
set_bkg_tiles(0x01, TEXTBOX_WIN_Y + 0x02, 1, 1, spaces);
|
||||
}
|
||||
|
||||
inline void questionBoxUpdate() {
|
||||
uint8_t tiles[1];
|
||||
uint8_t i;
|
||||
|
||||
if((TEXTBOX_STATE & (TEXTBOX_STATE_VISIBLE|TEXTBOX_STATE_IS_QUESTION)) == 0) return;
|
||||
|
||||
// Detect input
|
||||
if(INPUT_PRESSED & J_RIGHT) {
|
||||
QUESTION_BOX_OPTION_CURRENT++;
|
||||
} else if(INPUT_PRESSED & J_LEFT) {
|
||||
QUESTION_BOX_OPTION_CURRENT--;
|
||||
} else if(INPUT_PRESSED & J_UP) {
|
||||
QUESTION_BOX_OPTION_CURRENT -= 2;
|
||||
} else if(INPUT_PRESSED & J_DOWN) {
|
||||
QUESTION_BOX_OPTION_CURRENT += 2;
|
||||
} else {
|
||||
return;
|
||||
}
|
||||
|
||||
// Bound.
|
||||
QUESTION_BOX_OPTION_CURRENT = QUESTION_BOX_OPTION_CURRENT % QUESTION_BOX_OPTION_COUNT;
|
||||
|
||||
// Decide where to render arrow
|
||||
for(i = 0; i < QUESTION_BOX_OPTION_COUNT; i++) {
|
||||
if(i == QUESTION_BOX_OPTION_CURRENT) {
|
||||
tiles[0] = QUESTION_BOX_CURSOR - TEXTBOX_FONT_START + FONT_DATA_POSITION;
|
||||
} else {
|
||||
tiles[0] = ' ' - TEXTBOX_FONT_START + FONT_DATA_POSITION;
|
||||
}
|
||||
set_bkg_tiles(
|
||||
0x01 + ((i % 0x02) * QUESTION_BOX_QUESTION_SPACES),
|
||||
TEXTBOX_WIN_Y + 0x02 + (i / 0x02),
|
||||
1, 1,
|
||||
tiles
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#include "questionbox.h"
|
||||
|
||||
uint8_t QUESTION_BOX_OPTION_COUNT;
|
||||
uint8_t QUESTION_BOX_OPTION_CURRENT;
|
||||
|
||||
void questionBoxSetOptions(char *title, char **options, uint8_t count) {
|
||||
uint8_t i, j;
|
||||
char buffer[TEXTBOX_CHARS_MAX + 1];
|
||||
char spaces[QUESTION_BOX_QUESTION_SPACES];
|
||||
sprintf(buffer, title);
|
||||
|
||||
i = 0;
|
||||
QUESTION_BOX_OPTION_CURRENT = 0;
|
||||
QUESTION_BOX_OPTION_COUNT = count;
|
||||
|
||||
for(i = 0; i < QUESTION_BOX_QUESTION_SPACES; i++) {
|
||||
spaces[i] = ' ';
|
||||
}
|
||||
|
||||
// For each row...
|
||||
for(i = 0; i < count; i++) {
|
||||
if((i & 1) == 0) {
|
||||
j = strlen(options[i]);
|
||||
sprintf(buffer, "%s\n %s", buffer, options[i]);
|
||||
} else {
|
||||
j = QUESTION_BOX_QUESTION_SPACES - j;
|
||||
spaces[j + 1] = '\0';
|
||||
sprintf(buffer, "%s%s%s", buffer, spaces, options[i]);
|
||||
spaces[j + 1] = ' ';
|
||||
}
|
||||
}
|
||||
|
||||
conversationTextboxSetText(buffer);
|
||||
|
||||
// Modify the textbox state
|
||||
TEXTBOX_STATE |= TEXTBOX_STATE_IS_QUESTION;
|
||||
|
||||
// Repurpose old array and draw arrow
|
||||
spaces[0] = spriteFontTileFromChar(QUESTION_BOX_CURSOR);
|
||||
set_bkg_tiles(0x01, TEXTBOX_WIN_Y + 0x02, 1, 1, spaces);
|
||||
}
|
||||
|
||||
inline void questionBoxUpdate() {
|
||||
uint8_t tiles[1];
|
||||
uint8_t i;
|
||||
|
||||
if((TEXTBOX_STATE & (TEXTBOX_STATE_VISIBLE|TEXTBOX_STATE_IS_QUESTION)) == 0) return;
|
||||
|
||||
// Detect input
|
||||
if(INPUT_PRESSED & J_RIGHT) {
|
||||
QUESTION_BOX_OPTION_CURRENT++;
|
||||
} else if(INPUT_PRESSED & J_LEFT) {
|
||||
QUESTION_BOX_OPTION_CURRENT--;
|
||||
} else if(INPUT_PRESSED & J_UP) {
|
||||
QUESTION_BOX_OPTION_CURRENT -= 2;
|
||||
} else if(INPUT_PRESSED & J_DOWN) {
|
||||
QUESTION_BOX_OPTION_CURRENT += 2;
|
||||
} else {
|
||||
return;
|
||||
}
|
||||
|
||||
// Bound.
|
||||
QUESTION_BOX_OPTION_CURRENT = QUESTION_BOX_OPTION_CURRENT % QUESTION_BOX_OPTION_COUNT;
|
||||
|
||||
// Decide where to render arrow
|
||||
for(i = 0; i < QUESTION_BOX_OPTION_COUNT; i++) {
|
||||
if(i == QUESTION_BOX_OPTION_CURRENT) {
|
||||
tiles[0] = spriteFontTileFromChar(QUESTION_BOX_CURSOR);
|
||||
} else {
|
||||
tiles[0] = spriteFontTileFromChar(' ');
|
||||
}
|
||||
set_bkg_tiles(
|
||||
0x01 + ((i % 0x02) * QUESTION_BOX_QUESTION_SPACES),
|
||||
TEXTBOX_WIN_Y + 0x02 + (i / 0x02),
|
||||
1, 1,
|
||||
tiles
|
||||
);
|
||||
}
|
||||
|
||||
}
|
@@ -1,26 +1,26 @@
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
#include "../libs.h"
|
||||
#include "../util.h"
|
||||
#include "../input.h"
|
||||
#include "../display/common.h"
|
||||
#include "../display/tilemap.h"
|
||||
#include "frame.h"
|
||||
#include "textbox.h"
|
||||
|
||||
#define QUESTION_BOX_OPTIONS_MAX ((TEXTBOX_CHAR_ROWS-1)*2)
|
||||
#define QUESTION_BOX_CURSOR '>'
|
||||
#define QUESTION_BOX_QUESTION_SPACES 9
|
||||
|
||||
extern uint8_t QUESTION_BOX_OPTION_COUNT;
|
||||
extern uint8_t QUESTION_BOX_OPTION_CURRENT;
|
||||
|
||||
void questionBoxSetOptions(char *title, char **options, uint8_t count);
|
||||
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
#include "../libs.h"
|
||||
#include "../util.h"
|
||||
#include "../input.h"
|
||||
#include "../sprites/spritefont.h"
|
||||
#include "../sprites/spriteborder.h"
|
||||
#include "../sprites/spritetileset.h"
|
||||
#include "textbox.h"
|
||||
|
||||
#define QUESTION_BOX_OPTIONS_MAX ((TEXTBOX_CHAR_ROWS-1)*2)
|
||||
#define QUESTION_BOX_CURSOR '>'
|
||||
#define QUESTION_BOX_QUESTION_SPACES 9
|
||||
|
||||
extern uint8_t QUESTION_BOX_OPTION_COUNT;
|
||||
extern uint8_t QUESTION_BOX_OPTION_CURRENT;
|
||||
|
||||
void questionBoxSetOptions(char *title, char **options, uint8_t count);
|
||||
|
||||
inline void questionBoxUpdate();
|
@@ -1,315 +1,315 @@
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#include "queue.h"
|
||||
#include "pause.h"
|
||||
#include "textbox.h"
|
||||
#include "fade.h"
|
||||
#include "../poker/poker.h"
|
||||
|
||||
uint16_t QUEUE_ITEM;
|
||||
|
||||
void conversationQueueDebug() {
|
||||
conversationTextboxSetText(STR_ERROR);
|
||||
}
|
||||
|
||||
void conversationQueueBegin() {
|
||||
QUEUE_ITEM = QUEUE_TAKE_BLINDS;
|
||||
conversationTextboxSetText(STR_POKER_GAME_START);
|
||||
}
|
||||
|
||||
void conversationQueueTakeBlinds() {
|
||||
QUEUE_ITEM = QUEUE_DEAL_CARDS;
|
||||
conversationTextboxSetText(STR_POKER_GAME_TAKING_BLINDS);
|
||||
}
|
||||
|
||||
void conversationQueueDealCards() {
|
||||
QUEUE_ITEM = QUEUE_BEGIN_BETTING;
|
||||
conversationTextboxSetText(STR_POKER_GAME_CARDS_DEALT);
|
||||
}
|
||||
|
||||
void conversationQueueBeginBetting() {
|
||||
pokerturn_t turn;
|
||||
turn.chips = 0;
|
||||
// Begin the betting process. First we need to decide if the player or the
|
||||
// AI is betting, then based on that we decide what to do next.
|
||||
|
||||
// TODO: Actually bet.
|
||||
if(POKER_PLAYER_BETTER == POKER_HUMAN_INDEX) {
|
||||
// This is the human player.
|
||||
BGB_MESSAGE("Player folding.");
|
||||
conversationTextboxSetText(STR_DEBUG_PLAYER);
|
||||
POKER_PLAYERS[POKER_PLAYER_BETTER].state |= POKER_PLAYER_STATE_FOLDED;
|
||||
} else {
|
||||
// This is an AI player, get their turn.
|
||||
BGB_MESSAGE("AI turn to bet");
|
||||
pokerAi(POKER_PLAYER_BETTER, &turn);
|
||||
BGB_printf("AI Decided to %u, with %u chips and %u confidence, bluffin: %u", turn.type, turn.chips, turn.confidence, turn.bluff);
|
||||
|
||||
switch(turn.type) {
|
||||
case POKER_TURN_TYPE_FOLD:
|
||||
POKER_PLAYERS[POKER_PLAYER_BETTER].state |= POKER_PLAYER_STATE_FOLDED;
|
||||
conversationTextboxSetText(STR_POKER_GAME_AI_FOLD);
|
||||
break;
|
||||
|
||||
case POKER_TURN_TYPE_BET:
|
||||
if(turn.bluff) {
|
||||
conversationTextboxSetText(STR_POKER_GAME_AI_RAISE_BLUFF);
|
||||
} else {
|
||||
conversationTextboxSetText(STR_POKER_GAME_AI_RAISE);
|
||||
}
|
||||
break;
|
||||
|
||||
case POKER_TURN_TYPE_CALL:
|
||||
if(turn.bluff) {
|
||||
conversationTextboxSetText(STR_POKER_GAME_AI_CALL_BLUFF);
|
||||
} else {
|
||||
conversationTextboxSetText(STR_POKER_GAME_AI_CALL);
|
||||
}
|
||||
break;
|
||||
|
||||
case POKER_TURN_TYPE_ALL_IN:
|
||||
if(turn.bluff) {
|
||||
conversationTextboxSetText(STR_POKER_GAME_AI_ALL_IN_BLUFF);
|
||||
} else {
|
||||
conversationTextboxSetText(STR_POKER_GAME_AI_ALL_IN);
|
||||
}
|
||||
break;
|
||||
|
||||
case POKER_TURN_TYPE_CHECK:
|
||||
if(turn.bluff) {
|
||||
conversationTextboxSetText(STR_POKER_GAME_AI_CHECK_BLUFF);
|
||||
} else {
|
||||
conversationTextboxSetText(STR_POKER_GAME_AI_CHECK);
|
||||
}
|
||||
break;
|
||||
}
|
||||
|
||||
// Now we have their turn, decide what to say based on that.
|
||||
}
|
||||
|
||||
// Update bet state
|
||||
POKER_PLAYERS[POKER_PLAYER_BETTER].state |= (
|
||||
POKER_PLAYER_STATE_HAS_BET_THIS_ROUND
|
||||
);
|
||||
|
||||
if(turn.chips > 0) {
|
||||
pokerBet(POKER_PLAYER_BETTER, turn.chips);
|
||||
}
|
||||
|
||||
QUEUE_ITEM = QUEUE_NEXT_BETTER;
|
||||
}
|
||||
|
||||
void conversationQueueNextBetter() {
|
||||
uint8_t i, j, countStillInGame;
|
||||
|
||||
// Now we decide the next better.
|
||||
countStillInGame = 0;
|
||||
for(i = 0; i < POKER_PLAYER_COUNT; i++) {
|
||||
//In theory I don't think the current better can ever be selected again.
|
||||
// if(i == POKER_PLAYER_BETTER) continue; // Commented because we now count
|
||||
|
||||
// Next better is the better to the right of the current better.
|
||||
j = (POKER_PLAYER_BETTER + i) % POKER_PLAYER_COUNT;
|
||||
if(!pokerDoesPlayerNeedToBet(j)) {
|
||||
if((POKER_PLAYERS[j].state & (POKER_PLAYER_STATE_FOLDED | POKER_PLAYER_STATE_OUT)) == 0) {
|
||||
countStillInGame++;
|
||||
}
|
||||
continue;
|
||||
}
|
||||
|
||||
// They haven't bet yet, make them the "next better"
|
||||
POKER_PLAYER_BETTER = j;
|
||||
|
||||
QUEUE_ITEM = QUEUE_BEGIN_BETTING;
|
||||
conversationQueueNext();
|
||||
return;
|
||||
}
|
||||
|
||||
// If we reach this point then we either need to begin the betting round, or
|
||||
// we are going to move to the winning decider.
|
||||
if(POKER_COMMUNITY_SIZE_MAX == POKER_COMMUNITY_SIZE || countStillInGame == 1) {
|
||||
QUEUE_ITEM = QUEUE_WINNER_DECIDE;
|
||||
conversationQueueNext();
|
||||
return;
|
||||
}
|
||||
|
||||
QUEUE_ITEM = QUEUE_FLOP;
|
||||
conversationQueueNext();
|
||||
}
|
||||
|
||||
void conversationQueueFlopTurnRiver() {
|
||||
uint8_t i, count;
|
||||
pokerplayer_t *player;
|
||||
|
||||
|
||||
switch(POKER_COMMUNITY_SIZE) {
|
||||
case 0:
|
||||
count = POKER_COUNT_FLOP;
|
||||
conversationTextboxSetText(STR_POKER_GAME_CARDS_FLOPPED);
|
||||
break;
|
||||
|
||||
case POKER_COUNT_FLOP:
|
||||
count = POKER_COUNT_TURN;
|
||||
conversationTextboxSetText(STR_POKER_GAME_CARDS_TURNED);
|
||||
break;
|
||||
|
||||
default:
|
||||
count = POKER_COUNT_RIVER;
|
||||
conversationTextboxSetText(STR_POKER_GAME_CARDS_RIVERED);
|
||||
break;
|
||||
}
|
||||
|
||||
// Reset each players required to bet state
|
||||
do {
|
||||
player = POKER_PLAYERS + i;
|
||||
player->state &= ~POKER_PLAYER_STATE_HAS_BET_THIS_ROUND;
|
||||
player->timesRaised = 0;
|
||||
} while(++i < POKER_PLAYER_COUNT);
|
||||
|
||||
// In reality we'd burn the top card but that would waste some CPU I need.
|
||||
// Deal the top cards.
|
||||
for(i = 0; i < count; i++) {
|
||||
POKER_COMMUNITY[POKER_COMMUNITY_SIZE++] = POKER_DECK[--POKER_DECK_SIZE];
|
||||
}
|
||||
|
||||
// Check how many players need to bet, if it's zero then all players are
|
||||
// either folded or all-in
|
||||
if(pokerGetRemainingBetterCount() == 0x00) {
|
||||
if(POKER_COMMUNITY_SIZE == POKER_COMMUNITY_SIZE_MAX) {
|
||||
QUEUE_ITEM = QUEUE_WINNER_DECIDE;
|
||||
} else {
|
||||
QUEUE_ITEM = QUEUE_FLOP;
|
||||
}
|
||||
} else {
|
||||
QUEUE_ITEM = QUEUE_BEGIN_BETTING;
|
||||
}
|
||||
}
|
||||
|
||||
void conversationQueueWinnerDecide() {
|
||||
pokerpot_t *pot;
|
||||
uint8_t i, j, countOfPotsWithChips, chipsEach;
|
||||
|
||||
QUEUE_ITEM = QUEUE_BEGIN;
|
||||
|
||||
countOfPotsWithChips = 0;
|
||||
for(i = 0; i < POKER_POT_COUNT; i++) {
|
||||
pot = POKER_POTS + i;
|
||||
if(pot->chips == 0) break;
|
||||
countOfPotsWithChips++;
|
||||
}
|
||||
|
||||
// TODO: Messages
|
||||
if(countOfPotsWithChips == 1) {
|
||||
} else {
|
||||
}
|
||||
|
||||
// Pots.
|
||||
for(i = 0; i < countOfPotsWithChips; i++) {
|
||||
pot = POKER_POTS + i;
|
||||
pokerWinnerDetermineForPot(
|
||||
pot,
|
||||
POKER_WINNERS,
|
||||
POKER_WINNER_PLAYERS,
|
||||
&POKER_WINNER_COUNT,
|
||||
POKER_WINNER_PARTICIPANTS,
|
||||
&POKER_WINNER_PARTICIPANT_COUNT
|
||||
);
|
||||
|
||||
chipsEach = pot->chips / POKER_WINNER_COUNT;
|
||||
for(j = 0; j < POKER_WINNER_COUNT; j++) {
|
||||
POKER_PLAYERS[POKER_WINNER_PLAYERS[j]].chips += chipsEach;
|
||||
// TODO: I can determine rounding error here if I need to, just sub the
|
||||
// taken chips for each player and when I get to chips remaining less than
|
||||
// the chipsEach, then reward the rounding offset.
|
||||
}
|
||||
}
|
||||
|
||||
// TODO: Decide on a winner for real.
|
||||
conversationTextboxSetText(STR_DEBUG_WINNER_DECIDED);
|
||||
|
||||
// New Round
|
||||
pokerNewRound();
|
||||
}
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
queuecallback_t *QUEUE_CALLBACKS[] = {
|
||||
// 0
|
||||
NULL,
|
||||
&conversationQueueDebug,
|
||||
NULL,
|
||||
NULL,
|
||||
NULL,
|
||||
|
||||
// 5
|
||||
&conversationQueueBegin,
|
||||
NULL,
|
||||
NULL,
|
||||
NULL,
|
||||
NULL,
|
||||
|
||||
// 10
|
||||
&conversationQueueTakeBlinds,
|
||||
NULL,
|
||||
NULL,
|
||||
NULL,
|
||||
NULL,
|
||||
|
||||
// 15
|
||||
&conversationQueueDealCards,
|
||||
NULL,
|
||||
NULL,
|
||||
NULL,
|
||||
NULL,
|
||||
|
||||
// 20
|
||||
&conversationQueueBeginBetting,
|
||||
NULL,
|
||||
NULL,
|
||||
NULL,
|
||||
NULL,
|
||||
|
||||
// 25
|
||||
&conversationQueueNextBetter,
|
||||
NULL,
|
||||
NULL,
|
||||
NULL,
|
||||
NULL,
|
||||
|
||||
// 30
|
||||
&conversationQueueFlopTurnRiver,
|
||||
NULL,
|
||||
NULL,
|
||||
NULL,
|
||||
NULL,
|
||||
|
||||
// 35
|
||||
NULL,
|
||||
NULL,
|
||||
NULL,
|
||||
NULL,
|
||||
NULL,
|
||||
|
||||
// 40
|
||||
&conversationQueueWinnerDecide,
|
||||
// NULL,
|
||||
// NULL,
|
||||
// NULL,
|
||||
// NULL,
|
||||
};
|
||||
|
||||
inline void conversationQueueInit() {
|
||||
QUEUE_ITEM = QUEUE_BEGIN;
|
||||
}
|
||||
|
||||
inline void conversationQueueNext() {
|
||||
BGB_printf("Doing %d", QUEUE_ITEM);
|
||||
if(QUEUE_ITEM > QUEUE_WINNER_DECIDE) return;
|
||||
if(QUEUE_CALLBACKS[QUEUE_ITEM] == NULL) return;
|
||||
QUEUE_CALLBACKS[QUEUE_ITEM]();
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#include "queue.h"
|
||||
#include "pause.h"
|
||||
#include "textbox.h"
|
||||
#include "fade.h"
|
||||
#include "../poker/poker.h"
|
||||
|
||||
uint16_t QUEUE_ITEM;
|
||||
|
||||
void conversationQueueDebug() {
|
||||
conversationTextboxSetText(STR_ERROR);
|
||||
}
|
||||
|
||||
void conversationQueueBegin() {
|
||||
QUEUE_ITEM = QUEUE_TAKE_BLINDS;
|
||||
conversationTextboxSetText(STR_POKER_GAME_START);
|
||||
}
|
||||
|
||||
void conversationQueueTakeBlinds() {
|
||||
QUEUE_ITEM = QUEUE_DEAL_CARDS;
|
||||
conversationTextboxSetText(STR_POKER_GAME_TAKING_BLINDS);
|
||||
}
|
||||
|
||||
void conversationQueueDealCards() {
|
||||
QUEUE_ITEM = QUEUE_BEGIN_BETTING;
|
||||
conversationTextboxSetText(STR_POKER_GAME_CARDS_DEALT);
|
||||
}
|
||||
|
||||
void conversationQueueBeginBetting() {
|
||||
pokerturn_t turn;
|
||||
turn.chips = 0;
|
||||
// Begin the betting process. First we need to decide if the player or the
|
||||
// AI is betting, then based on that we decide what to do next.
|
||||
|
||||
// TODO: Actually bet.
|
||||
if(POKER_PLAYER_BETTER == POKER_HUMAN_INDEX) {
|
||||
// This is the human player.
|
||||
BGB_MESSAGE("Player folding.");
|
||||
conversationTextboxSetText(STR_DEBUG_PLAYER);
|
||||
POKER_PLAYERS[POKER_PLAYER_BETTER].state |= POKER_PLAYER_STATE_FOLDED;
|
||||
} else {
|
||||
// This is an AI player, get their turn.
|
||||
BGB_MESSAGE("AI turn to bet");
|
||||
pokerAi(POKER_PLAYER_BETTER, &turn);
|
||||
BGB_printf("AI Decided to %u, with %u chips and %u confidence, bluffin: %u", turn.type, turn.chips, turn.confidence, turn.bluff);
|
||||
|
||||
switch(turn.type) {
|
||||
case POKER_TURN_TYPE_FOLD:
|
||||
POKER_PLAYERS[POKER_PLAYER_BETTER].state |= POKER_PLAYER_STATE_FOLDED;
|
||||
conversationTextboxSetText(STR_POKER_GAME_AI_FOLD);
|
||||
break;
|
||||
|
||||
case POKER_TURN_TYPE_BET:
|
||||
if(turn.bluff) {
|
||||
conversationTextboxSetText(STR_POKER_GAME_AI_RAISE_BLUFF);
|
||||
} else {
|
||||
conversationTextboxSetText(STR_POKER_GAME_AI_RAISE);
|
||||
}
|
||||
break;
|
||||
|
||||
case POKER_TURN_TYPE_CALL:
|
||||
if(turn.bluff) {
|
||||
conversationTextboxSetText(STR_POKER_GAME_AI_CALL_BLUFF);
|
||||
} else {
|
||||
conversationTextboxSetText(STR_POKER_GAME_AI_CALL);
|
||||
}
|
||||
break;
|
||||
|
||||
case POKER_TURN_TYPE_ALL_IN:
|
||||
if(turn.bluff) {
|
||||
conversationTextboxSetText(STR_POKER_GAME_AI_ALL_IN_BLUFF);
|
||||
} else {
|
||||
conversationTextboxSetText(STR_POKER_GAME_AI_ALL_IN);
|
||||
}
|
||||
break;
|
||||
|
||||
case POKER_TURN_TYPE_CHECK:
|
||||
if(turn.bluff) {
|
||||
conversationTextboxSetText(STR_POKER_GAME_AI_CHECK_BLUFF);
|
||||
} else {
|
||||
conversationTextboxSetText(STR_POKER_GAME_AI_CHECK);
|
||||
}
|
||||
break;
|
||||
}
|
||||
|
||||
// Now we have their turn, decide what to say based on that.
|
||||
}
|
||||
|
||||
// Update bet state
|
||||
POKER_PLAYERS[POKER_PLAYER_BETTER].state |= (
|
||||
POKER_PLAYER_STATE_HAS_BET_THIS_ROUND
|
||||
);
|
||||
|
||||
if(turn.chips > 0) {
|
||||
pokerBet(POKER_PLAYER_BETTER, turn.chips);
|
||||
}
|
||||
|
||||
QUEUE_ITEM = QUEUE_NEXT_BETTER;
|
||||
}
|
||||
|
||||
void conversationQueueNextBetter() {
|
||||
uint8_t i, j, countStillInGame;
|
||||
|
||||
// Now we decide the next better.
|
||||
countStillInGame = 0;
|
||||
for(i = 0; i < POKER_PLAYER_COUNT; i++) {
|
||||
//In theory I don't think the current better can ever be selected again.
|
||||
// if(i == POKER_PLAYER_BETTER) continue; // Commented because we now count
|
||||
|
||||
// Next better is the better to the right of the current better.
|
||||
j = (POKER_PLAYER_BETTER + i) % POKER_PLAYER_COUNT;
|
||||
if(!pokerDoesPlayerNeedToBet(j)) {
|
||||
if((POKER_PLAYERS[j].state & (POKER_PLAYER_STATE_FOLDED | POKER_PLAYER_STATE_OUT)) == 0) {
|
||||
countStillInGame++;
|
||||
}
|
||||
continue;
|
||||
}
|
||||
|
||||
// They haven't bet yet, make them the "next better"
|
||||
POKER_PLAYER_BETTER = j;
|
||||
|
||||
QUEUE_ITEM = QUEUE_BEGIN_BETTING;
|
||||
conversationQueueNext();
|
||||
return;
|
||||
}
|
||||
|
||||
// If we reach this point then we either need to begin the betting round, or
|
||||
// we are going to move to the winning decider.
|
||||
if(POKER_COMMUNITY_SIZE_MAX == POKER_COMMUNITY_SIZE || countStillInGame == 1) {
|
||||
QUEUE_ITEM = QUEUE_WINNER_DECIDE;
|
||||
conversationQueueNext();
|
||||
return;
|
||||
}
|
||||
|
||||
QUEUE_ITEM = QUEUE_FLOP;
|
||||
conversationQueueNext();
|
||||
}
|
||||
|
||||
void conversationQueueFlopTurnRiver() {
|
||||
uint8_t i, count;
|
||||
pokerplayer_t *player;
|
||||
|
||||
|
||||
switch(POKER_COMMUNITY_SIZE) {
|
||||
case 0:
|
||||
count = POKER_COUNT_FLOP;
|
||||
conversationTextboxSetText(STR_POKER_GAME_CARDS_FLOPPED);
|
||||
break;
|
||||
|
||||
case POKER_COUNT_FLOP:
|
||||
count = POKER_COUNT_TURN;
|
||||
conversationTextboxSetText(STR_POKER_GAME_CARDS_TURNED);
|
||||
break;
|
||||
|
||||
default:
|
||||
count = POKER_COUNT_RIVER;
|
||||
conversationTextboxSetText(STR_POKER_GAME_CARDS_RIVERED);
|
||||
break;
|
||||
}
|
||||
|
||||
// Reset each players required to bet state
|
||||
do {
|
||||
player = POKER_PLAYERS + i;
|
||||
player->state &= ~POKER_PLAYER_STATE_HAS_BET_THIS_ROUND;
|
||||
player->timesRaised = 0;
|
||||
} while(++i < POKER_PLAYER_COUNT);
|
||||
|
||||
// In reality we'd burn the top card but that would waste some CPU I need.
|
||||
// Deal the top cards.
|
||||
for(i = 0; i < count; i++) {
|
||||
POKER_COMMUNITY[POKER_COMMUNITY_SIZE++] = POKER_DECK[--POKER_DECK_SIZE];
|
||||
}
|
||||
|
||||
// Check how many players need to bet, if it's zero then all players are
|
||||
// either folded or all-in
|
||||
if(pokerGetRemainingBetterCount() == 0x00) {
|
||||
if(POKER_COMMUNITY_SIZE == POKER_COMMUNITY_SIZE_MAX) {
|
||||
QUEUE_ITEM = QUEUE_WINNER_DECIDE;
|
||||
} else {
|
||||
QUEUE_ITEM = QUEUE_FLOP;
|
||||
}
|
||||
} else {
|
||||
QUEUE_ITEM = QUEUE_BEGIN_BETTING;
|
||||
}
|
||||
}
|
||||
|
||||
void conversationQueueWinnerDecide() {
|
||||
pokerpot_t *pot;
|
||||
uint8_t i, j, countOfPotsWithChips, chipsEach;
|
||||
|
||||
QUEUE_ITEM = QUEUE_BEGIN;
|
||||
|
||||
countOfPotsWithChips = 0;
|
||||
for(i = 0; i < POKER_POT_COUNT; i++) {
|
||||
pot = POKER_POTS + i;
|
||||
if(pot->chips == 0) break;
|
||||
countOfPotsWithChips++;
|
||||
}
|
||||
|
||||
// TODO: Messages
|
||||
if(countOfPotsWithChips == 1) {
|
||||
} else {
|
||||
}
|
||||
|
||||
// Pots.
|
||||
for(i = 0; i < countOfPotsWithChips; i++) {
|
||||
pot = POKER_POTS + i;
|
||||
pokerWinnerDetermineForPot(
|
||||
pot,
|
||||
POKER_WINNERS,
|
||||
POKER_WINNER_PLAYERS,
|
||||
&POKER_WINNER_COUNT,
|
||||
POKER_WINNER_PARTICIPANTS,
|
||||
&POKER_WINNER_PARTICIPANT_COUNT
|
||||
);
|
||||
|
||||
chipsEach = pot->chips / POKER_WINNER_COUNT;
|
||||
for(j = 0; j < POKER_WINNER_COUNT; j++) {
|
||||
POKER_PLAYERS[POKER_WINNER_PLAYERS[j]].chips += chipsEach;
|
||||
// TODO: I can determine rounding error here if I need to, just sub the
|
||||
// taken chips for each player and when I get to chips remaining less than
|
||||
// the chipsEach, then reward the rounding offset.
|
||||
}
|
||||
}
|
||||
|
||||
// TODO: Decide on a winner for real.
|
||||
conversationTextboxSetText(STR_DEBUG_WINNER_DECIDED);
|
||||
|
||||
// New Round
|
||||
pokerNewRound();
|
||||
}
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
queuecallback_t *QUEUE_CALLBACKS[] = {
|
||||
// 0
|
||||
NULL,
|
||||
&conversationQueueDebug,
|
||||
NULL,
|
||||
NULL,
|
||||
NULL,
|
||||
|
||||
// 5
|
||||
&conversationQueueBegin,
|
||||
NULL,
|
||||
NULL,
|
||||
NULL,
|
||||
NULL,
|
||||
|
||||
// 10
|
||||
&conversationQueueTakeBlinds,
|
||||
NULL,
|
||||
NULL,
|
||||
NULL,
|
||||
NULL,
|
||||
|
||||
// 15
|
||||
&conversationQueueDealCards,
|
||||
NULL,
|
||||
NULL,
|
||||
NULL,
|
||||
NULL,
|
||||
|
||||
// 20
|
||||
&conversationQueueBeginBetting,
|
||||
NULL,
|
||||
NULL,
|
||||
NULL,
|
||||
NULL,
|
||||
|
||||
// 25
|
||||
&conversationQueueNextBetter,
|
||||
NULL,
|
||||
NULL,
|
||||
NULL,
|
||||
NULL,
|
||||
|
||||
// 30
|
||||
&conversationQueueFlopTurnRiver,
|
||||
NULL,
|
||||
NULL,
|
||||
NULL,
|
||||
NULL,
|
||||
|
||||
// 35
|
||||
NULL,
|
||||
NULL,
|
||||
NULL,
|
||||
NULL,
|
||||
NULL,
|
||||
|
||||
// 40
|
||||
&conversationQueueWinnerDecide,
|
||||
// NULL,
|
||||
// NULL,
|
||||
// NULL,
|
||||
// NULL,
|
||||
};
|
||||
|
||||
inline void conversationQueueInit() {
|
||||
QUEUE_ITEM = QUEUE_BEGIN;
|
||||
}
|
||||
|
||||
inline void conversationQueueNext() {
|
||||
BGB_printf("Doing %d", QUEUE_ITEM);
|
||||
if(QUEUE_ITEM > QUEUE_WINNER_DECIDE) return;
|
||||
if(QUEUE_CALLBACKS[QUEUE_ITEM] == NULL) return;
|
||||
QUEUE_CALLBACKS[QUEUE_ITEM]();
|
||||
}
|
@@ -1,27 +1,27 @@
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
#include "../libs.h"
|
||||
#include "../strings.h"
|
||||
|
||||
typedef void queuecallback_t();
|
||||
|
||||
extern uint16_t QUEUE_ITEM;
|
||||
extern queuecallback_t *QUEUE_CALLBACKS[];
|
||||
|
||||
#define QUEUE_DEBUG 1
|
||||
#define QUEUE_BEGIN 5
|
||||
#define QUEUE_TAKE_BLINDS 10
|
||||
#define QUEUE_DEAL_CARDS 15
|
||||
#define QUEUE_BEGIN_BETTING 20
|
||||
#define QUEUE_NEXT_BETTER 25
|
||||
#define QUEUE_FLOP 30
|
||||
#define QUEUE_WINNER_DECIDE 40
|
||||
|
||||
inline void conversationQueueInit();
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
#include "../libs.h"
|
||||
#include "../strings.h"
|
||||
|
||||
typedef void queuecallback_t();
|
||||
|
||||
extern uint16_t QUEUE_ITEM;
|
||||
extern queuecallback_t *QUEUE_CALLBACKS[];
|
||||
|
||||
#define QUEUE_DEBUG 1
|
||||
#define QUEUE_BEGIN 5
|
||||
#define QUEUE_TAKE_BLINDS 10
|
||||
#define QUEUE_DEAL_CARDS 15
|
||||
#define QUEUE_BEGIN_BETTING 20
|
||||
#define QUEUE_NEXT_BETTER 25
|
||||
#define QUEUE_FLOP 30
|
||||
#define QUEUE_WINNER_DECIDE 40
|
||||
|
||||
inline void conversationQueueInit();
|
||||
inline void conversationQueueNext();
|
@@ -1,150 +1,144 @@
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#include "textbox.h"
|
||||
|
||||
char TEXTBOX_TEXTS[TEXTBOX_SCROLL_ROWS_MAX * TEXTBOX_CHARS_PER_ROW];
|
||||
uint8_t TEXTBOX_ROW_COUNT;
|
||||
uint8_t TEXTBOX_ROW_TILE_LAST;
|
||||
uint8_t TEXTBOX_ROW_CURRENT;
|
||||
uint8_t TEXTBOX_STATE;
|
||||
uint8_t TEXTBOX_SCROLL;
|
||||
|
||||
inline void conversationTextboxInit() {
|
||||
uint8_t i;
|
||||
uint8_t TEXTBOX_TILES[TEXTBOX_TILES_MAX];
|
||||
|
||||
// Reset textbox state
|
||||
TEXTBOX_STATE = 0;
|
||||
|
||||
// Setup window data
|
||||
set_win_data(FONT_DATA_POSITION, FONT_IMAGE_TILES, FONT_IMAGE);
|
||||
set_win_data(BORDER_DATA_POSITION, BORDER_IMAGE_TILES, BORDER_IMAGE);
|
||||
}
|
||||
|
||||
void conversationTextboxSetText(char *text) {
|
||||
uint8_t i, j, k, rowStart, stateFlags;
|
||||
char c, c2;
|
||||
|
||||
// Begin by filling the textbox text chars with whitespace to begin.
|
||||
// TODO: I'm pretty sure I can move this lower and optimize.
|
||||
for(i = 0; i < TEXTBOX_SCROLL_ROWS_MAX * TEXTBOX_CHARS_PER_ROW; i++) {
|
||||
TEXTBOX_TEXTS[i] = ' ';
|
||||
}
|
||||
|
||||
// Reset textbox state
|
||||
TEXTBOX_STATE = TEXTBOX_STATE_VISIBLE;
|
||||
TEXTBOX_SCROLL = 0;
|
||||
TEXTBOX_ROW_COUNT = 0;
|
||||
TEXTBOX_ROW_COUNT = 1;
|
||||
|
||||
// Copy source text to buffer, also determine wordwrapping here.
|
||||
i = 0, j = 0, rowStart = 0, stateFlags = 0;
|
||||
while((c = text[i]) != '\0') {// "For each char in string"
|
||||
if(c == ' ') {
|
||||
// Scan ahead and look at how many chars remain to the next space.
|
||||
k = i + 1;
|
||||
while(
|
||||
(c2 = text[k]) != '\0' &&
|
||||
c2 != '\n' &&
|
||||
c2 != ' ' &&
|
||||
(k - rowStart) < TEXTBOX_CHARS_PER_ROW
|
||||
) k++;
|
||||
|
||||
// IF that number is less than the remaining chars on the current row,
|
||||
// then treat this space like a newline.
|
||||
if(k >= (rowStart + TEXTBOX_CHARS_PER_ROW + 1)) {
|
||||
stateFlags |= 1 << 0;
|
||||
}
|
||||
} else if(c == '\n') {
|
||||
stateFlags |= 1 << 0;
|
||||
}
|
||||
|
||||
// Do we need to insert newline where we are currently?
|
||||
if((stateFlags & (1 << 0)) != 0) {
|
||||
stateFlags &= ~(1 << 0);// Remove newline flag
|
||||
i++;
|
||||
rowStart = i;// Update the row start (Should this be i+1?)
|
||||
//TODO: can I optimize the next line by using rowStart somehow?
|
||||
j = ((j / TEXTBOX_CHARS_PER_ROW)+1) * TEXTBOX_CHARS_PER_ROW;// Update destination character position.
|
||||
TEXTBOX_ROW_COUNT++;
|
||||
continue;
|
||||
}
|
||||
|
||||
// Insert the character
|
||||
TEXTBOX_TEXTS[j] = c;
|
||||
i++;
|
||||
j++;
|
||||
}
|
||||
|
||||
// Now we have organized the string nicely we can prep for rendering. Fill the
|
||||
// tiles with blank chars.
|
||||
textboxFillBlank();
|
||||
}
|
||||
|
||||
inline void textboxFillBlank() {
|
||||
uint8_t TEXTBOX_TILES[TEXTBOX_WIDTH_IN_TILES * TEXTBOX_HEIGHT_IN_TILES];
|
||||
|
||||
frameBuffer(TEXTBOX_TILES, TEXTBOX_WIDTH_IN_TILES, TEXTBOX_HEIGHT_IN_TILES, TEXTBOX_TILE_BLANK);
|
||||
|
||||
set_bkg_tiles(
|
||||
0x00, TEXTBOX_WIN_Y,
|
||||
TEXTBOX_WIDTH_IN_TILES, TEXTBOX_HEIGHT_IN_TILES,
|
||||
TEXTBOX_TILES
|
||||
);
|
||||
}
|
||||
|
||||
inline void conversationTextboxUpdate() {
|
||||
uint8_t i;
|
||||
char c;
|
||||
uint8_t tiles[1];
|
||||
|
||||
// Is the textbox visible?
|
||||
if((TEXTBOX_STATE & TEXTBOX_STATE_VISIBLE) == 0) return;
|
||||
|
||||
// Have we finished scrolling?
|
||||
if(TEXTBOX_STATE & TEXTBOX_STATE_SCROLLED) {
|
||||
// Is the user trying to go to the next line?
|
||||
if(INPUT_PRESSED & J_A) {
|
||||
// First, lets figure out if there's any more text to reveal or not.
|
||||
if((TEXTBOX_ROW_COUNT - TEXTBOX_ROW_CURRENT) < TEXTBOX_TILES_ROWS) {
|
||||
TEXTBOX_STATE &= ~TEXTBOX_STATE_VISIBLE;
|
||||
HIDE_WIN;
|
||||
conversationQueueNext();
|
||||
return;
|
||||
}
|
||||
|
||||
TEXTBOX_STATE &= ~TEXTBOX_STATE_SCROLLED;
|
||||
TEXTBOX_SCROLL = 0;
|
||||
TEXTBOX_ROW_CURRENT += TEXTBOX_TILES_ROWS;
|
||||
textboxFillBlank();
|
||||
}
|
||||
return;
|
||||
}
|
||||
|
||||
// Move to the next character.
|
||||
i = TEXTBOX_ROW_CURRENT * TEXTBOX_CHARS_PER_ROW;
|
||||
c = TEXTBOX_TEXTS[i+TEXTBOX_SCROLL];
|
||||
|
||||
if(TEXTBOX_SCROLL == TEXTBOX_CHARS_MAX) {
|
||||
TEXTBOX_STATE |= TEXTBOX_STATE_SCROLLED;
|
||||
} else {
|
||||
tiles[0] = c - TEXTBOX_FONT_START + FONT_DATA_POSITION;
|
||||
|
||||
set_bkg_tiles(
|
||||
0x01 + (TEXTBOX_SCROLL % TEXTBOX_CHARS_PER_ROW),
|
||||
TEXTBOX_WIN_Y + 0x01 + (TEXTBOX_SCROLL / TEXTBOX_CHARS_PER_ROW),
|
||||
1, 1,
|
||||
tiles
|
||||
);
|
||||
|
||||
TEXTBOX_SCROLL++;
|
||||
|
||||
// Skip spaces
|
||||
while(TEXTBOX_SCROLL < TEXTBOX_CHARS_MAX && TEXTBOX_TEXTS[i+TEXTBOX_SCROLL] == ' ') TEXTBOX_SCROLL++;
|
||||
}
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#include "textbox.h"
|
||||
|
||||
char TEXTBOX_TEXTS[TEXTBOX_SCROLL_ROWS_MAX * TEXTBOX_CHARS_PER_ROW];
|
||||
uint8_t TEXTBOX_ROW_COUNT;
|
||||
uint8_t TEXTBOX_ROW_TILE_LAST;
|
||||
uint8_t TEXTBOX_ROW_CURRENT;
|
||||
uint8_t TEXTBOX_STATE;
|
||||
uint8_t TEXTBOX_SCROLL;
|
||||
|
||||
inline void conversationTextboxInit() {
|
||||
// Reset textbox state
|
||||
TEXTBOX_STATE = 0;
|
||||
}
|
||||
|
||||
void conversationTextboxSetText(char *text) {
|
||||
uint8_t i, j, k, rowStart, stateFlags;
|
||||
char c, c2;
|
||||
|
||||
// Begin by filling the textbox text chars with whitespace to begin.
|
||||
// TODO: I'm pretty sure I can move this lower and optimize.
|
||||
for(i = 0; i < TEXTBOX_SCROLL_ROWS_MAX * TEXTBOX_CHARS_PER_ROW; i++) {
|
||||
TEXTBOX_TEXTS[i] = ' ';
|
||||
}
|
||||
|
||||
// Reset textbox state
|
||||
TEXTBOX_STATE = TEXTBOX_STATE_VISIBLE;
|
||||
TEXTBOX_SCROLL = 0;
|
||||
TEXTBOX_ROW_COUNT = 0;
|
||||
TEXTBOX_ROW_COUNT = 1;
|
||||
|
||||
// Copy source text to buffer, also determine wordwrapping here.
|
||||
i = 0, j = 0, rowStart = 0, stateFlags = 0;
|
||||
while((c = text[i]) != '\0') {// "For each char in string"
|
||||
if(c == ' ') {
|
||||
// Scan ahead and look at how many chars remain to the next space.
|
||||
k = i + 1;
|
||||
while(
|
||||
(c2 = text[k]) != '\0' &&
|
||||
c2 != '\n' &&
|
||||
c2 != ' ' &&
|
||||
(k - rowStart) < TEXTBOX_CHARS_PER_ROW
|
||||
) k++;
|
||||
|
||||
// IF that number is less than the remaining chars on the current row,
|
||||
// then treat this space like a newline.
|
||||
if(k >= (rowStart + TEXTBOX_CHARS_PER_ROW + 1)) {
|
||||
stateFlags |= 1 << 0;
|
||||
}
|
||||
} else if(c == '\n') {
|
||||
stateFlags |= 1 << 0;
|
||||
}
|
||||
|
||||
// Do we need to insert newline where we are currently?
|
||||
if((stateFlags & (1 << 0)) != 0) {
|
||||
stateFlags &= ~(1 << 0);// Remove newline flag
|
||||
i++;
|
||||
rowStart = i;// Update the row start (Should this be i+1?)
|
||||
//TODO: can I optimize the next line by using rowStart somehow?
|
||||
j = ((j / TEXTBOX_CHARS_PER_ROW)+1) * TEXTBOX_CHARS_PER_ROW;// Update destination character position.
|
||||
TEXTBOX_ROW_COUNT++;
|
||||
continue;
|
||||
}
|
||||
|
||||
// Insert the character
|
||||
TEXTBOX_TEXTS[j] = c;
|
||||
i++;
|
||||
j++;
|
||||
}
|
||||
|
||||
// Now we have organized the string nicely we can prep for rendering. Fill the
|
||||
// tiles with blank chars.
|
||||
textboxFillBlank();
|
||||
}
|
||||
|
||||
inline void textboxFillBlank() {
|
||||
uint8_t tiles[TEXTBOX_WIDTH_IN_TILES * TEXTBOX_HEIGHT_IN_TILES];
|
||||
|
||||
spriteBorderBufferEdges(
|
||||
tiles, TEXTBOX_WIDTH_IN_TILES, TEXTBOX_HEIGHT_IN_TILES, SPRITE_TILESET_WHITE
|
||||
);
|
||||
|
||||
set_bkg_tiles(
|
||||
0x00, TEXTBOX_WIN_Y,
|
||||
TEXTBOX_WIDTH_IN_TILES, TEXTBOX_HEIGHT_IN_TILES,
|
||||
tiles
|
||||
);
|
||||
}
|
||||
|
||||
inline void conversationTextboxUpdate() {
|
||||
uint8_t i, tile;
|
||||
char c;
|
||||
|
||||
// Is the textbox visible?
|
||||
if((TEXTBOX_STATE & TEXTBOX_STATE_VISIBLE) == 0) return;
|
||||
|
||||
// Have we finished scrolling?
|
||||
if(TEXTBOX_STATE & TEXTBOX_STATE_SCROLLED) {
|
||||
// Is the user trying to go to the next line?
|
||||
if(INPUT_PRESSED & J_A) {
|
||||
// First, lets figure out if there's any more text to reveal or not.
|
||||
if((TEXTBOX_ROW_COUNT - TEXTBOX_ROW_CURRENT) < TEXTBOX_TILES_ROWS) {
|
||||
TEXTBOX_STATE &= ~TEXTBOX_STATE_VISIBLE;
|
||||
HIDE_WIN;
|
||||
conversationQueueNext();
|
||||
return;
|
||||
}
|
||||
|
||||
TEXTBOX_STATE &= ~TEXTBOX_STATE_SCROLLED;
|
||||
TEXTBOX_SCROLL = 0;
|
||||
TEXTBOX_ROW_CURRENT += TEXTBOX_TILES_ROWS;
|
||||
textboxFillBlank();
|
||||
}
|
||||
return;
|
||||
}
|
||||
|
||||
// Move to the next character.
|
||||
i = TEXTBOX_ROW_CURRENT * TEXTBOX_CHARS_PER_ROW;
|
||||
c = TEXTBOX_TEXTS[i+TEXTBOX_SCROLL];
|
||||
|
||||
if(TEXTBOX_SCROLL == TEXTBOX_CHARS_MAX) {
|
||||
TEXTBOX_STATE |= TEXTBOX_STATE_SCROLLED;
|
||||
} else {
|
||||
tile = spriteFontTileFromChar(c);
|
||||
|
||||
set_bkg_tiles(
|
||||
0x01 + (TEXTBOX_SCROLL % TEXTBOX_CHARS_PER_ROW),
|
||||
TEXTBOX_WIN_Y + 0x01 + (TEXTBOX_SCROLL / TEXTBOX_CHARS_PER_ROW),
|
||||
1, 1,
|
||||
&tile
|
||||
);
|
||||
|
||||
TEXTBOX_SCROLL++;
|
||||
|
||||
// Skip spaces
|
||||
while(TEXTBOX_SCROLL < TEXTBOX_CHARS_MAX && TEXTBOX_TEXTS[i+TEXTBOX_SCROLL] == ' ') TEXTBOX_SCROLL++;
|
||||
}
|
||||
}
|
@@ -1,49 +1,46 @@
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
#include "../libs.h"
|
||||
#include "../util.h"
|
||||
#include "../input.h"
|
||||
#include "../display/common.h"
|
||||
#include "../display/tilemap.h"
|
||||
#include "queue.h"
|
||||
#include "frame.h"
|
||||
|
||||
#define TEXTBOX_STATE_VISIBLE (1 << 0)
|
||||
#define TEXTBOX_STATE_SCROLLED (1 << 1)
|
||||
#define TEXTBOX_STATE_IS_QUESTION (1 << 2)
|
||||
|
||||
#define TEXTBOX_WIDTH_IN_TILES 20
|
||||
#define TEXTBOX_HEIGHT_IN_TILES 5
|
||||
#define TEXTBOX_TILES_MAX (TEXTBOX_WIDTH_IN_TILES * TEXTBOX_HEIGHT_IN_TILES)
|
||||
|
||||
#define TEXTBOX_CHARS_PER_ROW (TEXTBOX_WIDTH_IN_TILES - 2)
|
||||
#define TEXTBOX_CHAR_ROWS (TEXTBOX_HEIGHT_IN_TILES - 2)
|
||||
#define TEXTBOX_CHARS_MAX (TEXTBOX_CHAR_ROWS * TEXTBOX_CHARS_PER_ROW)
|
||||
#define TEXTBOX_BUFFER_MAX (TEXTBOX_CHARS_MAX * 3)
|
||||
|
||||
#define TEXTBOX_TILES_PER_ROW TEXTBOX_WIDTH_IN_TILES
|
||||
#define TEXTBOX_TILES_ROWS 3
|
||||
#define TEXTBOX_TILE_BLANK COMMON_TILE_3
|
||||
|
||||
#define TEXTBOX_SCROLL_ROWS_MAX 14
|
||||
|
||||
#define TEXTBOX_FONT_START 33
|
||||
|
||||
#define TEXTBOX_WIN_Y (18 - TEXTBOX_HEIGHT_IN_TILES)
|
||||
|
||||
extern char TEXTBOX_TEXTS[TEXTBOX_SCROLL_ROWS_MAX * TEXTBOX_CHARS_PER_ROW];
|
||||
extern uint8_t TEXTBOX_ROW_COUNT;
|
||||
extern uint8_t TEXTBOX_ROW_CURRENT;
|
||||
extern uint8_t TEXTBOX_STATE;
|
||||
extern uint8_t TEXTBOX_SCROLL;
|
||||
|
||||
inline void conversationTextboxInit();
|
||||
void conversationTextboxSetText(char *text);
|
||||
inline void textboxFillBlank();
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
#include "../libs.h"
|
||||
#include "../util.h"
|
||||
#include "../input.h"
|
||||
#include "../sprites/spriteborder.h"
|
||||
#include "../sprites/spritefont.h"
|
||||
#include "../sprites/spritetileset.h"
|
||||
#include "queue.h"
|
||||
|
||||
#define TEXTBOX_STATE_VISIBLE (1 << 0)
|
||||
#define TEXTBOX_STATE_SCROLLED (1 << 1)
|
||||
#define TEXTBOX_STATE_IS_QUESTION (1 << 2)
|
||||
|
||||
#define TEXTBOX_WIDTH_IN_TILES 20
|
||||
#define TEXTBOX_HEIGHT_IN_TILES 5
|
||||
#define TEXTBOX_TILES_MAX (TEXTBOX_WIDTH_IN_TILES * TEXTBOX_HEIGHT_IN_TILES)
|
||||
|
||||
#define TEXTBOX_CHARS_PER_ROW (TEXTBOX_WIDTH_IN_TILES - 2)
|
||||
#define TEXTBOX_CHAR_ROWS (TEXTBOX_HEIGHT_IN_TILES - 2)
|
||||
#define TEXTBOX_CHARS_MAX (TEXTBOX_CHAR_ROWS * TEXTBOX_CHARS_PER_ROW)
|
||||
#define TEXTBOX_BUFFER_MAX (TEXTBOX_CHARS_MAX * 3)
|
||||
|
||||
#define TEXTBOX_TILES_PER_ROW TEXTBOX_WIDTH_IN_TILES
|
||||
#define TEXTBOX_TILES_ROWS 3
|
||||
|
||||
#define TEXTBOX_SCROLL_ROWS_MAX 14
|
||||
|
||||
#define TEXTBOX_WIN_Y (18 - TEXTBOX_HEIGHT_IN_TILES)
|
||||
|
||||
extern char TEXTBOX_TEXTS[TEXTBOX_SCROLL_ROWS_MAX * TEXTBOX_CHARS_PER_ROW];
|
||||
extern uint8_t TEXTBOX_ROW_COUNT;
|
||||
extern uint8_t TEXTBOX_ROW_CURRENT;
|
||||
extern uint8_t TEXTBOX_STATE;
|
||||
extern uint8_t TEXTBOX_SCROLL;
|
||||
|
||||
inline void conversationTextboxInit();
|
||||
void conversationTextboxSetText(char *text);
|
||||
inline void textboxFillBlank();
|
||||
inline void conversationTextboxUpdate();
|
@@ -1,19 +0,0 @@
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#include "common.h"
|
||||
|
||||
const uint8_t COMMON_TILES[] = {
|
||||
0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,
|
||||
0xFF,0x00,0xFF,0x00,0xFF,0x00,0xFF,0x00,0xFF,0x00,0xFF,0x00,0xFF,0x00,0xFF,0x00,
|
||||
0x00,0xFF,0x00,0xFF,0x00,0xFF,0x00,0xFF,0x00,0xFF,0x00,0xFF,0x00,0xFF,0x00,0xFF,
|
||||
0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00
|
||||
};
|
||||
|
||||
inline void commonTilesInit() {
|
||||
set_bkg_data(0x00, COMMON_TILE_COUNT, COMMON_TILES);
|
||||
}
|
@@ -1,37 +0,0 @@
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
#include "../libs.h"
|
||||
|
||||
#define COMMON_TILE_COUNT 0x04
|
||||
|
||||
#define COMMON_TILE_0 0x00
|
||||
#define COMMON_TILE_1 0x01
|
||||
#define COMMON_TILE_2 0x02
|
||||
#define COMMON_TILE_3 0x03
|
||||
|
||||
// Shades are mapped where each set of 4 colors is mapped to two bits that will
|
||||
// specify its darkness. Higher = Darker, Lower = Brighter
|
||||
// 11 11 11 11
|
||||
#define COMMON_SHADE_BLACK 0xFF
|
||||
// 11 11 11 10
|
||||
#define COMMON_SHADE_DARKER 0xFE
|
||||
// 11 11 10 01
|
||||
#define COMMON_SHADE_DARK 0xF9
|
||||
// 11 10 01 00
|
||||
#define COMMON_SHADE_NORMAL 0xE4
|
||||
// 10 01 00 00
|
||||
#define COMMON_SHADE_BRIGHT 0x90
|
||||
// 01 00 00 00
|
||||
#define COMMON_SHADE_BRIGHTER 0x40
|
||||
// 00 00 00 00
|
||||
#define COMMON_SHADE_WHITE 0x00
|
||||
|
||||
extern const uint8_t COMMON_TILES[];
|
||||
|
||||
inline void commonTilesInit();
|
@@ -1,15 +0,0 @@
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
#include "FONT.h"
|
||||
#include "BORDER.h"
|
||||
// #include "SM.h"
|
||||
|
||||
#define FONT_DATA_POSITION 0x80
|
||||
#define BORDER_DATA_POSITION FONT_DATA_POSITION+FONT_IMAGE_TILES
|
||||
// #define SM_DATA_POSITION BORDER_DATA_POSITION+BORDER_IMAGE_TILES
|
22
src/input.c
22
src/input.c
@@ -1,12 +1,12 @@
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#include "input.h"
|
||||
|
||||
uint8_t INPUT_STATE = 0x00;
|
||||
uint8_t INPUT_PRESSED = 0x00;
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#include "input.h"
|
||||
|
||||
uint8_t INPUT_STATE = 0x00;
|
||||
uint8_t INPUT_PRESSED = 0x00;
|
||||
uint8_t INPUT_LAST = 0x00;
|
24
src/input.h
24
src/input.h
@@ -1,13 +1,13 @@
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
#include "libs.h"
|
||||
|
||||
extern uint8_t INPUT_STATE;
|
||||
extern uint8_t INPUT_PRESSED;
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
#include "libs.h"
|
||||
|
||||
extern uint8_t INPUT_STATE;
|
||||
extern uint8_t INPUT_PRESSED;
|
||||
extern uint8_t INPUT_LAST;
|
28
src/libs.h
28
src/libs.h
@@ -1,15 +1,15 @@
|
||||
/**
|
||||
* Copyright (c) 2021 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
#include <gb/gb.h>
|
||||
#include <gb/bgb_emu.h>
|
||||
#include <stdint.h>
|
||||
#include <stdio.h>
|
||||
#include <stdbool.h>
|
||||
#include <rand.h>
|
||||
/**
|
||||
* Copyright (c) 2021 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
#include <gb/gb.h>
|
||||
#include <gb/bgb_emu.h>
|
||||
#include <stdint.h>
|
||||
#include <stdio.h>
|
||||
#include <stdbool.h>
|
||||
#include <rand.h>
|
||||
#include <string.h>
|
296
src/main.c
296
src/main.c
@@ -1,218 +1,80 @@
|
||||
/**
|
||||
* Copyright (c) 2021 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#include "main.h"
|
||||
|
||||
inline uint8_t mainGetChar(char c) {
|
||||
return c - TEXTBOX_FONT_START + FONT_DATA_POSITION;
|
||||
}
|
||||
|
||||
inline void mainBufferCard(uint8_t card, uint8_t *tiles) {
|
||||
uint8_t suit, number;
|
||||
|
||||
if(card >= CARD_DECK_SIZE) {
|
||||
tiles[0] = mainGetChar('N');
|
||||
tiles[1] = mainGetChar('A');
|
||||
return;
|
||||
}
|
||||
|
||||
suit = cardGetSuit(card);
|
||||
number = cardGetNumber(card);
|
||||
|
||||
switch(suit) {
|
||||
case CARD_SUIT_CLUBS:
|
||||
tiles[0] = mainGetChar('C');
|
||||
break;
|
||||
case CARD_SUIT_DIAMONDS:
|
||||
tiles[0] = mainGetChar('D');
|
||||
break;
|
||||
case CARD_SUIT_HEARTS:
|
||||
tiles[0] = mainGetChar('H');
|
||||
break;
|
||||
case CARD_SUIT_SPADES:
|
||||
tiles[0] = mainGetChar('S');
|
||||
break;
|
||||
}
|
||||
|
||||
switch(number) {
|
||||
case CARD_TWO:
|
||||
tiles[1] = mainGetChar('2');
|
||||
break;
|
||||
case CARD_THREE:
|
||||
tiles[1] = mainGetChar('3');
|
||||
break;
|
||||
case CARD_FOUR:
|
||||
tiles[1] = mainGetChar('4');
|
||||
break;
|
||||
case CARD_FIVE:
|
||||
tiles[1] = mainGetChar('5');
|
||||
break;
|
||||
case CARD_SIX:
|
||||
tiles[1] = mainGetChar('6');
|
||||
break;
|
||||
case CARD_SEVEN:
|
||||
tiles[1] = mainGetChar('7');
|
||||
break;
|
||||
case CARD_EIGHT:
|
||||
tiles[1] = mainGetChar('8');
|
||||
break;
|
||||
case CARD_NINE:
|
||||
tiles[1] = mainGetChar('9');
|
||||
break;
|
||||
case CARD_TEN:
|
||||
tiles[1] = mainGetChar('T');
|
||||
break;
|
||||
case CARD_JACK:
|
||||
tiles[1] = mainGetChar('J');
|
||||
break;
|
||||
case CARD_QUEEN:
|
||||
tiles[1] = mainGetChar('Q');
|
||||
break;
|
||||
case CARD_KING:
|
||||
tiles[1] = mainGetChar('K');
|
||||
break;
|
||||
case CARD_ACE:
|
||||
tiles[1] = mainGetChar('A');
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
inline void mainDebugDraw() {
|
||||
uint8_t j, i, n;
|
||||
|
||||
// DEBUG DRAW
|
||||
uint8_t tiles[15];
|
||||
char buffer[6];
|
||||
buffer[0] = '\0';
|
||||
|
||||
for(j = 0; j < POKER_PLAYER_COUNT; j++) {
|
||||
n = 0;
|
||||
|
||||
if(j == POKER_PLAYER_BETTER) {
|
||||
tiles[n++] = mainGetChar('>');
|
||||
} else {
|
||||
tiles[n++] = COMMON_TILE_3;
|
||||
}
|
||||
|
||||
mainBufferCard(POKER_PLAYERS[j].hand[0], tiles+n);
|
||||
n+=2;
|
||||
mainBufferCard(POKER_PLAYERS[j].hand[1], tiles+n);
|
||||
n+=2;
|
||||
|
||||
tiles[n++] = COMMON_TILE_3;
|
||||
|
||||
if((POKER_PLAYERS[j].state & POKER_PLAYER_STATE_FOLDED) == 0) {
|
||||
tiles[n++] = COMMON_TILE_3;
|
||||
} else {
|
||||
tiles[n++] = mainGetChar('F');
|
||||
}
|
||||
|
||||
if((POKER_PLAYERS[j].state & POKER_PLAYER_STATE_HAS_BET_THIS_ROUND) == 0) {
|
||||
tiles[n++] = COMMON_TILE_3;
|
||||
} else {
|
||||
tiles[n++] = mainGetChar('H');
|
||||
}
|
||||
|
||||
if((POKER_PLAYERS[j].state & POKER_PLAYER_STATE_OUT) == 0) {
|
||||
tiles[n++] = COMMON_TILE_3;
|
||||
} else {
|
||||
tiles[n++] = mainGetChar('O');
|
||||
}
|
||||
|
||||
tiles[n++] = COMMON_TILE_3;
|
||||
|
||||
// Print chips
|
||||
sprintf(buffer, "%u", (uint16_t)POKER_PLAYERS[j].chips);
|
||||
for(i = 0; i < strlen(buffer); i++) {
|
||||
tiles[n++] = mainGetChar(buffer[i]);
|
||||
}
|
||||
|
||||
while(n < 15) tiles[n++] = COMMON_TILE_3;
|
||||
set_bkg_tiles(0x00, j, n - 1, 1, tiles);
|
||||
}
|
||||
|
||||
for(j = 0; j < POKER_COMMUNITY_SIZE_MAX; j++) {
|
||||
if(j >= POKER_COMMUNITY_SIZE) {
|
||||
tiles[j*2] = COMMON_TILE_3;
|
||||
tiles[(j*2) + 1] = COMMON_TILE_3;
|
||||
} else {
|
||||
mainBufferCard(POKER_COMMUNITY[j], tiles + (j * 2));
|
||||
}
|
||||
}
|
||||
|
||||
set_bkg_tiles(0x00, POKER_PLAYER_COUNT + 1, POKER_COMMUNITY_SIZE_MAX * 2, 1, tiles);
|
||||
|
||||
|
||||
// Print Pot
|
||||
n = 0;
|
||||
sprintf(buffer, "%u", (uint16_t)POKER_POTS[POKER_POT_CURRENT].chips);
|
||||
for(i = 0; i < strlen(buffer); i++) {
|
||||
tiles[n++] = mainGetChar(buffer[i]);
|
||||
}
|
||||
while(n < 5) tiles[n++] = COMMON_TILE_3;
|
||||
set_bkg_tiles(0x00, POKER_PLAYER_COUNT + 2, n, 1, tiles);
|
||||
}
|
||||
|
||||
void main() {
|
||||
int16_t j;
|
||||
uint8_t filled[GB_BACKGROUND_COLUMNS*GB_BACKGROUND_ROWS];
|
||||
|
||||
// Set up the GAMEBOY's registers.
|
||||
disable_interrupts();
|
||||
DISPLAY_OFF;
|
||||
LCDC_REG = LCDCF_OFF | LCDCF_WIN9C00 | LCDCF_BG8800 | LCDCF_BG9800 | LCDCF_BGON;
|
||||
// Set the background color palette register
|
||||
BGP_REG = OBP0_REG = OBP1_REG = 0xE4U;
|
||||
|
||||
// Init the random seed
|
||||
initarand(DIV_REG);
|
||||
|
||||
// Init things
|
||||
commonTilesInit();
|
||||
conversationTextboxInit();
|
||||
conversationQueueInit();
|
||||
pokerInit();
|
||||
|
||||
// Fill screen white
|
||||
for(j = 0; j < GB_BACKGROUND_COLUMNS * GB_BACKGROUND_ROWS; j++) filled[j] = COMMON_TILE_3;
|
||||
set_bkg_tiles(0x00, 0x00, GB_BACKGROUND_COLUMNS, GB_BACKGROUND_ROWS, filled);
|
||||
SCX_REG = 0x00;
|
||||
SCY_REG = 0x00;
|
||||
|
||||
// Now turn the screen on
|
||||
DISPLAY_ON;
|
||||
enable_interrupts();
|
||||
wait_vbl_done();
|
||||
|
||||
// Begin game
|
||||
conversationQueueNext();
|
||||
|
||||
// Begin the loop
|
||||
while(1) {
|
||||
// Perform non-graphical code updates
|
||||
wait_vbl_done();
|
||||
|
||||
// Update the input state
|
||||
INPUT_LAST = INPUT_STATE;
|
||||
INPUT_STATE = joypad();
|
||||
INPUT_PRESSED = (~INPUT_LAST) & INPUT_STATE;
|
||||
|
||||
// Tick time.
|
||||
timeUpdate();
|
||||
|
||||
// Update conversation pause effect
|
||||
conversationPauseUpdate();
|
||||
|
||||
// Update question box and textbox
|
||||
questionBoxUpdate();
|
||||
conversationTextboxUpdate();
|
||||
|
||||
// Update conversation fade effect
|
||||
conversationFadeUpdate();
|
||||
mainDebugDraw();
|
||||
}
|
||||
/**
|
||||
* Copyright (c) 2021 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#include "main.h"
|
||||
|
||||
void main() {
|
||||
int16_t j;
|
||||
uint8_t filled[GB_BACKGROUND_COLUMNS*GB_BACKGROUND_ROWS];
|
||||
|
||||
// Set up the GAMEBOY's registers.
|
||||
disable_interrupts();
|
||||
DISPLAY_OFF;
|
||||
LCDC_REG = LCDCF_OFF | LCDCF_BG8000 | LCDCF_BG9800 | LCDCF_BGON;
|
||||
|
||||
// Set the background color palette register
|
||||
BGP_REG = OBP0_REG = OBP1_REG = 0xE4U;
|
||||
|
||||
// Init the random seed
|
||||
initarand(DIV_REG);
|
||||
|
||||
// Init things
|
||||
spriteTilesetBuffer();
|
||||
spriteFontBuffer();
|
||||
spriteBorderBuffer();
|
||||
spriteCardsBuffer();
|
||||
|
||||
conversationTextboxInit();
|
||||
conversationQueueInit();
|
||||
pokerInit();
|
||||
|
||||
// Fill screen white
|
||||
for(j = 0; j < GB_BACKGROUND_COLUMNS * GB_BACKGROUND_ROWS; j++) {
|
||||
filled[j] = SPRITE_TILESET_WHITE;
|
||||
}
|
||||
set_bkg_tiles(0x00, 0x00, GB_BACKGROUND_COLUMNS, GB_BACKGROUND_ROWS, filled);
|
||||
SCX_REG = 0x00;
|
||||
SCY_REG = 0x00;
|
||||
|
||||
// Card Test
|
||||
uint8_t cardTiles[SPRITE_CARD_TILE_COUNT];
|
||||
spriteCardBufferTiles(cardTiles, CARD_HEARTS_TWO);
|
||||
set_bkg_tiles(0x00, 0x00, SPRITE_CARD_WIDTH, SPRITE_CARD_HEIGHT, cardTiles);
|
||||
|
||||
// Now turn the screen on
|
||||
DISPLAY_ON;
|
||||
enable_interrupts();
|
||||
wait_vbl_done();
|
||||
|
||||
// Begin game
|
||||
conversationQueueNext();
|
||||
|
||||
// Begin the loop
|
||||
while(1) {
|
||||
// Perform non-graphical code updates
|
||||
wait_vbl_done();
|
||||
|
||||
// Update the input state
|
||||
INPUT_LAST = INPUT_STATE;
|
||||
INPUT_STATE = joypad();
|
||||
INPUT_PRESSED = (~INPUT_LAST) & INPUT_STATE;
|
||||
|
||||
// Tick time.
|
||||
timeUpdate();
|
||||
|
||||
// Update conversation pause effect
|
||||
conversationPauseUpdate();
|
||||
|
||||
// Update question box and textbox
|
||||
questionBoxUpdate();
|
||||
conversationTextboxUpdate();
|
||||
|
||||
// Update conversation fade effect
|
||||
conversationFadeUpdate();
|
||||
// mainDebugDraw();
|
||||
}
|
||||
}
|
54
src/main.h
54
src/main.h
@@ -1,28 +1,28 @@
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
|
||||
#include "libs.h"
|
||||
#include "time.h"
|
||||
|
||||
#include "SM.h"
|
||||
|
||||
#include "display/common.h"
|
||||
#include "display/tilemap.h"
|
||||
#include "poker/poker.h"
|
||||
#include "poker/card.h"
|
||||
#include "conversation/fade.h"
|
||||
#include "conversation/pause.h"
|
||||
#include "conversation/queue.h"
|
||||
#include "conversation/textbox.h"
|
||||
#include "conversation/questionbox.h"
|
||||
|
||||
#define GB_BACKGROUND_COLUMNS 0x20
|
||||
#define GB_BACKGROUND_ROWS 0x20
|
||||
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
|
||||
#include "libs.h"
|
||||
#include "time.h"
|
||||
|
||||
#include "SM.h"
|
||||
|
||||
#include "poker/poker.h"
|
||||
#include "poker/card.h"
|
||||
#include "conversation/fade.h"
|
||||
#include "conversation/pause.h"
|
||||
#include "conversation/queue.h"
|
||||
#include "conversation/textbox.h"
|
||||
#include "conversation/questionbox.h"
|
||||
|
||||
#include "sprites/spritecards.h"
|
||||
|
||||
#define GB_BACKGROUND_COLUMNS 0x20
|
||||
#define GB_BACKGROUND_ROWS 0x20
|
||||
|
||||
void main();
|
@@ -1,50 +1,50 @@
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#include "card.h"
|
||||
|
||||
inline uint8_t cardGetNumber(uint8_t card) {
|
||||
return card % CARD_COUNT_PER_SUIT;
|
||||
}
|
||||
|
||||
inline uint8_t cardGetSuit(uint8_t card) {
|
||||
return card / CARD_COUNT_PER_SUIT;
|
||||
}
|
||||
|
||||
inline uint8_t cardGet(uint8_t number, uint8_t suit) {
|
||||
return (suit * CARD_COUNT_PER_SUIT) + number;
|
||||
}
|
||||
|
||||
inline uint8_t cardContains(uint8_t *hand, uint8_t length, uint8_t card) {
|
||||
uint8_t i;
|
||||
for(i = 0; i < length; i++) {
|
||||
if(hand[i] == card) return i;
|
||||
}
|
||||
return 0xFF;
|
||||
}
|
||||
|
||||
inline uint8_t cardContainsNumber(uint8_t *hand,uint8_t length,uint8_t number) {
|
||||
uint8_t i;
|
||||
for(i = 0; i < length; i++) {
|
||||
if(cardGetNumber(hand[i]) == number) return i;
|
||||
}
|
||||
return 0xFF;
|
||||
}
|
||||
|
||||
inline uint8_t cardCountPairs(
|
||||
uint8_t *in, uint8_t inCount, uint8_t number, uint8_t out[CARD_SUIT_COUNT]
|
||||
) {
|
||||
uint8_t i, count;
|
||||
|
||||
count = 0;
|
||||
for(i = 0; i < inCount; i++) {// "For each suit"
|
||||
if(cardGetNumber(in[i]) != number) continue;
|
||||
out[count++] = i;
|
||||
}
|
||||
|
||||
return count;
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#include "card.h"
|
||||
|
||||
inline uint8_t cardGetNumber(uint8_t card) {
|
||||
return card % CARD_COUNT_PER_SUIT;
|
||||
}
|
||||
|
||||
inline uint8_t cardGetSuit(uint8_t card) {
|
||||
return card / CARD_COUNT_PER_SUIT;
|
||||
}
|
||||
|
||||
inline uint8_t cardGet(uint8_t number, uint8_t suit) {
|
||||
return (suit * CARD_COUNT_PER_SUIT) + number;
|
||||
}
|
||||
|
||||
inline uint8_t cardContains(uint8_t *hand, uint8_t length, uint8_t card) {
|
||||
uint8_t i;
|
||||
for(i = 0; i < length; i++) {
|
||||
if(hand[i] == card) return i;
|
||||
}
|
||||
return 0xFF;
|
||||
}
|
||||
|
||||
inline uint8_t cardContainsNumber(uint8_t *hand,uint8_t length,uint8_t number) {
|
||||
uint8_t i;
|
||||
for(i = 0; i < length; i++) {
|
||||
if(cardGetNumber(hand[i]) == number) return i;
|
||||
}
|
||||
return 0xFF;
|
||||
}
|
||||
|
||||
inline uint8_t cardCountPairs(
|
||||
uint8_t *in, uint8_t inCount, uint8_t number, uint8_t out[CARD_SUIT_COUNT]
|
||||
) {
|
||||
uint8_t i, count;
|
||||
|
||||
count = 0;
|
||||
for(i = 0; i < inCount; i++) {// "For each suit"
|
||||
if(cardGetNumber(in[i]) != number) continue;
|
||||
out[count++] = i;
|
||||
}
|
||||
|
||||
return count;
|
||||
}
|
232
src/poker/card.h
232
src/poker/card.h
@@ -1,117 +1,117 @@
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
#include "../libs.h"
|
||||
#include "../util.h"
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////
|
||||
// Cards
|
||||
////////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
// Aces
|
||||
#define CARD_CLUBS_TWO 0x00
|
||||
#define CARD_CLUBS_THREE 0x01
|
||||
#define CARD_CLUBS_FOUR 0x02
|
||||
#define CARD_CLUBS_FIVE 0x03
|
||||
#define CARD_CLUBS_SIX 0x04
|
||||
#define CARD_CLUBS_SEVEN 0x05
|
||||
#define CARD_CLUBS_EIGHT 0x06
|
||||
#define CARD_CLUBS_NINE 0x07
|
||||
#define CARD_CLUBS_TEN 0x08
|
||||
#define CARD_CLUBS_JACK 0x09
|
||||
#define CARD_CLUBS_QUEEN 0x0A
|
||||
#define CARD_CLUBS_KING 0x0B
|
||||
#define CARD_CLUBS_ACE 0x0C
|
||||
|
||||
// Diamonds
|
||||
#define CARD_DIAMONDS_TWO 0x0D
|
||||
#define CARD_DIAMONDS_THREE 0x0E
|
||||
#define CARD_DIAMONDS_FOUR 0x0F
|
||||
#define CARD_DIAMONDS_FIVE 0x10
|
||||
#define CARD_DIAMONDS_SIX 0x11
|
||||
#define CARD_DIAMONDS_SEVEN 0x12
|
||||
#define CARD_DIAMONDS_EIGHT 0x13
|
||||
#define CARD_DIAMONDS_NINE 0x14
|
||||
#define CARD_DIAMONDS_TEN 0x15
|
||||
#define CARD_DIAMONDS_JACK 0x16
|
||||
#define CARD_DIAMONDS_QUEEN 0x17
|
||||
#define CARD_DIAMONDS_KING 0x18
|
||||
#define CARD_DIAMONDS_ACE 0x19
|
||||
|
||||
// Hearts
|
||||
#define CARD_HEARTS_TWO 0x1A
|
||||
#define CARD_HEARTS_THREE 0x1B
|
||||
#define CARD_HEARTS_FOUR 0x1C
|
||||
#define CARD_HEARTS_FIVE 0x1D
|
||||
#define CARD_HEARTS_SIX 0x1E
|
||||
#define CARD_HEARTS_SEVEN 0x1F
|
||||
#define CARD_HEARTS_EIGHT 0x20
|
||||
#define CARD_HEARTS_NINE 0x21
|
||||
#define CARD_HEARTS_TEN 0x22
|
||||
#define CARD_HEARTS_JACK 0x23
|
||||
#define CARD_HEARTS_QUEEN 0x24
|
||||
#define CARD_HEARTS_KING 0x25
|
||||
#define CARD_HEARTS_ACE 0x26
|
||||
|
||||
// Spades
|
||||
#define CARD_SPADES_TWO 0x27
|
||||
#define CARD_SPADES_THREE 0x28
|
||||
#define CARD_SPADES_FOUR 0x29
|
||||
#define CARD_SPADES_FIVE 0x2A
|
||||
#define CARD_SPADES_SIX 0x2B
|
||||
#define CARD_SPADES_SEVEN 0x2C
|
||||
#define CARD_SPADES_EIGHT 0x2D
|
||||
#define CARD_SPADES_NINE 0x2E
|
||||
#define CARD_SPADES_TEN 0x2F
|
||||
#define CARD_SPADES_JACK 0x30
|
||||
#define CARD_SPADES_QUEEN 0x31
|
||||
#define CARD_SPADES_KING 0x32
|
||||
#define CARD_SPADES_ACE 0x33
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////
|
||||
// Suits
|
||||
////////////////////////////////////////////////////////////////////////////////
|
||||
#define CARD_SUIT_CLUBS 0x00
|
||||
#define CARD_SUIT_DIAMONDS 0x01
|
||||
#define CARD_SUIT_HEARTS 0x02
|
||||
#define CARD_SUIT_SPADES 0x03
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////
|
||||
// Card numbers
|
||||
////////////////////////////////////////////////////////////////////////////////
|
||||
#define CARD_TWO 0x00
|
||||
#define CARD_THREE 0x01
|
||||
#define CARD_FOUR 0x02
|
||||
#define CARD_FIVE 0x03
|
||||
#define CARD_SIX 0x04
|
||||
#define CARD_SEVEN 0x05
|
||||
#define CARD_EIGHT 0x06
|
||||
#define CARD_NINE 0x07
|
||||
#define CARD_TEN 0x08
|
||||
#define CARD_JACK 0x09
|
||||
#define CARD_QUEEN 0x0A
|
||||
#define CARD_KING 0x0B
|
||||
#define CARD_ACE 0x0C
|
||||
|
||||
/** Count of cards in each suit */
|
||||
#define CARD_COUNT_PER_SUIT 13
|
||||
|
||||
/** Count of suits */
|
||||
#define CARD_SUIT_COUNT 4
|
||||
|
||||
/** Standard Card Deck Size */
|
||||
#define CARD_DECK_SIZE 52
|
||||
|
||||
inline uint8_t cardGetNumber(uint8_t card);
|
||||
inline uint8_t cardGetSuit(uint8_t card);
|
||||
inline uint8_t cardGet(uint8_t card, uint8_t suit);
|
||||
inline uint8_t cardContains(uint8_t *hand, uint8_t length, uint8_t card);
|
||||
inline uint8_t cardContainsNumber(uint8_t *hand,uint8_t length,uint8_t number);
|
||||
inline uint8_t cardCountPairs(
|
||||
uint8_t *in, uint8_t inCount, uint8_t number, uint8_t out[CARD_SUIT_COUNT]
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
#include "../libs.h"
|
||||
#include "../util.h"
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////
|
||||
// Cards
|
||||
////////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
// Aces
|
||||
#define CARD_CLUBS_TWO 0x00
|
||||
#define CARD_CLUBS_THREE 0x01
|
||||
#define CARD_CLUBS_FOUR 0x02
|
||||
#define CARD_CLUBS_FIVE 0x03
|
||||
#define CARD_CLUBS_SIX 0x04
|
||||
#define CARD_CLUBS_SEVEN 0x05
|
||||
#define CARD_CLUBS_EIGHT 0x06
|
||||
#define CARD_CLUBS_NINE 0x07
|
||||
#define CARD_CLUBS_TEN 0x08
|
||||
#define CARD_CLUBS_JACK 0x09
|
||||
#define CARD_CLUBS_QUEEN 0x0A
|
||||
#define CARD_CLUBS_KING 0x0B
|
||||
#define CARD_CLUBS_ACE 0x0C
|
||||
|
||||
// Diamonds
|
||||
#define CARD_DIAMONDS_TWO 0x0D
|
||||
#define CARD_DIAMONDS_THREE 0x0E
|
||||
#define CARD_DIAMONDS_FOUR 0x0F
|
||||
#define CARD_DIAMONDS_FIVE 0x10
|
||||
#define CARD_DIAMONDS_SIX 0x11
|
||||
#define CARD_DIAMONDS_SEVEN 0x12
|
||||
#define CARD_DIAMONDS_EIGHT 0x13
|
||||
#define CARD_DIAMONDS_NINE 0x14
|
||||
#define CARD_DIAMONDS_TEN 0x15
|
||||
#define CARD_DIAMONDS_JACK 0x16
|
||||
#define CARD_DIAMONDS_QUEEN 0x17
|
||||
#define CARD_DIAMONDS_KING 0x18
|
||||
#define CARD_DIAMONDS_ACE 0x19
|
||||
|
||||
// Hearts
|
||||
#define CARD_HEARTS_TWO 0x1A
|
||||
#define CARD_HEARTS_THREE 0x1B
|
||||
#define CARD_HEARTS_FOUR 0x1C
|
||||
#define CARD_HEARTS_FIVE 0x1D
|
||||
#define CARD_HEARTS_SIX 0x1E
|
||||
#define CARD_HEARTS_SEVEN 0x1F
|
||||
#define CARD_HEARTS_EIGHT 0x20
|
||||
#define CARD_HEARTS_NINE 0x21
|
||||
#define CARD_HEARTS_TEN 0x22
|
||||
#define CARD_HEARTS_JACK 0x23
|
||||
#define CARD_HEARTS_QUEEN 0x24
|
||||
#define CARD_HEARTS_KING 0x25
|
||||
#define CARD_HEARTS_ACE 0x26
|
||||
|
||||
// Spades
|
||||
#define CARD_SPADES_TWO 0x27
|
||||
#define CARD_SPADES_THREE 0x28
|
||||
#define CARD_SPADES_FOUR 0x29
|
||||
#define CARD_SPADES_FIVE 0x2A
|
||||
#define CARD_SPADES_SIX 0x2B
|
||||
#define CARD_SPADES_SEVEN 0x2C
|
||||
#define CARD_SPADES_EIGHT 0x2D
|
||||
#define CARD_SPADES_NINE 0x2E
|
||||
#define CARD_SPADES_TEN 0x2F
|
||||
#define CARD_SPADES_JACK 0x30
|
||||
#define CARD_SPADES_QUEEN 0x31
|
||||
#define CARD_SPADES_KING 0x32
|
||||
#define CARD_SPADES_ACE 0x33
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////
|
||||
// Suits
|
||||
////////////////////////////////////////////////////////////////////////////////
|
||||
#define CARD_SUIT_CLUBS 0x00
|
||||
#define CARD_SUIT_DIAMONDS 0x01
|
||||
#define CARD_SUIT_HEARTS 0x02
|
||||
#define CARD_SUIT_SPADES 0x03
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////
|
||||
// Card numbers
|
||||
////////////////////////////////////////////////////////////////////////////////
|
||||
#define CARD_TWO 0x00
|
||||
#define CARD_THREE 0x01
|
||||
#define CARD_FOUR 0x02
|
||||
#define CARD_FIVE 0x03
|
||||
#define CARD_SIX 0x04
|
||||
#define CARD_SEVEN 0x05
|
||||
#define CARD_EIGHT 0x06
|
||||
#define CARD_NINE 0x07
|
||||
#define CARD_TEN 0x08
|
||||
#define CARD_JACK 0x09
|
||||
#define CARD_QUEEN 0x0A
|
||||
#define CARD_KING 0x0B
|
||||
#define CARD_ACE 0x0C
|
||||
|
||||
/** Count of cards in each suit */
|
||||
#define CARD_COUNT_PER_SUIT 13
|
||||
|
||||
/** Count of suits */
|
||||
#define CARD_SUIT_COUNT 4
|
||||
|
||||
/** Standard Card Deck Size */
|
||||
#define CARD_DECK_SIZE 52
|
||||
|
||||
inline uint8_t cardGetNumber(uint8_t card);
|
||||
inline uint8_t cardGetSuit(uint8_t card);
|
||||
inline uint8_t cardGet(uint8_t card, uint8_t suit);
|
||||
inline uint8_t cardContains(uint8_t *hand, uint8_t length, uint8_t card);
|
||||
inline uint8_t cardContainsNumber(uint8_t *hand,uint8_t length,uint8_t number);
|
||||
inline uint8_t cardCountPairs(
|
||||
uint8_t *in, uint8_t inCount, uint8_t number, uint8_t out[CARD_SUIT_COUNT]
|
||||
);
|
@@ -1,28 +1,28 @@
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
#include "../libs.h"
|
||||
#include "card.h"
|
||||
|
||||
#define POKER_PLAYER_COUNT_MAX 5
|
||||
#define POKER_PLAYER_HAND_SIZE_MAX 2
|
||||
|
||||
#define POKER_PLAYER_STATE_FOLDED (1 << 0)
|
||||
#define POKER_PLAYER_STATE_OUT (1 << 1)
|
||||
#define POKER_PLAYER_STATE_HAS_BET_THIS_ROUND (1 << 2)
|
||||
// #define POKER_PLAYER_STATE_SHOWING 1 << 3
|
||||
|
||||
typedef struct {
|
||||
uint16_t chips;
|
||||
uint8_t hand[POKER_PLAYER_HAND_SIZE_MAX];
|
||||
uint8_t state;
|
||||
uint8_t timesRaised;
|
||||
} pokerplayer_t;
|
||||
|
||||
extern pokerplayer_t POKER_PLAYERS[];
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
#include "../libs.h"
|
||||
#include "card.h"
|
||||
|
||||
#define POKER_PLAYER_COUNT_MAX 5
|
||||
#define POKER_PLAYER_HAND_SIZE_MAX 2
|
||||
|
||||
#define POKER_PLAYER_STATE_FOLDED (1 << 0)
|
||||
#define POKER_PLAYER_STATE_OUT (1 << 1)
|
||||
#define POKER_PLAYER_STATE_HAS_BET_THIS_ROUND (1 << 2)
|
||||
// #define POKER_PLAYER_STATE_SHOWING 1 << 3
|
||||
|
||||
typedef struct {
|
||||
uint16_t chips;
|
||||
uint8_t hand[POKER_PLAYER_HAND_SIZE_MAX];
|
||||
uint8_t state;
|
||||
uint8_t timesRaised;
|
||||
} pokerplayer_t;
|
||||
|
||||
extern pokerplayer_t POKER_PLAYERS[];
|
||||
extern uint8_t POKER_PLAYER_COUNT;
|
1576
src/poker/poker.c
1576
src/poker/poker.c
File diff suppressed because it is too large
Load Diff
@@ -1,57 +1,57 @@
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
#include "../libs.h"
|
||||
#include "../util.h"
|
||||
#include "card.h"
|
||||
#include "player.h"
|
||||
#include "pot.h"
|
||||
#include "turn.h"
|
||||
#include "winner.h"
|
||||
|
||||
#define POKER_COMMUNITY_SIZE_MAX 5
|
||||
#define POKER_HUMAN_INDEX 0x00
|
||||
|
||||
#define POKER_COUNT_FLOP 0x03
|
||||
#define POKER_COUNT_TURN 0x01
|
||||
#define POKER_COUNT_RIVER 0x01
|
||||
|
||||
extern uint8_t POKER_DECK[];
|
||||
extern uint8_t POKER_DECK_SIZE;
|
||||
extern uint8_t POKER_COMMUNITY[];
|
||||
extern uint8_t POKER_COMMUNITY_SIZE;
|
||||
|
||||
extern uint8_t POKER_PLAYER_DEALER;
|
||||
extern uint8_t POKER_PLAYER_SMALL_BLIND;
|
||||
extern uint8_t POKER_PLAYER_BIG_BLIND;
|
||||
extern uint8_t POKER_PLAYER_BETTER;
|
||||
|
||||
extern uint16_t POKER_GAME_BLINDS_CURRENT;
|
||||
|
||||
void pokerInit();
|
||||
void pokerNewRound();
|
||||
inline void pokerBet(uint8_t player, uint16_t amount);
|
||||
inline uint8_t pokerGetCallBet(uint8_t player);
|
||||
void pokerAi(uint8_t player, pokerturn_t *turn);
|
||||
inline bool pokerCanPlayerCheck(uint8_t player);
|
||||
inline bool pokerDoesPlayerNeedToBet(uint8_t playerIndex);
|
||||
inline uint8_t pokerGetRemainingBetterCount();
|
||||
void pokerWinnerFillRemaining(pokerplayerwinning_t *winning);
|
||||
void pokerWinnerGetForPlayer(uint8_t playerIndex,pokerplayerwinning_t *winning);
|
||||
inline uint16_t pokerWinnerGetTypeConfidence(uint8_t type);
|
||||
uint8_t pokerWinnerCompare(
|
||||
pokerplayerwinning_t *left, pokerplayerwinning_t *right
|
||||
);
|
||||
void pokerWinnerDetermineForPot(
|
||||
pokerpot_t *pot,
|
||||
pokerplayerwinning_t *winners,
|
||||
uint8_t *winnerPlayers,
|
||||
uint8_t *winnerCount,
|
||||
uint8_t *participants,
|
||||
uint8_t *participantCount
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
#include "../libs.h"
|
||||
#include "../util.h"
|
||||
#include "card.h"
|
||||
#include "player.h"
|
||||
#include "pot.h"
|
||||
#include "turn.h"
|
||||
#include "winner.h"
|
||||
|
||||
#define POKER_COMMUNITY_SIZE_MAX 5
|
||||
#define POKER_HUMAN_INDEX 0x00
|
||||
|
||||
#define POKER_COUNT_FLOP 0x03
|
||||
#define POKER_COUNT_TURN 0x01
|
||||
#define POKER_COUNT_RIVER 0x01
|
||||
|
||||
extern uint8_t POKER_DECK[];
|
||||
extern uint8_t POKER_DECK_SIZE;
|
||||
extern uint8_t POKER_COMMUNITY[];
|
||||
extern uint8_t POKER_COMMUNITY_SIZE;
|
||||
|
||||
extern uint8_t POKER_PLAYER_DEALER;
|
||||
extern uint8_t POKER_PLAYER_SMALL_BLIND;
|
||||
extern uint8_t POKER_PLAYER_BIG_BLIND;
|
||||
extern uint8_t POKER_PLAYER_BETTER;
|
||||
|
||||
extern uint16_t POKER_GAME_BLINDS_CURRENT;
|
||||
|
||||
void pokerInit();
|
||||
void pokerNewRound();
|
||||
inline void pokerBet(uint8_t player, uint16_t amount);
|
||||
inline uint8_t pokerGetCallBet(uint8_t player);
|
||||
void pokerAi(uint8_t player, pokerturn_t *turn);
|
||||
inline bool pokerCanPlayerCheck(uint8_t player);
|
||||
inline bool pokerDoesPlayerNeedToBet(uint8_t playerIndex);
|
||||
inline uint8_t pokerGetRemainingBetterCount();
|
||||
void pokerWinnerFillRemaining(pokerplayerwinning_t *winning);
|
||||
void pokerWinnerGetForPlayer(uint8_t playerIndex,pokerplayerwinning_t *winning);
|
||||
inline uint16_t pokerWinnerGetTypeConfidence(uint8_t type);
|
||||
uint8_t pokerWinnerCompare(
|
||||
pokerplayerwinning_t *left, pokerplayerwinning_t *right
|
||||
);
|
||||
void pokerWinnerDetermineForPot(
|
||||
pokerpot_t *pot,
|
||||
pokerplayerwinning_t *winners,
|
||||
uint8_t *winnerPlayers,
|
||||
uint8_t *winnerCount,
|
||||
uint8_t *participants,
|
||||
uint8_t *participantCount
|
||||
);
|
@@ -1,27 +1,27 @@
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
#include "../libs.h"
|
||||
#include "player.h"
|
||||
|
||||
#define POKER_POT_COUNT_MAX POKER_PLAYER_COUNT_MAX
|
||||
|
||||
typedef struct {
|
||||
/** Current pot of chips */
|
||||
uint16_t chips;
|
||||
|
||||
/** Current call value for this pot */
|
||||
uint16_t call;
|
||||
|
||||
/** Players who are participating in the pots current bet (in the pot) */
|
||||
uint16_t players[POKER_PLAYER_COUNT_MAX];
|
||||
} pokerpot_t;
|
||||
|
||||
extern pokerpot_t POKER_POTS[];
|
||||
extern uint8_t POKER_POT_CURRENT;
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
#include "../libs.h"
|
||||
#include "player.h"
|
||||
|
||||
#define POKER_POT_COUNT_MAX POKER_PLAYER_COUNT_MAX
|
||||
|
||||
typedef struct {
|
||||
/** Current pot of chips */
|
||||
uint16_t chips;
|
||||
|
||||
/** Current call value for this pot */
|
||||
uint16_t call;
|
||||
|
||||
/** Players who are participating in the pots current bet (in the pot) */
|
||||
uint16_t players[POKER_PLAYER_COUNT_MAX];
|
||||
} pokerpot_t;
|
||||
|
||||
extern pokerpot_t POKER_POTS[];
|
||||
extern uint8_t POKER_POT_CURRENT;
|
||||
extern uint8_t POKER_POT_COUNT;
|
@@ -1,30 +1,30 @@
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
#include "../libs.h"
|
||||
|
||||
#define POKER_TURN_MAX_RAISES 0x02
|
||||
|
||||
/** Turn Types */
|
||||
#define POKER_TURN_TYPE_OUT 0x00
|
||||
#define POKER_TURN_TYPE_FOLD 0x01
|
||||
#define POKER_TURN_TYPE_BET 0x02
|
||||
#define POKER_TURN_TYPE_CALL 0x03
|
||||
#define POKER_TURN_TYPE_ALL_IN 0x04
|
||||
#define POKER_TURN_TYPE_CHECK 0x05
|
||||
|
||||
typedef struct {
|
||||
/** What type of action the turn is */
|
||||
uint8_t type;
|
||||
/** How many chips they did in their turn (if applicable) */
|
||||
uint16_t chips;
|
||||
/** How confident the AI is about their turn. 0 = none, 1000 = full */
|
||||
uint16_t confidence;
|
||||
/** Is this turn a bluff? */
|
||||
bool bluff;
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
#include "../libs.h"
|
||||
|
||||
#define POKER_TURN_MAX_RAISES 0x02
|
||||
|
||||
/** Turn Types */
|
||||
#define POKER_TURN_TYPE_OUT 0x00
|
||||
#define POKER_TURN_TYPE_FOLD 0x01
|
||||
#define POKER_TURN_TYPE_BET 0x02
|
||||
#define POKER_TURN_TYPE_CALL 0x03
|
||||
#define POKER_TURN_TYPE_ALL_IN 0x04
|
||||
#define POKER_TURN_TYPE_CHECK 0x05
|
||||
|
||||
typedef struct {
|
||||
/** What type of action the turn is */
|
||||
uint8_t type;
|
||||
/** How many chips they did in their turn (if applicable) */
|
||||
uint16_t chips;
|
||||
/** How confident the AI is about their turn. 0 = none, 1000 = full */
|
||||
uint16_t confidence;
|
||||
/** Is this turn a bluff? */
|
||||
bool bluff;
|
||||
} pokerturn_t;
|
@@ -1,64 +1,64 @@
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
#include "../libs.h"
|
||||
#include "card.h"
|
||||
|
||||
/** Maximum number of cards a winning state can hold. */
|
||||
#define POKER_WINNING_FULL_SIZE 0x07
|
||||
|
||||
/** How many cards in the winning set */
|
||||
#define POKER_WINNING_SET_SIZE 0x05
|
||||
|
||||
/** Winning Types */
|
||||
#define POKER_WINNING_TYPE_NULL 0x00
|
||||
#define POKER_WINNING_TYPE_ROYAL_FLUSH 0x01
|
||||
#define POKER_WINNING_TYPE_STRAIGHT_FLUSH 0x02
|
||||
#define POKER_WINNING_TYPE_FOUR_OF_A_KIND 0x03
|
||||
#define POKER_WINNING_TYPE_FULL_HOUSE 0x04
|
||||
#define POKER_WINNING_TYPE_FLUSH 0x05
|
||||
#define POKER_WINNING_TYPE_STRAIGHT 0x06
|
||||
#define POKER_WINNING_TYPE_THREE_OF_A_KIND 0x07
|
||||
#define POKER_WINNING_TYPE_TWO_PAIR 0x08
|
||||
#define POKER_WINNING_TYPE_PAIR 0x09
|
||||
#define POKER_WINNING_TYPE_HIGH_CARD 0x0A
|
||||
|
||||
/** Confidences of winning based on the current hand type */
|
||||
#define POKER_WINNING_CONFIDENCE_ROYAL_FLUSH 1000
|
||||
#define POKER_WINNING_CONFIDENCE_STRAIGHT_FLUSH 990
|
||||
#define POKER_WINNING_CONFIDENCE_FOUR_OF_A_KIND 900
|
||||
#define POKER_WINNING_CONFIDENCE_FULL_HOUSE 850
|
||||
#define POKER_WINNING_CONFIDENCE_FLUSH 800
|
||||
#define POKER_WINNING_CONFIDENCE_STRAIGHT 700
|
||||
#define POKER_WINNING_CONFIDENCE_THREE_OF_A_KIND 500
|
||||
#define POKER_WINNING_CONFIDENCE_TWO_PAIR 400
|
||||
#define POKER_WINNING_CONFIDENCE_PAIR 200
|
||||
#define POKER_WINNING_CONFIDENCE_HIGH_CARD 100
|
||||
|
||||
/** Holds information about a player's winning state */
|
||||
typedef struct {
|
||||
/** The full set of both the dealer and player's hand */
|
||||
uint8_t full[POKER_WINNING_FULL_SIZE];
|
||||
uint8_t fullSize;
|
||||
|
||||
/** Holds the winning set */
|
||||
uint8_t set[POKER_WINNING_SET_SIZE];
|
||||
uint8_t setSize;
|
||||
|
||||
/** Winning Type */
|
||||
uint8_t type;
|
||||
|
||||
/** If there was a kicker card it will be here, otherwise -1 for no kicker */
|
||||
uint8_t kicker;
|
||||
} pokerplayerwinning_t;
|
||||
|
||||
extern pokerplayerwinning_t POKER_WINNERS[POKER_PLAYER_COUNT_MAX];
|
||||
extern uint8_t POKER_WINNER_PLAYERS[POKER_PLAYER_COUNT_MAX];
|
||||
extern uint8_t POKER_WINNER_PARTICIPANTS[POKER_PLAYER_COUNT_MAX];
|
||||
extern uint8_t POKER_WINNER_COUNT;
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
#include "../libs.h"
|
||||
#include "card.h"
|
||||
|
||||
/** Maximum number of cards a winning state can hold. */
|
||||
#define POKER_WINNING_FULL_SIZE 0x07
|
||||
|
||||
/** How many cards in the winning set */
|
||||
#define POKER_WINNING_SET_SIZE 0x05
|
||||
|
||||
/** Winning Types */
|
||||
#define POKER_WINNING_TYPE_NULL 0x00
|
||||
#define POKER_WINNING_TYPE_ROYAL_FLUSH 0x01
|
||||
#define POKER_WINNING_TYPE_STRAIGHT_FLUSH 0x02
|
||||
#define POKER_WINNING_TYPE_FOUR_OF_A_KIND 0x03
|
||||
#define POKER_WINNING_TYPE_FULL_HOUSE 0x04
|
||||
#define POKER_WINNING_TYPE_FLUSH 0x05
|
||||
#define POKER_WINNING_TYPE_STRAIGHT 0x06
|
||||
#define POKER_WINNING_TYPE_THREE_OF_A_KIND 0x07
|
||||
#define POKER_WINNING_TYPE_TWO_PAIR 0x08
|
||||
#define POKER_WINNING_TYPE_PAIR 0x09
|
||||
#define POKER_WINNING_TYPE_HIGH_CARD 0x0A
|
||||
|
||||
/** Confidences of winning based on the current hand type */
|
||||
#define POKER_WINNING_CONFIDENCE_ROYAL_FLUSH 1000
|
||||
#define POKER_WINNING_CONFIDENCE_STRAIGHT_FLUSH 990
|
||||
#define POKER_WINNING_CONFIDENCE_FOUR_OF_A_KIND 900
|
||||
#define POKER_WINNING_CONFIDENCE_FULL_HOUSE 850
|
||||
#define POKER_WINNING_CONFIDENCE_FLUSH 800
|
||||
#define POKER_WINNING_CONFIDENCE_STRAIGHT 700
|
||||
#define POKER_WINNING_CONFIDENCE_THREE_OF_A_KIND 500
|
||||
#define POKER_WINNING_CONFIDENCE_TWO_PAIR 400
|
||||
#define POKER_WINNING_CONFIDENCE_PAIR 200
|
||||
#define POKER_WINNING_CONFIDENCE_HIGH_CARD 100
|
||||
|
||||
/** Holds information about a player's winning state */
|
||||
typedef struct {
|
||||
/** The full set of both the dealer and player's hand */
|
||||
uint8_t full[POKER_WINNING_FULL_SIZE];
|
||||
uint8_t fullSize;
|
||||
|
||||
/** Holds the winning set */
|
||||
uint8_t set[POKER_WINNING_SET_SIZE];
|
||||
uint8_t setSize;
|
||||
|
||||
/** Winning Type */
|
||||
uint8_t type;
|
||||
|
||||
/** If there was a kicker card it will be here, otherwise -1 for no kicker */
|
||||
uint8_t kicker;
|
||||
} pokerplayerwinning_t;
|
||||
|
||||
extern pokerplayerwinning_t POKER_WINNERS[POKER_PLAYER_COUNT_MAX];
|
||||
extern uint8_t POKER_WINNER_PLAYERS[POKER_PLAYER_COUNT_MAX];
|
||||
extern uint8_t POKER_WINNER_PARTICIPANTS[POKER_PLAYER_COUNT_MAX];
|
||||
extern uint8_t POKER_WINNER_COUNT;
|
||||
extern uint8_t POKER_WINNER_PARTICIPANT_COUNT;
|
44
src/sprites/spriteborder.c
Normal file
44
src/sprites/spriteborder.c
Normal file
@@ -0,0 +1,44 @@
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#include "spriteborder.h"
|
||||
|
||||
inline void spriteBorderBuffer() {
|
||||
spriteBuffer(SPRITE_BORDER_VRAM_START, BORDER_IMAGE_TILES, BORDER_IMAGE);
|
||||
}
|
||||
|
||||
inline void spriteBorderBufferEdges(
|
||||
uint8_t *buffer, uint8_t bufferWidth, uint8_t bufferHeight, uint8_t fill
|
||||
) {
|
||||
uint8_t i, j, max;
|
||||
max = bufferWidth * bufferHeight;
|
||||
|
||||
// Corners
|
||||
buffer[0] = SPRITE_BORDER_VRAM_START + SPRITE_BORDER_TOP_LEFT;
|
||||
buffer[bufferWidth-1] = SPRITE_BORDER_VRAM_START + SPRITE_BORDER_TOP_RIGHT;
|
||||
buffer[max-1] = SPRITE_BORDER_VRAM_START + SPRITE_BORDER_BOTTOM_RIGHT;
|
||||
buffer[max-bufferWidth] = SPRITE_BORDER_VRAM_START + SPRITE_BORDER_BOTTOM_LEFT;
|
||||
|
||||
// Edges
|
||||
for(i = 1; i < bufferWidth-1; i++) {
|
||||
buffer[i] = SPRITE_BORDER_VRAM_START + SPRITE_BORDER_BOTTOM_TOP;
|
||||
buffer[max - 1 - i] = SPRITE_BORDER_VRAM_START + SPRITE_BORDER_BOTTOM_TOP;
|
||||
}
|
||||
for(i = 1; i < bufferHeight - 1; i++) {
|
||||
buffer[bufferWidth * i] = SPRITE_BORDER_VRAM_START + SPRITE_BORDER_LEFT_RIGHT;
|
||||
buffer[bufferWidth * (i+1) - 1] = SPRITE_BORDER_VRAM_START + SPRITE_BORDER_LEFT_RIGHT;
|
||||
}
|
||||
|
||||
// Inner
|
||||
if(fill != 0xFF) {
|
||||
for(j = 1; j < bufferHeight-1; j++) {
|
||||
for(i = 1; i < bufferWidth-1; i++) {
|
||||
buffer[i + (j * bufferWidth)] = fill;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
39
src/sprites/spriteborder.h
Normal file
39
src/sprites/spriteborder.h
Normal file
@@ -0,0 +1,39 @@
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
#include "../libs.h"
|
||||
#include "sprites.h"
|
||||
#include "BORDER.h"
|
||||
#include "spritefont.h"
|
||||
|
||||
#define SPRITE_BORDER_VRAM_START SPRITE_FONT_VRAM_END
|
||||
#define SPRITE_BORDER_VRAM_END SPRITE_BORDER_VRAM_START + BORDER_IMAGE_TILES
|
||||
|
||||
#define SPRITE_BORDER_TOP_LEFT 0x00
|
||||
#define SPRITE_BORDER_TOP_RIGHT 0x01
|
||||
#define SPRITE_BORDER_LEFT_RIGHT 0x02
|
||||
#define SPRITE_BORDER_BOTTOM_LEFT 0x03
|
||||
#define SPRITE_BORDER_BOTTOM_RIGHT 0x04
|
||||
#define SPRITE_BORDER_BOTTOM_TOP 0x05
|
||||
|
||||
/**
|
||||
* Buffer the border sprite into VRAM.
|
||||
*/
|
||||
inline void spriteBorderBuffer();
|
||||
|
||||
/**
|
||||
* Buffer the edges of a border to a tile buffer.
|
||||
*
|
||||
* @param buffer Buffer to write the tiles in to.
|
||||
* @param bufferWidth Width of the buffer that you want to write.
|
||||
* @param bufferHeight Height of the buffer that you want to write.
|
||||
* @param fill NULL for no fill, otherwise TILE INDEX of fill within border.
|
||||
*/
|
||||
inline void spriteBorderBufferEdges(
|
||||
uint8_t *buffer, uint8_t bufferWidth, uint8_t bufferHeight, uint8_t fill
|
||||
);
|
38
src/sprites/spritecards.c
Normal file
38
src/sprites/spritecards.c
Normal file
@@ -0,0 +1,38 @@
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#include "spritecards.h"
|
||||
|
||||
const uint8_t SPRITE_HEARTS_ACE[SPRITE_CARD_TILE_COUNT] = {
|
||||
SPRITE_CARD_ACE_TOP, SPRITE_CARD_TOP, SPRITE_CARD_TOP, SPRITE_CARD_TOP_RIGHT,
|
||||
SPRITE_CARD_LEFT, SPRITE_CARD_BLANK, SPRITE_CARD_BLANK, SPRITE_CARD_RIGHT,
|
||||
SPRITE_CARD_LEFT, SPRITE_CARD_HEART_BIG_TOP_LEFT, SPRITE_CARD_HEART_BIG_TOP_RIGHT, SPRITE_CARD_RIGHT,
|
||||
SPRITE_CARD_LEFT, SPRITE_CARD_HEART_BIG_BOTTOM_LEFT, SPRITE_CARD_HEART_BIG_BOTTOM_RIGHT, SPRITE_CARD_RIGHT,
|
||||
SPRITE_CARD_LEFT, SPRITE_CARD_BLANK, SPRITE_CARD_BLANK, SPRITE_CARD_RIGHT,
|
||||
SPRITE_CARD_BOTTOM_LEFT, SPRITE_CARD_BOTTOM, SPRITE_CARD_BOTTOM, SPRITE_CARD_BOTTOM_RIGHT
|
||||
};
|
||||
|
||||
// const uint8_t *SPRITE_CARD_LIST[] = {
|
||||
// SPRITE_HEARTS_ACE
|
||||
// };
|
||||
|
||||
inline void spriteCardsBuffer() {
|
||||
spriteBuffer(SPRITE_CARD_VRAM_START, CARDS_TILES_IMAGE_TILES, CARDS_TILES_IMAGE);
|
||||
}
|
||||
|
||||
inline uint8_t * spriteCardsForCard(uint8_t card) {
|
||||
return SPRITE_HEARTS_ACE;
|
||||
}
|
||||
|
||||
inline void spriteCardBufferTiles(uint8_t *buffer, uint8_t card) {
|
||||
uint8_t i;
|
||||
uint8_t *spriteTiles = spriteCardsForCard(card);
|
||||
while(i != SPRITE_CARD_TILE_COUNT) {
|
||||
buffer[i] = spriteTiles[i];
|
||||
i++;
|
||||
}
|
||||
}
|
68
src/sprites/spritecards.h
Normal file
68
src/sprites/spritecards.h
Normal file
@@ -0,0 +1,68 @@
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
#include "../libs.h"
|
||||
#include "CARDS_TILES.h"
|
||||
#include "../poker/card.h"
|
||||
#include "spritetileset.h"
|
||||
#include "sprites.h"
|
||||
#include "spriteborder.h"
|
||||
|
||||
#define SPRITE_CARD_VRAM_START SPRITE_BORDER_VRAM_END
|
||||
|
||||
#define SPRITE_CARD_BLANK SPRITE_TILESET_WHITE
|
||||
|
||||
#define SPRITE_CARD_ACE_TOP SPRITE_CARD_VRAM_START + 0
|
||||
#define SPRITE_CARD_ACE_BOTTOM SPRITE_CARD_ACE_TOP/* ref */
|
||||
#define SPRITE_CARD_TWO_TOP SPRITE_CARD_VRAM_START + 1
|
||||
#define SPRITE_CARD_TWO_BOTTOM SPRITE_CARD_TWO_TOP/* ref */
|
||||
#define SPRITE_CARD_THREE_TOP SPRITE_CARD_VRAM_START + 2
|
||||
#define SPRITE_CARD_THREE_BOTTOM SPRITE_CARD_THREE_TOP/* ref */
|
||||
#define SPRITE_CARD_FOUR_TOP SPRITE_CARD_VRAM_START + 3
|
||||
#define SPRITE_CARD_FOUR_BOTTOM SPRITE_CARD_THREE_TOP/* ref */
|
||||
#define SPRITE_CARD_FIVE_TOP SPRITE_CARD_VRAM_START + 4
|
||||
#define SPRITE_CARD_FIVE_BOTTOM SPRITE_CARD_FIVE_TOP/* ref */
|
||||
#define SPRITE_CARD_SIX_TOP SPRITE_CARD_VRAM_START + 5
|
||||
#define SPRITE_CARD_SIX_BOTTOM SPRITE_CARD_SIX_TOP/* ref */
|
||||
#define SPRITE_CARD_SEVEN_TOP SPRITE_CARD_VRAM_START + 6
|
||||
#define SPRITE_CARD_SEVEN_BOTTOM SPRITE_CARD_SEVEN_TOP/* ref */
|
||||
#define SPRITE_CARD_EIGHT_TOP SPRITE_CARD_VRAM_START + 7
|
||||
#define SPRITE_CARD_EIGHT_BOTTOM SPRITE_CARD_EIGHT_TOP/* ref */
|
||||
#define SPRITE_CARD_NINE_TOP SPRITE_CARD_VRAM_START + 8
|
||||
#define SPRITE_CARD_NINE_BOTTOM SPRITE_CARD_NINE_TOP/* ref */
|
||||
#define SPRITE_CARD_TEN_TOP SPRITE_CARD_VRAM_START + 9
|
||||
#define SPRITE_CARD_TEN_BOTTOM/* ref */
|
||||
|
||||
#define SPRITE_CARD_TOP SPRITE_CARD_VRAM_START + 11
|
||||
#define SPRITE_CARD_TOP_RIGHT SPRITE_CARD_VRAM_START + 10
|
||||
#define SPRITE_CARD_LEFT SPRITE_CARD_TOP/* ref */
|
||||
#define SPRITE_CARD_RIGHT SPRITE_CARD_TOP/* ref */
|
||||
#define SPRITE_CARD_BOTTOM_LEFT SPRITE_CARD_TOP_RIGHT/* ref */
|
||||
#define SPRITE_CARD_BOTTOM_RIGHT SPRITE_CARD_TOP_RIGHT/* ref */
|
||||
#define SPRITE_CARD_BOTTOM SPRITE_CARD_TOP/* ref */
|
||||
|
||||
#define SPRITE_CARD_DIAMOND_BIG_TOP_LEFT SPRITE_CARD_VRAM_START + 12
|
||||
#define SPRITE_CARD_DIAMOND_BIG_TOP_RIGHT SPRITE_CARD_DIAMOND_BIG_TOP_LEFT/* ref */
|
||||
#define SPRITE_CARD_DIAMOND_BIG_BOTTOM_LEFT SPRITE_CARD_DIAMOND_BIG_TOP_LEFT/* ref */
|
||||
#define SPRITE_CARD_DIAMOND_BIG_BOTTOM_RIGHT SPRITE_CARD_DIAMOND_BIG_TOP_LEFT/* ref */
|
||||
#define SPRITE_CARD_HEART_BIG_TOP_LEFT SPRITE_CARD_VRAM_START + 13
|
||||
#define SPRITE_CARD_HEART_BIG_TOP_RIGHT SPRITE_CARD_HEART_BIG_TOP_LEFT/* ref */
|
||||
#define SPRITE_CARD_HEART_BIG_BOTTOM_LEFT SPRITE_CARD_DIAMOND_BIG_BOTTOM_LEFT
|
||||
#define SPRITE_CARD_HEART_BIG_BOTTOM_RIGHT SPRITE_CARD_DIAMOND_BIG_BOTTOM_RIGHT
|
||||
|
||||
#define SPRITE_CARD_WIDTH 4
|
||||
#define SPRITE_CARD_HEIGHT 6
|
||||
#define SPRITE_CARD_TILE_COUNT (SPRITE_CARD_WIDTH * SPRITE_CARD_HEIGHT)
|
||||
|
||||
extern const uint8_t SPRITE_HEARTS_ACE[];
|
||||
|
||||
inline void spriteCardsBuffer();
|
||||
|
||||
inline uint8_t * spriteCardsForCard(uint8_t card);
|
||||
|
||||
inline void spriteCardBufferTiles(uint8_t *buffer, uint8_t card);
|
16
src/sprites/spritefont.c
Normal file
16
src/sprites/spritefont.c
Normal file
@@ -0,0 +1,16 @@
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#include "spritefont.h"
|
||||
|
||||
inline void spriteFontBuffer() {
|
||||
spriteBuffer(SPRITE_FONT_VRAM_START, FONT_IMAGE_TILES, FONT_IMAGE);
|
||||
}
|
||||
|
||||
inline uint8_t spriteFontTileFromChar(char character) {
|
||||
return character - SPRITE_FONT_FIRST_CHARACTER + SPRITE_FONT_VRAM_START;
|
||||
}
|
30
src/sprites/spritefont.h
Normal file
30
src/sprites/spritefont.h
Normal file
@@ -0,0 +1,30 @@
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
#include "../libs.h"
|
||||
#include "FONT.h"
|
||||
#include "sprites.h"
|
||||
#include "spritetileset.h"
|
||||
|
||||
#define SPRITE_FONT_FIRST_CHARACTER 33
|
||||
|
||||
#define SPRITE_FONT_VRAM_START SPRITE_TILESET_VRAM_END
|
||||
#define SPRITE_FONT_VRAM_END SPRITE_FONT_VRAM_START + FONT_IMAGE_TILES
|
||||
|
||||
/**
|
||||
* Buffer the font tiles to VRAM.
|
||||
*/
|
||||
inline void spriteFontBuffer();
|
||||
|
||||
/**
|
||||
* Get the tile index for a given character (ASCII).
|
||||
*
|
||||
* @param character Character to get the tile index from.
|
||||
* @return The tile index for the given character.
|
||||
*/
|
||||
inline uint8_t spriteFontTileFromChar(char character);
|
12
src/sprites/sprites.c
Normal file
12
src/sprites/sprites.c
Normal file
@@ -0,0 +1,12 @@
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#include "sprites.h"
|
||||
|
||||
inline void spriteBuffer(uint8_t position, uint8_t length, uint8_t *tiles) {
|
||||
set_bkg_data(position, length, tiles);
|
||||
}
|
18
src/sprites/sprites.h
Normal file
18
src/sprites/sprites.h
Normal file
@@ -0,0 +1,18 @@
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
#include "../libs.h"
|
||||
|
||||
/**
|
||||
* Buffer tiles data into VRAM
|
||||
*
|
||||
* @param position Position in VRAM to buffer in to.
|
||||
* @param length Length of the data being buffered (count of tiles).
|
||||
* @param tiles Pointer to array of tiles to be bufffered.
|
||||
*/
|
||||
inline void spriteBuffer(uint8_t position, uint8_t length, uint8_t *tiles);
|
12
src/sprites/spritetileset.c
Normal file
12
src/sprites/spritetileset.c
Normal file
@@ -0,0 +1,12 @@
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#include "spritetileset.h"
|
||||
|
||||
void spriteTilesetBuffer() {
|
||||
spriteBuffer(SPRITE_TILESET_VRAM_START, TILESET_IMAGE_TILES, TILESET_IMAGE);
|
||||
}
|
50
src/sprites/spritetileset.h
Normal file
50
src/sprites/spritetileset.h
Normal file
@@ -0,0 +1,50 @@
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
#include "../libs.h"
|
||||
#include "TILESET.h"
|
||||
#include "sprites.h"
|
||||
|
||||
#define SPRITE_TILESET_VRAM_START 0x00
|
||||
#define SPRITE_TILESET_VRAM_END SPRITE_TILESET_VRAM_START + TILESET_IMAGE_TILES
|
||||
|
||||
#define SPRITE_TILESET_TILE_0 SPRITE_TILESET_VRAM_START + 0x00
|
||||
#define SPRITE_TILESET_TILE_1 SPRITE_TILESET_VRAM_START + 0x01
|
||||
#define SPRITE_TILESET_TILE_2 SPRITE_TILESET_VRAM_START + 0x02
|
||||
#define SPRITE_TILESET_TILE_3 SPRITE_TILESET_VRAM_START + 0x03
|
||||
|
||||
#define SPRITE_TILESET_WHITE SPRITE_TILESET_TILE_0
|
||||
#define SPRITE_TILESET_BLACK SPRITE_TILESET_TILE_3
|
||||
#define SPRITE_TILESET_LIGHT SPRITE_TILESET_TILE_1
|
||||
#define SPRITE_TILESET_DARK SPRITE_TILESET_TILE_2
|
||||
|
||||
|
||||
// Shades are mapped where each set of 4 colors is mapped to two bits that will
|
||||
// specify its darkness. Higher = Darker, Lower = Brighter
|
||||
// 11 11 11 11
|
||||
#define TILESET_SHADE_BLACK 0xFF
|
||||
// 11 11 11 10
|
||||
#define TILESET_SHADE_DARKER 0xFE
|
||||
// 11 11 10 01
|
||||
#define TILESET_SHADE_DARK 0xF9
|
||||
// 11 10 01 00
|
||||
#define TILESET_SHADE_NORMAL 0xE4
|
||||
// 10 01 00 00
|
||||
#define TILESET_SHADE_BRIGHT 0x90
|
||||
// 01 00 00 00
|
||||
#define TILESET_SHADE_BRIGHTER 0x40
|
||||
// 00 00 00 00
|
||||
#define TILESET_SHADE_WHITE 0x00
|
||||
|
||||
|
||||
/**
|
||||
* Buffer the TILESET tileset sprites onto VRAM.
|
||||
*
|
||||
* @param position Position in VRAM to buuffer on to.
|
||||
*/
|
||||
void spriteTilesetBuffer();
|
@@ -1,33 +1,33 @@
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#include "strings.h"
|
||||
|
||||
const char STR_ERROR[] = "An error\nhas occured";
|
||||
const char STR_HELLO[] = "Hello World, How are you today?\nGood thanks. Thank god!";
|
||||
|
||||
const char STR_POKER_GAME_START[] = "Poker game started";
|
||||
const char STR_POKER_GAME_TAKING_BLINDS[] = "Blinds taken.";
|
||||
const char STR_POKER_GAME_CARDS_DEALT[] = "Cards dealt.";
|
||||
|
||||
const char STR_POKER_GAME_CARDS_FLOPPED[] = "Cards flopped";
|
||||
const char STR_POKER_GAME_CARDS_TURNED[] = "Cards turned";
|
||||
const char STR_POKER_GAME_CARDS_RIVERED[] = "Cards river";
|
||||
|
||||
const char STR_DEBUG_WINNER_DECIDED[] = "DEBUG WINNER";
|
||||
const char STR_DEBUG_PLAYER[] = "DEBUG PLAYER";
|
||||
|
||||
const char STR_POKER_GAME_AI_FOLD[] = "AI Folding";
|
||||
const char STR_POKER_GAME_AI_RAISE[] = "AI Raise";
|
||||
const char STR_POKER_GAME_AI_RAISE_BLUFF[] = "AI Raise\nBut Bluffing";
|
||||
const char STR_POKER_GAME_AI_CALL[] = "AI Calling";
|
||||
const char STR_POKER_GAME_AI_CALL_BLUFF[] = "AI Calling\nBut Bluffing";
|
||||
const char STR_POKER_GAME_AI_ALL_IN[] = "AI All In";
|
||||
const char STR_POKER_GAME_AI_ALL_IN_BLUFF[] = "AI All In\nBut Bluffing";
|
||||
const char STR_POKER_GAME_AI_CHECK[] = "AI Checking";
|
||||
const char STR_POKER_GAME_AI_CHECK_BLUFF[] = "AI Checking\nBut Bluffing";
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#include "strings.h"
|
||||
|
||||
const char STR_ERROR[] = "An error\nhas occured";
|
||||
const char STR_HELLO[] = "Hello World, How are you today?\nGood thanks. Thank god!";
|
||||
|
||||
const char STR_POKER_GAME_START[] = "Poker game started";
|
||||
const char STR_POKER_GAME_TAKING_BLINDS[] = "Blinds taken.";
|
||||
const char STR_POKER_GAME_CARDS_DEALT[] = "Cards dealt.";
|
||||
|
||||
const char STR_POKER_GAME_CARDS_FLOPPED[] = "Cards flopped";
|
||||
const char STR_POKER_GAME_CARDS_TURNED[] = "Cards turned";
|
||||
const char STR_POKER_GAME_CARDS_RIVERED[] = "Cards river";
|
||||
|
||||
const char STR_DEBUG_WINNER_DECIDED[] = "DEBUG WINNER";
|
||||
const char STR_DEBUG_PLAYER[] = "DEBUG PLAYER";
|
||||
|
||||
const char STR_POKER_GAME_AI_FOLD[] = "AI Folding";
|
||||
const char STR_POKER_GAME_AI_RAISE[] = "AI Raise";
|
||||
const char STR_POKER_GAME_AI_RAISE_BLUFF[] = "AI Raise\nBut Bluffing";
|
||||
const char STR_POKER_GAME_AI_CALL[] = "AI Calling";
|
||||
const char STR_POKER_GAME_AI_CALL_BLUFF[] = "AI Calling\nBut Bluffing";
|
||||
const char STR_POKER_GAME_AI_ALL_IN[] = "AI All In";
|
||||
const char STR_POKER_GAME_AI_ALL_IN_BLUFF[] = "AI All In\nBut Bluffing";
|
||||
const char STR_POKER_GAME_AI_CHECK[] = "AI Checking";
|
||||
const char STR_POKER_GAME_AI_CHECK_BLUFF[] = "AI Checking\nBut Bluffing";
|
||||
const char STR_FOX[] = "The quick brown fox jumps over the lazy dog.";
|
@@ -1,34 +1,34 @@
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
#include "libs.h"
|
||||
|
||||
extern const char STR_ERROR[];
|
||||
extern const char STR_HELLO[];
|
||||
|
||||
extern const char STR_POKER_GAME_START[];
|
||||
extern const char STR_POKER_GAME_TAKING_BLINDS[];
|
||||
extern const char STR_POKER_GAME_CARDS_DEALT[];
|
||||
|
||||
extern const char STR_POKER_GAME_CARDS_FLOPPED[];
|
||||
extern const char STR_POKER_GAME_CARDS_TURNED[];
|
||||
extern const char STR_POKER_GAME_CARDS_RIVERED[];
|
||||
|
||||
extern const char STR_DEBUG_WINNER_DECIDED[];
|
||||
extern const char STR_DEBUG_PLAYER[];
|
||||
|
||||
extern const char STR_POKER_GAME_AI_FOLD[];
|
||||
extern const char STR_POKER_GAME_AI_RAISE[];
|
||||
extern const char STR_POKER_GAME_AI_RAISE_BLUFF[];
|
||||
extern const char STR_POKER_GAME_AI_CALL[];
|
||||
extern const char STR_POKER_GAME_AI_CALL_BLUFF[];
|
||||
extern const char STR_POKER_GAME_AI_ALL_IN[];
|
||||
extern const char STR_POKER_GAME_AI_ALL_IN_BLUFF[];
|
||||
extern const char STR_POKER_GAME_AI_CHECK[];
|
||||
extern const char STR_POKER_GAME_AI_CHECK_BLUFF[];
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
#include "libs.h"
|
||||
|
||||
extern const char STR_ERROR[];
|
||||
extern const char STR_HELLO[];
|
||||
|
||||
extern const char STR_POKER_GAME_START[];
|
||||
extern const char STR_POKER_GAME_TAKING_BLINDS[];
|
||||
extern const char STR_POKER_GAME_CARDS_DEALT[];
|
||||
|
||||
extern const char STR_POKER_GAME_CARDS_FLOPPED[];
|
||||
extern const char STR_POKER_GAME_CARDS_TURNED[];
|
||||
extern const char STR_POKER_GAME_CARDS_RIVERED[];
|
||||
|
||||
extern const char STR_DEBUG_WINNER_DECIDED[];
|
||||
extern const char STR_DEBUG_PLAYER[];
|
||||
|
||||
extern const char STR_POKER_GAME_AI_FOLD[];
|
||||
extern const char STR_POKER_GAME_AI_RAISE[];
|
||||
extern const char STR_POKER_GAME_AI_RAISE_BLUFF[];
|
||||
extern const char STR_POKER_GAME_AI_CALL[];
|
||||
extern const char STR_POKER_GAME_AI_CALL_BLUFF[];
|
||||
extern const char STR_POKER_GAME_AI_ALL_IN[];
|
||||
extern const char STR_POKER_GAME_AI_ALL_IN_BLUFF[];
|
||||
extern const char STR_POKER_GAME_AI_CHECK[];
|
||||
extern const char STR_POKER_GAME_AI_CHECK_BLUFF[];
|
||||
extern const char STR_FOX[];
|
42
src/time.c
42
src/time.c
@@ -1,22 +1,22 @@
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#include "time.h"
|
||||
|
||||
uint16_t TIME_CURRENT;
|
||||
uint16_t TIME_FUTURE;
|
||||
uint8_t TIME_FUTURE_TYPE;
|
||||
|
||||
inline void timeInit() {
|
||||
TIME_CURRENT = 0;
|
||||
TIME_FUTURE = 0;
|
||||
TIME_FUTURE_TYPE = TIME_FUTURE_TYPE_NULL;
|
||||
}
|
||||
|
||||
inline void timeUpdate() {
|
||||
TIME_CURRENT++;
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#include "time.h"
|
||||
|
||||
uint16_t TIME_CURRENT;
|
||||
uint16_t TIME_FUTURE;
|
||||
uint8_t TIME_FUTURE_TYPE;
|
||||
|
||||
inline void timeInit() {
|
||||
TIME_CURRENT = 0;
|
||||
TIME_FUTURE = 0;
|
||||
TIME_FUTURE_TYPE = TIME_FUTURE_TYPE_NULL;
|
||||
}
|
||||
|
||||
inline void timeUpdate() {
|
||||
TIME_CURRENT++;
|
||||
}
|
48
src/time.h
48
src/time.h
@@ -1,25 +1,25 @@
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
#include "libs.h"
|
||||
|
||||
#define TIME_PER_SECOND 60
|
||||
|
||||
#define TIME_FUTURE_TYPE_NULL 0x00
|
||||
#define TIME_FUTURE_TYPE_PAUSE 0x01
|
||||
#define TIME_FUTURE_TYPE_FADE_TO_BLACK 0x02
|
||||
#define TIME_FUTURE_TYPE_FADE_FROM_BLACK 0x03
|
||||
#define TIME_FUTURE_TYPE_FADE_TO_WHITE 0x04
|
||||
#define TIME_FUTURE_TYPE_FADE_FROM_WHITE 0x05
|
||||
|
||||
extern uint16_t TIME_CURRENT;
|
||||
extern uint16_t TIME_FUTURE;
|
||||
extern uint8_t TIME_FUTURE_TYPE;
|
||||
|
||||
inline void timeInit();
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
#include "libs.h"
|
||||
|
||||
#define TIME_PER_SECOND 60
|
||||
|
||||
#define TIME_FUTURE_TYPE_NULL 0x00
|
||||
#define TIME_FUTURE_TYPE_PAUSE 0x01
|
||||
#define TIME_FUTURE_TYPE_FADE_TO_BLACK 0x02
|
||||
#define TIME_FUTURE_TYPE_FADE_FROM_BLACK 0x03
|
||||
#define TIME_FUTURE_TYPE_FADE_TO_WHITE 0x04
|
||||
#define TIME_FUTURE_TYPE_FADE_FROM_WHITE 0x05
|
||||
|
||||
extern uint16_t TIME_CURRENT;
|
||||
extern uint16_t TIME_FUTURE;
|
||||
extern uint8_t TIME_FUTURE_TYPE;
|
||||
|
||||
inline void timeInit();
|
||||
inline void timeUpdate();
|
24
src/util.h
24
src/util.h
@@ -1,13 +1,13 @@
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
#include "libs.h"
|
||||
|
||||
#define MATH_MIN(a, b) a > b ? b : a
|
||||
#define MATH_MAX(a, b) a < b ? b : a
|
||||
/**
|
||||
* Copyright (c) 2022 Dominic Masters
|
||||
*
|
||||
* This software is released under the MIT License.
|
||||
* https://opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
#include "libs.h"
|
||||
|
||||
#define MATH_MIN(a, b) a > b ? b : a
|
||||
#define MATH_MAX(a, b) a < b ? b : a
|
||||
#define MATH_ABS(n) (n < 0 ? -n : n)
|
Reference in New Issue
Block a user