From f76ef65b7b29f4130b35969fa8c01a0bd2e9512e Mon Sep 17 00:00:00 2001 From: Dominic Masters Date: Mon, 10 May 2021 21:42:09 -0700 Subject: [PATCH] working on some render tools --- include/dawn/cards/poker/holdem.h | 20 ++++ src/card/poker/action/action.c | 50 ++++++++ src/card/poker/action/action.h | 32 +++++ src/card/poker/action/start.c | 35 ++++++ src/card/poker/action/start.h | 15 +++ src/card/poker/holdemgame.c | 145 ++-------------------- src/card/poker/holdemgame.h | 25 ++-- src/card/poker/render/holdemrender.c | 172 +++++++++++++++++++++++++-- src/card/poker/render/holdemrender.h | 20 ++++ 9 files changed, 358 insertions(+), 156 deletions(-) create mode 100644 src/card/poker/action/action.c create mode 100644 src/card/poker/action/action.h create mode 100644 src/card/poker/action/start.c create mode 100644 src/card/poker/action/start.h diff --git a/include/dawn/cards/poker/holdem.h b/include/dawn/cards/poker/holdem.h index 2f02f2c2..5a2a11e9 100644 --- a/include/dawn/cards/poker/holdem.h +++ b/include/dawn/cards/poker/holdem.h @@ -34,6 +34,11 @@ #define HOLDEM_GAME_CARD_HEIGHT 0.07 #define HOLDEM_GAME_CARD_DEPTH 0.001 +/** How many actions the queue can hold */ +#define HOLDEM_GAME_ACTION_QUEUE_SIZE 12 + +/** How much data (in length of sizeof size_t) each action has available */ +#define HOLDEM_GAME_ACTION_DATA_SIZE 256 /** Texas Hold'em Player State */ typedef struct { @@ -74,6 +79,16 @@ typedef struct { holdemplayer_t players[HOLDEM_PLAYER_COUNT]; } holdemmatch_t; +/** Callback for actions to use */ +typedef void (*holdemActionCallback)(int32_t index, void *data); + +/** Texas Hold'em Game action that can be queued and executed */ +typedef struct { + holdemActionCallback init; + holdemActionCallback update; + holdemActionCallback dispose; +} holdemaction_t; + typedef struct { holdemmatch_t match; @@ -81,6 +96,11 @@ typedef struct { tileset_t *kagamiTileset; primitive_t *kagamiQuad; + /** Action and Allocated Data Space */ + holdemaction_t actionQueue[HOLDEM_GAME_ACTION_QUEUE_SIZE]; + void *actionData[HOLDEM_GAME_ACTION_DATA_SIZE*HOLDEM_GAME_ACTION_QUEUE_SIZE]; + + /** Poker Table */ primitive_t *tablePrimitive; texture_t *tableTexture; diff --git a/src/card/poker/action/action.c b/src/card/poker/action/action.c new file mode 100644 index 00000000..9683bd52 --- /dev/null +++ b/src/card/poker/action/action.c @@ -0,0 +1,50 @@ +/** + * Copyright (c) 2021 Dominic Masters + * + * This software is released under the MIT License. + * https://opensource.org/licenses/MIT + */ + +#include "action.h" + +void holdemActionInit() { + // Free up all actions + memset(HOLDEM_GAME_STATE.actionQueue, (int32_t)NULL, + sizeof(holdemaction_t) * HOLDEM_GAME_ACTION_QUEUE_SIZE + ); + + // Free up all data + memset(HOLDEM_GAME_STATE.actionData, (int32_t)NULL, sizeof(void *) * + HOLDEM_GAME_ACTION_DATA_SIZE * HOLDEM_GAME_ACTION_QUEUE_SIZE + ); +} + +void holdemActionAdd(holdemaction_t action) { + int32_t i = -1; + int32_t j = -1; + + for(i = 0; i < HOLDEM_GAME_ACTION_QUEUE_SIZE; i++) { + if(HOLDEM_GAME_STATE.actionQueue[i].init != NULL) continue; + j = i; + break; + } + + HOLDEM_GAME_STATE.actionQueue[j] = action; + action.init(j, HOLDEM_GAME_STATE.actionData + j); +} + +void holdemActionUpdate() { + int32_t i; + for(i = 0; i < HOLDEM_GAME_ACTION_QUEUE_SIZE; i++) { + if(HOLDEM_GAME_STATE.actionQueue[i].update == NULL) continue; + HOLDEM_GAME_STATE.actionQueue[i].update(i, HOLDEM_GAME_STATE.actionData+i); + } +} + +void holdemActionDispose() { + int32_t i; + for(i = 0; i < HOLDEM_GAME_ACTION_QUEUE_SIZE; i++) { + if(HOLDEM_GAME_STATE.actionQueue[i].dispose == NULL) continue; + HOLDEM_GAME_STATE.actionQueue[i].dispose(i, HOLDEM_GAME_STATE.actionData+i); + } +} \ No newline at end of file diff --git a/src/card/poker/action/action.h b/src/card/poker/action/action.h new file mode 100644 index 00000000..353df42e --- /dev/null +++ b/src/card/poker/action/action.h @@ -0,0 +1,32 @@ +/** + * Copyright (c) 2021 Dominic Masters + * + * This software is released under the MIT License. + * https://opensource.org/licenses/MIT + */ + +#pragma once +#include + +/** + * Initializes the action manager. + */ +void holdemActionInit(); + +/** + * Adds an action to the action queue. + * + * @param action Action to add to the queue. + */ +void holdemActionAdd(holdemaction_t action); + +/** + * Updates the action manager, which (in turn) updates all actions that are + * currently running. + */ +void holdemActionUpdate(); + +/** + * Cleans up the action manager and all actions. + */ +void holdemActionDispose(); \ No newline at end of file diff --git a/src/card/poker/action/start.c b/src/card/poker/action/start.c new file mode 100644 index 00000000..76aa27c4 --- /dev/null +++ b/src/card/poker/action/start.c @@ -0,0 +1,35 @@ +/** + * Copyright (c) 2021 Dominic Masters + * + * This software is released under the MIT License. + * https://opensource.org/licenses/MIT + */ + +#include "start.h" + +holdemaction_t actionStart() { + holdemaction_t action = { + .init = &actionStartInit, + .update = &actionStartUpdate, + .dispose = &actionStartDispose + }; + + return action; +} + +void actionStartInit(int32_t index, void *data) { + // holdemactionstart_t *convData = data; + + // Prepare the match + holdemMatchInit(&HOLDEM_GAME_STATE.match); + holdemRoundInit(&HOLDEM_GAME_STATE.match); + cardShuffle(HOLDEM_GAME_STATE.match.deck, HOLDEM_GAME_STATE.match.deckSize); + holdemFlop(&HOLDEM_GAME_STATE.match); +} + +void actionStartUpdate(int32_t index, void *data) { +} + +void actionStartDispose(int32_t index, void *data) { + +} \ No newline at end of file diff --git a/src/card/poker/action/start.h b/src/card/poker/action/start.h new file mode 100644 index 00000000..15107b8a --- /dev/null +++ b/src/card/poker/action/start.h @@ -0,0 +1,15 @@ +/** + * Copyright (c) 2021 Dominic Masters + * + * This software is released under the MIT License. + * https://opensource.org/licenses/MIT + */ + +#pragma once +#include + +holdemaction_t actionStart(); + +void actionStartInit(int32_t index, void *data); +void actionStartUpdate(int32_t index, void *data); +void actionStartDispose(int32_t index, void *data); \ No newline at end of file diff --git a/src/card/poker/holdemgame.c b/src/card/poker/holdemgame.c index f5f3b8e4..1bf1427d 100644 --- a/src/card/poker/holdemgame.c +++ b/src/card/poker/holdemgame.c @@ -9,144 +9,21 @@ holdemgame_t HOLDEM_GAME_STATE; void holdemGameInit() { - int32_t lWidth, rWidth, height; - card_t card; - tilesetdiv_t *cardBack; + // Prepare the renderer. + holdemRenderInit(); - // Create the initial frame buffers - lWidth = HOLDEM_GAME_FRAME_LEFT_WIDTH, rWidth = HOLDEM_GAME_FRAME_RIGHT_WIDTH; - height = HOLDEM_GAME_FRAME_HEIGHT; - HOLDEM_GAME_STATE.frameLeft = frameBufferCreate(lWidth, height); - HOLDEM_GAME_STATE.frameRight = frameBufferCreate(rWidth, height); - HOLDEM_GAME_STATE.quadLeft = quadCreate(0, 0, 0, 0, 0, lWidth, height, 1, 1); - HOLDEM_GAME_STATE.quadRight = quadCreate(0, 0, 0, 0, 0, rWidth, height, 1, 1); + // Prepare the action manager + holdemActionInit(); - // Font - HOLDEM_GAME_STATE.fontTexture = assetTextureLoad("font.png"); - HOLDEM_GAME_STATE.fontTileset = tilesetCreate(20, 20, - HOLDEM_GAME_STATE.fontTexture->width, - HOLDEM_GAME_STATE.fontTexture->height, - 1, 1, 1, 1 - ); - HOLDEM_GAME_STATE.fontBatch = spriteBatchCreate(1024); - - // Poker Table - HOLDEM_GAME_STATE.tablePrimitive = pokerTableCreate(); - HOLDEM_GAME_STATE.tableTexture = assetTextureLoad("pokertable.png"); - - // Kagami - HOLDEM_GAME_STATE.kagamiTexture = assetTextureLoad("kagami.png"); - HOLDEM_GAME_STATE.kagamiTileset = tilesetCreate(3, 2, - HOLDEM_GAME_STATE.kagamiTexture->width, - HOLDEM_GAME_STATE.kagamiTexture->height, - 0, 0, 0, 0 - ); - HOLDEM_GAME_STATE.kagamiQuad = quadCreate(0, 0, 0, 0, 0, 1, 1, 1, 1); - - // Load Cards Texture - HOLDEM_GAME_STATE.cardTexture = assetTextureLoad("cards_normal.png"); - HOLDEM_GAME_STATE.cardTileset = tilesetCreate(CARD_COUNT_PER_SUIT, 6, - HOLDEM_GAME_STATE.cardTexture->width, HOLDEM_GAME_STATE.cardTexture->height, - 0, 0, 0, 0 - ); - - // Cards Primitive - cardBack = HOLDEM_GAME_STATE.cardTileset->divisions+( - HOLDEM_GAME_STATE.cardTileset->columns * 4 - ); - HOLDEM_GAME_STATE.cardPrimitive = primitiveCreate( - QUAD_VERTICE_COUNT * 2, QUAD_INDICE_COUNT * 2 - ); - quadBuffer(HOLDEM_GAME_STATE.cardPrimitive, -HOLDEM_GAME_CARD_DEPTH, - -HOLDEM_GAME_CARD_WIDTH, -HOLDEM_GAME_CARD_HEIGHT, - cardBack->x0, cardBack->y1, - HOLDEM_GAME_CARD_WIDTH, HOLDEM_GAME_CARD_HEIGHT, - cardBack->x1, cardBack->y0, - QUAD_VERTICE_COUNT, QUAD_INDICE_COUNT - ); - - // Prepare match - holdemMatchInit(&HOLDEM_GAME_STATE.match); - holdemRoundInit(&HOLDEM_GAME_STATE.match); - cardShuffle(HOLDEM_GAME_STATE.match.deck, HOLDEM_GAME_STATE.match.deckSize); - holdemFlop(&HOLDEM_GAME_STATE.match); + // Start the first action + holdemActionAdd(actionStart()); } void holdemGameUpdate() { - int32_t lWidth, rWidth, height; + holdemActionUpdate(); + holdemRender(); +} - if(true) { - cameraPerspective(&HOLDEM_GAME_STATE.cameraLeft, 45, - ((float)RENDER_STATE.width/(float)RENDER_STATE.height), 1.0f, 1000.0f - ); - cameraLookAt(&HOLDEM_GAME_STATE.cameraLeft, 2, 2, 2, 0, 0, 0); - shaderUseCamera(GAME_STATE.shaderWorld, &HOLDEM_GAME_STATE.cameraLeft); - holdemRenderWorld(); - return; - } - - // Resize Frame buffers. - lWidth = HOLDEM_GAME_FRAME_LEFT_WIDTH, rWidth = HOLDEM_GAME_FRAME_RIGHT_WIDTH; - height = HOLDEM_GAME_FRAME_HEIGHT; - if( - HOLDEM_GAME_STATE.frameLeft->texture->width != lWidth || - HOLDEM_GAME_STATE.frameLeft->texture->height != height - ) { - frameBufferDispose(HOLDEM_GAME_STATE.frameLeft); - frameBufferDispose(HOLDEM_GAME_STATE.frameRight); - HOLDEM_GAME_STATE.frameLeft = frameBufferCreate(lWidth, height); - HOLDEM_GAME_STATE.frameRight = frameBufferCreate(rWidth, height); - quadBuffer(HOLDEM_GAME_STATE.quadLeft, 0, - 0, 0, 0, 1, - lWidth, height, 1, 0, - 0, 0 - ); - quadBuffer(HOLDEM_GAME_STATE.quadRight, 0, - 0, 0, 0, 1, - rWidth, height, 1, 0, - 0, 0 - ); - } - - // Render things on the left frame buffer - glClearColor(0.3, 0, 0, 1); - frameBufferUse(HOLDEM_GAME_STATE.frameLeft, true); - cameraPerspective(&HOLDEM_GAME_STATE.cameraLeft, 45, - ((float)lWidth/height), 1.0f, 1000.0f - ); - cameraLookAt(&HOLDEM_GAME_STATE.cameraLeft, 2, 2, 2, 0, 0, 0); - shaderUseCamera(GAME_STATE.shaderWorld, &HOLDEM_GAME_STATE.cameraLeft); - holdemRenderWorld(); - - - // Render things on the right frame buffer - glClearColor(0.3, 0.3, 0, 1); - frameBufferUse(HOLDEM_GAME_STATE.frameRight, true); - cameraPerspective(&HOLDEM_GAME_STATE.cameraRight, 45, - ((float)rWidth/height), 0.25f, 100.0f - ); - cameraLookAt(&HOLDEM_GAME_STATE.cameraRight, 0, 3, 3, 0, 0, 0); - shaderUseCamera(GAME_STATE.shaderWorld, &HOLDEM_GAME_STATE.cameraRight); - holdemRenderWorld(); - - - // Finally, render the frame buffers to the back buffer. - glClearColor(0, 0, 0, 1); - frameBufferUse(NULL, true); - cameraOrtho(&GAME_STATE.cameraWorld, 0, - RENDER_STATE.width, RENDER_STATE.height, 1, 0, 1 - ); - cameraLookAt(&GAME_STATE.cameraWorld, 0, 0, 0.5f, 0, 0, 0); - shaderUseCamera(GAME_STATE.shaderWorld, &GAME_STATE.cameraWorld); - - // L - shaderUsePosition(GAME_STATE.shaderWorld, 0, 0, 0, 0, 0, 0); - shaderUseTexture(GAME_STATE.shaderWorld, HOLDEM_GAME_STATE.frameLeft->texture); - primitiveDraw(HOLDEM_GAME_STATE.quadLeft, 0, -1); - // R - shaderUsePosition(GAME_STATE.shaderWorld, - RENDER_STATE.width-rWidth, 0, 0, 0, 0, 0 - ); - shaderUseTexture(GAME_STATE.shaderWorld, HOLDEM_GAME_STATE.frameRight->texture); - primitiveDraw(HOLDEM_GAME_STATE.quadRight, 0, -1); +void holdemGameDispose() { + holdemActionDispose(); } \ No newline at end of file diff --git a/src/card/poker/holdemgame.h b/src/card/poker/holdemgame.h index 142174f2..e3bb453a 100644 --- a/src/card/poker/holdemgame.h +++ b/src/card/poker/holdemgame.h @@ -10,19 +10,22 @@ #include "holdem.h" #include "render/holdemrender.h" #include "../card.h" -#include "../../display/framebuffer.h" -#include "../../display/debug/position.h" -#include "../../display/primitive.h" -#include "../../display/shader.h" -#include "../../display/camera.h" -#include "../../display/primitives/cube.h" -#include "../../display/tileset.h" -#include "../../display/primitives/quad.h" #include "../../file/asset.h" #include "../../display/gui/font.h" -#include "model/pokertable.h" - +#include "action/action.h" +#include "action/start.h" +/** + * Initializes the Texas Hold'em game + */ void holdemGameInit(); -void holdemGameUpdate(); \ No newline at end of file +/** + * Update the Texas Hold'em game. + */ +void holdemGameUpdate(); + +/** + * Dispose the Texas Hold'em game. + */ +void holdemGameDispose(); \ No newline at end of file diff --git a/src/card/poker/render/holdemrender.c b/src/card/poker/render/holdemrender.c index a0f82384..67caf428 100644 --- a/src/card/poker/render/holdemrender.c +++ b/src/card/poker/render/holdemrender.c @@ -7,9 +7,159 @@ #include "holdemrender.h" +void holdemRenderInit() { + int32_t lWidth, rWidth, height; + card_t card; + tilesetdiv_t *cardBack; + + // Prepare the two frame buffers. + lWidth = HOLDEM_GAME_FRAME_LEFT_WIDTH, rWidth = HOLDEM_GAME_FRAME_RIGHT_WIDTH; + height = HOLDEM_GAME_FRAME_HEIGHT; + HOLDEM_GAME_STATE.frameLeft = frameBufferCreate(lWidth, height); + HOLDEM_GAME_STATE.frameRight = frameBufferCreate(rWidth, height); + HOLDEM_GAME_STATE.quadLeft = quadCreate(0, 0, 0, 0, 0, lWidth, height, 1, 1); + HOLDEM_GAME_STATE.quadRight = quadCreate(0, 0, 0, 0, 0, rWidth, height, 1, 1); + + // Font + HOLDEM_GAME_STATE.fontTexture = assetTextureLoad("font.png"); + HOLDEM_GAME_STATE.fontTileset = tilesetCreate(20, 20, + HOLDEM_GAME_STATE.fontTexture->width, + HOLDEM_GAME_STATE.fontTexture->height, + 1, 1, 1, 1 + ); + HOLDEM_GAME_STATE.fontBatch = spriteBatchCreate(1024); + + // Poker Table + HOLDEM_GAME_STATE.tablePrimitive = pokerTableCreate(); + HOLDEM_GAME_STATE.tableTexture = assetTextureLoad("pokertable.png"); + + // Kagami + HOLDEM_GAME_STATE.kagamiTexture = assetTextureLoad("kagami.png"); + HOLDEM_GAME_STATE.kagamiTileset = tilesetCreate(3, 2, + HOLDEM_GAME_STATE.kagamiTexture->width, + HOLDEM_GAME_STATE.kagamiTexture->height, + 0, 0, 0, 0 + ); + HOLDEM_GAME_STATE.kagamiQuad = quadCreate(0, 0, 0, 0, 0, 1, 1, 1, 1); + + // Load Cards Texture + HOLDEM_GAME_STATE.cardTexture = assetTextureLoad("cards_normal.png"); + HOLDEM_GAME_STATE.cardTileset = tilesetCreate(CARD_COUNT_PER_SUIT, 6, + HOLDEM_GAME_STATE.cardTexture->width, HOLDEM_GAME_STATE.cardTexture->height, + 0, 0, 0, 0 + ); + + // Cards Primitive + cardBack = HOLDEM_GAME_STATE.cardTileset->divisions+( + HOLDEM_GAME_STATE.cardTileset->columns * 4 + ); + HOLDEM_GAME_STATE.cardPrimitive = primitiveCreate( + QUAD_VERTICE_COUNT * 2, QUAD_INDICE_COUNT * 2 + ); + quadBuffer(HOLDEM_GAME_STATE.cardPrimitive, -HOLDEM_GAME_CARD_DEPTH, + -HOLDEM_GAME_CARD_WIDTH, -HOLDEM_GAME_CARD_HEIGHT, + cardBack->x0, cardBack->y1, + HOLDEM_GAME_CARD_WIDTH, HOLDEM_GAME_CARD_HEIGHT, + cardBack->x1, cardBack->y0, + QUAD_VERTICE_COUNT, QUAD_INDICE_COUNT + ); +} + +void holdemRender() { + int32_t lWidth, rWidth, height; + + // Resize Frame buffers. + lWidth = HOLDEM_GAME_FRAME_LEFT_WIDTH, rWidth = HOLDEM_GAME_FRAME_RIGHT_WIDTH; + height = HOLDEM_GAME_FRAME_HEIGHT; + if( + HOLDEM_GAME_STATE.frameLeft->texture->width != lWidth || + HOLDEM_GAME_STATE.frameLeft->texture->height != height + ) { + frameBufferDispose(HOLDEM_GAME_STATE.frameLeft); + frameBufferDispose(HOLDEM_GAME_STATE.frameRight); + HOLDEM_GAME_STATE.frameLeft = frameBufferCreate(lWidth, height); + HOLDEM_GAME_STATE.frameRight = frameBufferCreate(rWidth, height); + quadBuffer(HOLDEM_GAME_STATE.quadLeft, 0, + 0, 0, 0, 1, + lWidth, height, 1, 0, + 0, 0 + ); + quadBuffer(HOLDEM_GAME_STATE.quadRight, 0, + 0, 0, 0, 1, + rWidth, height, 1, 0, + 0, 0 + ); + } + + // Render things on the left frame buffer + glClearColor(0.3, 0, 0, 1); + frameBufferUse(HOLDEM_GAME_STATE.frameLeft, true); + cameraPerspective(&HOLDEM_GAME_STATE.cameraLeft, 25, + ((float)lWidth/height), 0.2f, 1000.0f + ); + // cameraLookAt(&HOLDEM_GAME_STATE.cameraLeft, 2, 2, 2, 0, 0, 0); + holdemLookHand(&HOLDEM_GAME_STATE.cameraLeft, 0x00); + shaderUseCamera(GAME_STATE.shaderWorld, &HOLDEM_GAME_STATE.cameraLeft); + holdemRenderWorld(); + + // Render things on the right frame buffer + glClearColor(0.3, 0.3, 0, 1); + frameBufferUse(HOLDEM_GAME_STATE.frameRight, true); + cameraPerspective(&HOLDEM_GAME_STATE.cameraRight, 45, + ((float)rWidth/height), 0.25f, 100.0f + ); + cameraLookAt(&HOLDEM_GAME_STATE.cameraRight, 0, 3, 3, 0, 0, 0); + shaderUseCamera(GAME_STATE.shaderWorld, &HOLDEM_GAME_STATE.cameraRight); + holdemRenderWorld(); + + // Finally, render the frame buffers to the back buffer. + glClearColor(0, 0, 0, 1); + frameBufferUse(NULL, true); + cameraOrtho(&GAME_STATE.cameraWorld, 0, + RENDER_STATE.width, RENDER_STATE.height, 1, 0, 1 + ); + cameraLookAt(&GAME_STATE.cameraWorld, 0, 0, 0.5f, 0, 0, 0); + shaderUseCamera(GAME_STATE.shaderWorld, &GAME_STATE.cameraWorld); + shaderUsePosition(GAME_STATE.shaderWorld, + 0, 0, 0, 0, 0, 0 + ); + shaderUseTexture(GAME_STATE.shaderWorld, HOLDEM_GAME_STATE.frameLeft->texture); + primitiveDraw(HOLDEM_GAME_STATE.quadLeft, 0, -1); + shaderUsePosition(GAME_STATE.shaderWorld, + RENDER_STATE.width-rWidth, 0, 0, 0, 0, 0 + ); + shaderUseTexture(GAME_STATE.shaderWorld, HOLDEM_GAME_STATE.frameRight->texture); + primitiveDraw(HOLDEM_GAME_STATE.quadRight, 0, -1); +} + +void holdemLookSeat(camera_t *camera, uint8_t seat) { + float x, z, angle; + + angle = mathDeg2Rad(-45*seat); + x = sin(angle); + z = cos(angle); + cameraLookAt(&HOLDEM_GAME_STATE.cameraLeft, + x, 0.2, z, + -x, 0.2, -z + ); +} + +void holdemLookHand(camera_t *camera, uint8_t seat) { + float x, lx, z, lz, angle, distance; + + angle = mathDeg2Rad(-45*seat); + x = sin(angle); + z = cos(angle); + + cameraLookAt(&HOLDEM_GAME_STATE.cameraLeft, + x*0.1, 0.8, z*0.1, + -x*0.5, 0.2, -z*0.5 + ); +} + void holdemRenderPlayer(float x, float y, float z, float yaw) { float w, h; - w = 0.75, h = ( + w = 0.6, h = ( (float)HOLDEM_GAME_STATE.kagamiTileset->divY / (float)HOLDEM_GAME_STATE.kagamiTileset->divX ) * w; @@ -55,15 +205,15 @@ void holdemRenderWorld() { // Poker Table shaderUsePositionAndScale(GAME_STATE.shaderWorld, - 0, -0.01, 0.05, + 0, -0.01, 0, 0, 0, 0, - 3.29, 3.29, 3.29 + 3.4, 3.4, 3.4 ); shaderUseTexture(GAME_STATE.shaderWorld, HOLDEM_GAME_STATE.tableTexture); primitiveDraw(HOLDEM_GAME_STATE.tablePrimitive, 0, -1); - + + pitch = mathDeg2Rad(-90); for(j = 0; j < HOLDEM_GAME_STATE.match.cardsFacing; j++) { - pitch = mathDeg2Rad(-90); holdemRenderCard(HOLDEM_GAME_STATE.match.cards[j], j*0.2, 0, -0.2, pitch, 0, 0); } @@ -100,10 +250,10 @@ void holdemRenderWorld() { spriteBatchDraw(HOLDEM_GAME_STATE.fontBatch, 0, -1); // Draw the players - float playerY = 0; + float playerY = 0.34; holdemRenderPlayer(0, playerY, -1, 0); - holdemRenderPlayer(-1, playerY, -0, 90); - holdemRenderPlayer(-0.75, playerY, 0.75, -45); - holdemRenderPlayer(0.75, playerY, 0.75, 45); - holdemRenderPlayer(1, playerY, 0, -90); -} \ No newline at end of file + // holdemRenderPlayer(-1, playerY, -0, 90); + // holdemRenderPlayer(-0.75, playerY, 0.75, -45); + // holdemRenderPlayer(0.75, playerY, 0.75, 45); + // holdemRenderPlayer(1, playerY, 0, -90); +} diff --git a/src/card/poker/render/holdemrender.h b/src/card/poker/render/holdemrender.h index a2ef9a4c..2395feb2 100644 --- a/src/card/poker/render/holdemrender.h +++ b/src/card/poker/render/holdemrender.h @@ -12,10 +12,30 @@ #include "../../../display/primitives/quad.h" #include "../../../display/spritebatch.h" #include "../../../display/gui/font.h" +#include "../../../display/framebuffer.h" +#include "../../../display/camera.h" +#include "../../../display/primitives/cube.h" +#include "../../../display/tileset.h" #include "../../../util/math.h" +#include "../model/pokertable.h" + +/** + * Prepare the Hold'em Game Renderer. + */ +void holdemRenderInit(); + +/** + * Render the Texas Hold'em Game. + */ +void holdemRender(); + +void holdemLookSeat(camera_t *camera, uint8_t seat); +void holdemLookHand(camera_t *camera, uint8_t seat); void holdemRenderPlayer(float x, float y, float z, float yaw); + void holdemRenderCard(card_t card, float x, float y, float z, float pitch, float yaw, float roll ); + void holdemRenderWorld(); \ No newline at end of file