Nuked PokerGame file

This commit is contained in:
2021-05-17 06:32:10 -07:00
parent 9af4115bad
commit c854ebbb5d
18 changed files with 82 additions and 163 deletions

View File

@ -8,6 +8,7 @@
#include "game.h" #include "game.h"
game_t GAME_STATE; game_t GAME_STATE;
pokergame_t POKER_STATE;
bool gameInit() { bool gameInit() {
// Init the game // Init the game
@ -26,8 +27,26 @@ bool gameInit() {
"shaders/textured.vert", "shaders/textured.frag" "shaders/textured.vert", "shaders/textured.frag"
); );
// Send to Texas Game // Font
holdemGameInit(); POKER_STATE.fontTexture = assetTextureLoad("font.png");
POKER_STATE.fontTileset = tilesetCreate(20, 20,
POKER_STATE.fontTexture->width,
POKER_STATE.fontTexture->height,
1, 1, 1, 1
);
POKER_STATE.fontBatch = spriteBatchCreate(1024);
// Prepare the renderer.
holdemRenderFrameInit();
holdemRenderWorldInit();
holdemRenderPlayerInit();
holdemRenderCardInit();
// Prepare the action manager
pokerActionInit();
// Start the first action
pokerActionAdd(actionStart());
// Init the input manger. // Init the input manger.
return true; return true;
@ -39,13 +58,24 @@ bool gameUpdate(float platformDelta) {
inputUpdate(); inputUpdate();
shaderUse(GAME_STATE.shaderWorld);// TODO: remove shaderUse(GAME_STATE.shaderWorld);// TODO: remove
holdemGameUpdate();
// Update the frame buffers and action queue
holdemRenderFrameUpdate();
pokerActionUpdate();
// Render things on each frame, then render those frames.
holdemRenderFrameUseLeft();
holdemRenderWorld();
holdemRenderFrameUseRight();
holdemRenderWorld();
holdemRenderFrameBack();
if(inputIsPressed(INPUT_NULL)) return false; if(inputIsPressed(INPUT_NULL)) return false;
return true; return true;
} }
void gameDispose() { void gameDispose() {
pokerActionDispose();
shaderDispose(GAME_STATE.shaderWorld); shaderDispose(GAME_STATE.shaderWorld);
inputDispose(); inputDispose();
renderDispose(); renderDispose();

View File

@ -9,10 +9,17 @@
#include "../display/render.h" #include "../display/render.h"
#include "../display/camera.h" #include "../display/camera.h"
#include "../display/shader.h" #include "../display/shader.h"
#include "../display/gui/font.h"
#include "../file/asset.h" #include "../file/asset.h"
#include "../input/input.h" #include "../input/input.h"
#include "../poker/holdemgame.h"
#include "../debug/log.h" #include "../debug/log.h"
#include "../poker/action/action.h"
#include "../poker/action/start.h"
#include "../poker/render/player.h"
#include "../poker/render/card.h"
#include "../poker/render/frame.h"
#include "../poker/render/look.h"
#include "../poker/render/world.h"
/** /**
* Initialize the game context. * Initialize the game context.

View File

@ -7,7 +7,7 @@
#include "action.h" #include "action.h"
void holdemActionInit() { void pokerActionInit() {
// Free up all actions // Free up all actions
memset(POKER_STATE.actionQueue, (int32_t)NULL, memset(POKER_STATE.actionQueue, (int32_t)NULL,
sizeof(pokeraction_t) * POKER_ACTION_QUEUE_SIZE sizeof(pokeraction_t) * POKER_ACTION_QUEUE_SIZE
@ -19,7 +19,7 @@ void holdemActionInit() {
); );
} }
int32_t holdemActionAdd(pokeraction_t action) { int32_t pokerActionAdd(pokeraction_t action) {
int32_t i = -1; int32_t i = -1;
int32_t j = -1; int32_t j = -1;
@ -35,7 +35,7 @@ int32_t holdemActionAdd(pokeraction_t action) {
return j; return j;
} }
void holdemActionRemove(int32_t index) { void pokerActionRemove(int32_t index) {
if(POKER_STATE.actionQueue[index].dispose != NULL) { if(POKER_STATE.actionQueue[index].dispose != NULL) {
POKER_STATE.actionQueue[index].dispose( POKER_STATE.actionQueue[index].dispose(
index, POKER_STATE.actionData + index index, POKER_STATE.actionData + index
@ -51,7 +51,7 @@ void holdemActionRemove(int32_t index) {
); );
} }
void holdemActionUpdate() { void pokerActionUpdate() {
int32_t i; int32_t i;
void **data; void **data;
pokeraction_t *action; pokeraction_t *action;
@ -71,7 +71,7 @@ void holdemActionUpdate() {
} }
} }
void holdemActionDispose() { void pokerActionDispose() {
int32_t i; int32_t i;
for(i = 0; i < POKER_ACTION_QUEUE_SIZE; i++) { for(i = 0; i < POKER_ACTION_QUEUE_SIZE; i++) {
if(POKER_STATE.actionQueue[i].dispose == NULL) continue; if(POKER_STATE.actionQueue[i].dispose == NULL) continue;

View File

@ -11,7 +11,7 @@
/** /**
* Initializes the action manager. * Initializes the action manager.
*/ */
void holdemActionInit(); void pokerActionInit();
/** /**
* Adds an action to the action queue. * Adds an action to the action queue.
@ -19,22 +19,22 @@ void holdemActionInit();
* @param action Action to add to the queue. * @param action Action to add to the queue.
* @returns The index of the action within the queue, or -1 if failure occured. * @returns The index of the action within the queue, or -1 if failure occured.
*/ */
int32_t holdemActionAdd(pokeraction_t action); int32_t pokerActionAdd(pokeraction_t action);
/** /**
* Removes an action from the action queue. * Removes an action from the action queue.
* *
* @param index Action to remove (by index in the queue). * @param index Action to remove (by index in the queue).
*/ */
void holdemActionRemove(int32_t index); void pokerActionRemove(int32_t index);
/** /**
* Updates the action manager, which (in turn) updates all actions that are * Updates the action manager, which (in turn) updates all actions that are
* currently running. * currently running.
*/ */
void holdemActionUpdate(); void pokerActionUpdate();
/** /**
* Cleans up the action manager and all actions. * Cleans up the action manager and all actions.
*/ */
void holdemActionDispose(); void pokerActionDispose();

View File

@ -25,7 +25,7 @@ void actionAiInit(int32_t index, void *data) {
worth the risk. I may need history of the game to make informed decision worth the risk. I may need history of the game to make informed decision
*/ */
holdemActionRemove(index); pokerActionRemove(index);
} }
void actionAiUpdate(int32_t index, void *data) { void actionAiUpdate(int32_t index, void *data) {
@ -34,6 +34,6 @@ void actionAiUpdate(int32_t index, void *data) {
void actionAiDispose(int32_t index, void *data) { void actionAiDispose(int32_t index, void *data) {
// Do we need to do a flop? // Do we need to do a flop?
if(POKER_STATE.cardsFacing < HOLDEM_DEALER_HAND) { if(POKER_STATE.cardsFacing < HOLDEM_DEALER_HAND) {
holdemActionAdd(actionFlop()); pokerActionAdd(actionFlop());
} }
} }

View File

@ -33,7 +33,7 @@ void actionDealInit(int32_t index, void *data) {
} }
} }
holdemActionRemove(index); pokerActionRemove(index);
} }
void actionDealUpdate(int32_t i, void *data) { void actionDealUpdate(int32_t i, void *data) {
@ -41,5 +41,5 @@ void actionDealUpdate(int32_t i, void *data) {
} }
void actionDealDispose(int32_t i, void *data) { void actionDealDispose(int32_t i, void *data) {
int32_t newI = holdemActionAdd(actionAi()); int32_t newI = pokerActionAdd(actionAi());
} }

View File

@ -39,7 +39,7 @@ void actionFlopInit(int32_t index, void *data) {
} }
// Next action // Next action
holdemActionRemove(index); pokerActionRemove(index);
} }
void actionFlopUpdate(int32_t index, void *data) { void actionFlopUpdate(int32_t index, void *data) {
@ -47,5 +47,5 @@ void actionFlopUpdate(int32_t index, void *data) {
} }
void actionFlopDispose(int32_t index, void *data) { void actionFlopDispose(int32_t index, void *data) {
holdemActionAdd(actionAi()); pokerActionAdd(actionAi());
} }

View File

@ -45,7 +45,7 @@ void actionRoundInit(int32_t index, void *data) {
} }
// Next action // Next action
holdemActionRemove(index); pokerActionRemove(index);
} }
void actionRoundUpdate(int32_t index, void *data) { void actionRoundUpdate(int32_t index, void *data) {
@ -53,11 +53,11 @@ void actionRoundUpdate(int32_t index, void *data) {
void actionRoundAfterShuffle() { void actionRoundAfterShuffle() {
logText("Shuffle Done"); logText("Shuffle Done");
int32_t i = holdemActionAdd(actionDeal()); int32_t i = pokerActionAdd(actionDeal());
} }
void actionRoundDispose(int32_t index, void *data) { void actionRoundDispose(int32_t index, void *data) {
int32_t newI = holdemActionAdd(actionShuffle()); int32_t newI = pokerActionAdd(actionShuffle());
shuffledata_t *newData=(shuffledata_t *)(POKER_STATE.actionData + newI); shuffledata_t *newData=(shuffledata_t *)(POKER_STATE.actionData + newI);
newData->done = &actionRoundAfterShuffle; newData->done = &actionRoundAfterShuffle;
} }

View File

@ -18,7 +18,7 @@ pokeraction_t actionShuffle() {
void actionShuffleInit(int32_t index, void *data) { void actionShuffleInit(int32_t index, void *data) {
logText("Shuffle Deck"); logText("Shuffle Deck");
cardShuffle(POKER_STATE.deck, POKER_STATE.deckSize); cardShuffle(POKER_STATE.deck, POKER_STATE.deckSize);
holdemActionRemove(index); pokerActionRemove(index);
} }
void actionShuffleUpdate(int32_t index, void *data) { void actionShuffleUpdate(int32_t index, void *data) {

View File

@ -34,7 +34,7 @@ void actionStartInit(int32_t index, void *data) {
player->chips = 0; player->chips = 0;
} }
holdemActionRemove(index); pokerActionRemove(index);
} }
void actionStartUpdate(int32_t index, void *data) { void actionStartUpdate(int32_t index, void *data) {
@ -42,5 +42,5 @@ void actionStartUpdate(int32_t index, void *data) {
void actionStartDispose(int32_t index, void *data) { void actionStartDispose(int32_t index, void *data) {
// Begin the first round // Begin the first round
holdemActionAdd(actionRound()); pokerActionAdd(actionRound());
} }

View File

@ -1,53 +0,0 @@
/**
* Copyright (c) 2021 Dominic Masters
*
* This software is released under the MIT License.
* https://opensource.org/licenses/MIT
*/
#include "holdemgame.h"
pokergame_t POKER_STATE;
void holdemGameInit() {
// Font
POKER_STATE.fontTexture = assetTextureLoad("font.png");
POKER_STATE.fontTileset = tilesetCreate(20, 20,
POKER_STATE.fontTexture->width,
POKER_STATE.fontTexture->height,
1, 1, 1, 1
);
POKER_STATE.fontBatch = spriteBatchCreate(1024);
// Prepare the renderer.
holdemRenderFrameInit();
holdemRenderSceneInit();
holdemRenderPlayerInit();
holdemRenderCardInit();
// Prepare the action manager
holdemActionInit();
// Start the first action
holdemActionAdd(actionStart());
}
void holdemGameUpdate() {
// Update the frame buffers and action queue
holdemRenderFrameUpdate();
holdemActionUpdate();
// Render things on the left frame buffer
holdemRenderFrameUseLeft();
holdemRenderWorld();
// Render things on the right frame buffer
holdemRenderFrameUseRight();
holdemRenderWorld();
// Finally, render the frame buffers to the back buffer.
holdemRenderFrameBack();
}
void holdemGameDispose() {
holdemActionDispose();
}

View File

@ -1,35 +0,0 @@
/**
* Copyright (c) 2021 Dominic Masters
*
* This software is released under the MIT License.
* https://opensource.org/licenses/MIT
*/
#pragma once
#include <dawn/dawn.h>
#include "../file/asset.h"
#include "../display/gui/font.h"
#include "card.h"
#include "action/action.h"
#include "action/start.h"
#include "render/player.h"
#include "render/card.h"
#include "render/frame.h"
#include "render/look.h"
#include "render/scene.h"
#include "render/world.h"
/**
* Initializes the Texas Hold'em game
*/
void holdemGameInit();
/**
* Update the Texas Hold'em game.
*/
void holdemGameUpdate();
/**
* Dispose the Texas Hold'em game.
*/
void holdemGameDispose();

View File

@ -1,24 +0,0 @@
/**
* Copyright (c) 2021 Dominic Masters
*
* This software is released under the MIT License.
* https://opensource.org/licenses/MIT
*/
#include "scene.h"
void holdemRenderSceneInit() {
POKER_STATE.tablePrimitive = pokerTableCreate();
POKER_STATE.tableTexture = assetTextureLoad("pokertable.png");
}
void holdemRenderScene() {
// Poker Table
shaderUsePositionAndScale(GAME_STATE.shaderWorld,
0, -0.01, 0,
0, 0, 0,
3.4, 3.4, 3.4
);
shaderUseTexture(GAME_STATE.shaderWorld, POKER_STATE.tableTexture);
primitiveDraw(POKER_STATE.tablePrimitive, 0, -1);
}

View File

@ -1,23 +0,0 @@
/**
* Copyright (c) 2021 Dominic Masters
*
* This software is released under the MIT License.
* https://opensource.org/licenses/MIT
*/
#pragma once
#include <dawn/dawn.h>
#include "../../display/shader.h"
#include "../../display/primitive.h"
#include "../../file/asset.h"
#include "../model/pokertable.h"
/**
* Initializes the scene renderer.
*/
void holdemRenderSceneInit();
/**
* Renders the scene for the holdem game (including table, chairs, etc.)
*/
void holdemRenderScene();

View File

@ -7,12 +7,24 @@
#include "world.h" #include "world.h"
void holdemRenderWorldInit() {
POKER_STATE.tablePrimitive = pokerTableCreate();
POKER_STATE.tableTexture = assetTextureLoad("pokertable.png");
}
void holdemRenderWorld() { void holdemRenderWorld() {
uint8_t i, j; uint8_t i, j;
pokerplayer_t *player; pokerplayer_t *player;
uint8_t seat; uint8_t seat;
holdemRenderScene(); // Poker Table
shaderUsePositionAndScale(GAME_STATE.shaderWorld,
0, -0.01, 0,
0, 0, 0,
3.4, 3.4, 3.4
);
shaderUseTexture(GAME_STATE.shaderWorld, POKER_STATE.tableTexture);
primitiveDraw(POKER_STATE.tablePrimitive, 0, -1);
// Render the dealer and her hand // Render the dealer and her hand
holdemRenderPlayer(HOLDEM_GAME_SEAT_DEALER); holdemRenderPlayer(HOLDEM_GAME_SEAT_DEALER);

View File

@ -8,8 +8,13 @@
#pragma once #pragma once
#include <dawn/dawn.h> #include <dawn/dawn.h>
#include "player.h" #include "player.h"
#include "scene.h"
#include "card.h" #include "card.h"
#include "../../assets/models/pokertable.h"
/**
* Initializes the world renderer.
*/
void holdemRenderWorldInit();
/** /**
* Renders the world. * Renders the world.