diff --git a/CMakeLists.txt b/CMakeLists.txt index 7d07c6d6..ff77ff8a 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -4,7 +4,7 @@ # https://opensource.org/licenses/MIT # DEBUG -set(DAWN_BUILDING dawnpokergame) +set(DAWN_BUILDING dawnosui) cmake_minimum_required(VERSION 3.13) set(CMAKE_C_STANDARD 99) diff --git a/src/dawn/display/font/TrueTypeFont.cpp b/src/dawn/display/font/TrueTypeFont.cpp index fd733906..f3328099 100644 --- a/src/dawn/display/font/TrueTypeFont.cpp +++ b/src/dawn/display/font/TrueTypeFont.cpp @@ -162,7 +162,7 @@ void TrueTypeFont::buffer( info->height = mathMax(info->height, quad->y1); // Buffer the quad. - QuadMesh::bufferQuadMesh(mesh, + QuadMesh::bufferQuadMesh(&mesh, glm::vec2(quad->x0, quad->y0), glm::vec2(quad->s0, quad->t0), glm::vec2(quad->x1, quad->y1), glm::vec2(quad->s1, quad->t1), j * QUAD_VERTICE_COUNT, j * QUAD_INDICE_COUNT diff --git a/src/dawn/display/mesh/QuadMesh.cpp b/src/dawn/display/mesh/QuadMesh.cpp index 4c9f3ece..55db82d5 100644 --- a/src/dawn/display/mesh/QuadMesh.cpp +++ b/src/dawn/display/mesh/QuadMesh.cpp @@ -8,12 +8,12 @@ using namespace Dawn; void QuadMesh::bufferQuadMeshWithZ( - Mesh &mesh, + Mesh *mesh, glm::vec2 xy0, glm::vec2 uv0, glm::vec2 xy1, glm::vec2 uv1, float_t z, int32_t verticeStart, int32_t indiceStart ) { - mesh.bufferPositions( + mesh->bufferPositions( verticeStart, std::array{{ glm::vec3(xy0, z), glm::vec3(xy1.x, xy0.y, z), @@ -22,14 +22,14 @@ void QuadMesh::bufferQuadMeshWithZ( }} ); - mesh.bufferCoordinates( + mesh->bufferCoordinates( verticeStart, std::array{{ uv0, glm::vec2(uv1.x, uv0.y), glm::vec2(uv0.x, uv1.y), uv1 }} ); - mesh.bufferIndices( + mesh->bufferIndices( indiceStart, std::array{{ verticeStart, verticeStart + 1, verticeStart + 2, verticeStart + 1, verticeStart + 2, verticeStart + 3 @@ -38,7 +38,7 @@ void QuadMesh::bufferQuadMeshWithZ( } void QuadMesh::bufferQuadMesh( - Mesh &mesh, + Mesh *mesh, glm::vec2 xy0, glm::vec2 uv0, glm::vec2 xy1, glm::vec2 uv1, int32_t verticeStart, int32_t indiceStart diff --git a/src/dawn/display/mesh/QuadMesh.hpp b/src/dawn/display/mesh/QuadMesh.hpp index 2f065667..201255ec 100644 --- a/src/dawn/display/mesh/QuadMesh.hpp +++ b/src/dawn/display/mesh/QuadMesh.hpp @@ -26,7 +26,7 @@ namespace Dawn { * @param indiceStart Start indice to buffer to. */ static void bufferQuadMeshWithZ( - Mesh &mesh, + Mesh *mesh, glm::vec2 xy0, glm::vec2 uv0, glm::vec2 xy1, glm::vec2 uv1, float_t z, int32_t verticeStart, int32_t indiceStart @@ -44,7 +44,7 @@ namespace Dawn { * @param indiceStart Start indice to buffer to. */ static void bufferQuadMesh( - Mesh &mesh, + Mesh *mesh, glm::vec2 xy0, glm::vec2 uv0, glm::vec2 xy1, glm::vec2 uv1, int32_t verticeStart, int32_t indiceStart diff --git a/src/dawn/display/shader/_Shader.hpp b/src/dawn/display/shader/_Shader.hpp index 2603f6f6..b581f3a1 100644 --- a/src/dawn/display/shader/_Shader.hpp +++ b/src/dawn/display/shader/_Shader.hpp @@ -14,7 +14,8 @@ namespace Dawn { SHADER_PARAMETER_TYPE_BOOLEAN, SHADER_PARAMETER_TYPE_COLOR, SHADER_PARAMETER_TYPE_VECTOR3, - SHADER_PARAMETER_TYPE_TEXTURE + SHADER_PARAMETER_TYPE_TEXTURE, + SHADER_PARAMETER_TYPE_FLOAT }; template @@ -102,5 +103,13 @@ namespace Dawn { * @param texture Texture to bind to the parameter. */ virtual void setTexture(T parameter, Texture *texture) = 0; + + /** + * Sets a floating point value to the shader. + * + * @param parameter Paramater to set the float ont o. + * @param float Float to bind. + */ + virtual void setFloat(T parameter, float_t value) = 0; }; } \ No newline at end of file diff --git a/src/dawn/scene/components/display/Material.cpp b/src/dawn/scene/components/display/Material.cpp index d02fbabb..57abdecd 100644 --- a/src/dawn/scene/components/display/Material.cpp +++ b/src/dawn/scene/components/display/Material.cpp @@ -51,6 +51,10 @@ void Material::setShaderParameters() { this->shader->setTexture(it->first, this->textureValues[it->first]); break; + case SHADER_PARAMETER_TYPE_FLOAT: + this->shader->setFloat(it->first, this->floatValues[it->first]); + break; + default: throw "An unsupported or invalid shader parameter type was supplied."; } diff --git a/src/dawn/scene/components/display/Material.hpp b/src/dawn/scene/components/display/Material.hpp index 30aa54df..ae36b18e 100644 --- a/src/dawn/scene/components/display/Material.hpp +++ b/src/dawn/scene/components/display/Material.hpp @@ -27,6 +27,7 @@ namespace Dawn { std::map matrixValues; std::map vec3Values; std::map textureValues; + std::map floatValues; /** * Material component constructor. diff --git a/src/dawn/ui/UIBorder.cpp b/src/dawn/ui/UIBorder.cpp index 1d0dceec..d045b8fd 100644 --- a/src/dawn/ui/UIBorder.cpp +++ b/src/dawn/ui/UIBorder.cpp @@ -30,7 +30,7 @@ void UIBorder::updatePositions() { glm::vec2 innerDimensions = overallDimensions - (this->edgeDimensions * 2.0f); // Top Left. - QuadMesh::bufferQuadMesh(this->mesh, + QuadMesh::bufferQuadMesh(&this->mesh, glm::vec2(0, 0), this->uv0, edgeDimensions, @@ -39,7 +39,7 @@ void UIBorder::updatePositions() { ); // Top Center - QuadMesh::bufferQuadMesh(this->mesh, + QuadMesh::bufferQuadMesh(&this->mesh, glm::vec2(edgeDimensions.x, 0), this->uv0 + glm::vec2(oneThird.x, 0), glm::vec2(edgeDimensions.x + innerDimensions.x, edgeDimensions.y), @@ -48,7 +48,7 @@ void UIBorder::updatePositions() { ); // Top Right - QuadMesh::bufferQuadMesh(this->mesh, + QuadMesh::bufferQuadMesh(&this->mesh, glm::vec2(edgeDimensions.x + innerDimensions.x, 0), this->uv0 + glm::vec2(oneThird.x * 2.0f, 0), glm::vec2(overallDimensions.x, edgeDimensions.y), @@ -57,7 +57,7 @@ void UIBorder::updatePositions() { ); // Middle Left - QuadMesh::bufferQuadMesh(this->mesh, + QuadMesh::bufferQuadMesh(&this->mesh, glm::vec2(0, edgeDimensions.y), this->uv0 + glm::vec2(0, oneThird.y), glm::vec2(edgeDimensions.x, edgeDimensions.y + innerDimensions.y), @@ -66,7 +66,7 @@ void UIBorder::updatePositions() { ); // Center - QuadMesh::bufferQuadMesh(this->mesh, + QuadMesh::bufferQuadMesh(&this->mesh, edgeDimensions, this->uv0 + oneThird, edgeDimensions + innerDimensions, @@ -75,7 +75,7 @@ void UIBorder::updatePositions() { ); // Middle Right - QuadMesh::bufferQuadMesh(this->mesh, + QuadMesh::bufferQuadMesh(&this->mesh, edgeDimensions + glm::vec2(innerDimensions.x, 0), this->uv0 + glm::vec2(oneThird.x * 2.0f, oneThird.y), edgeDimensions + innerDimensions + glm::vec2(edgeDimensions.x, 0), @@ -84,7 +84,7 @@ void UIBorder::updatePositions() { ); // Bottom Left - QuadMesh::bufferQuadMesh(this->mesh, + QuadMesh::bufferQuadMesh(&this->mesh, glm::vec2(0.0f, edgeDimensions.y + innerDimensions.y), this->uv0 + glm::vec2(0.0f, uv1.y - oneThird.y), glm::vec2(edgeDimensions.x, overallDimensions.y), @@ -93,7 +93,7 @@ void UIBorder::updatePositions() { ); // Bottom Center - QuadMesh::bufferQuadMesh(this->mesh, + QuadMesh::bufferQuadMesh(&this->mesh, edgeDimensions + glm::vec2(0.0f, innerDimensions.y), this->uv1 - oneThird, overallDimensions - glm::vec2(edgeDimensions.x, 0.0f), @@ -102,7 +102,7 @@ void UIBorder::updatePositions() { ); // Bottom Right - QuadMesh::bufferQuadMesh(this->mesh, + QuadMesh::bufferQuadMesh(&this->mesh, overallDimensions - edgeDimensions, this->uv1 - oneThird, overallDimensions, diff --git a/src/dawn/ui/UISprite.cpp b/src/dawn/ui/UISprite.cpp index 9000919b..a411468d 100644 --- a/src/dawn/ui/UISprite.cpp +++ b/src/dawn/ui/UISprite.cpp @@ -15,7 +15,7 @@ void UISprite::updatePositions() { UIComponent::updatePositions(); QuadMesh::bufferQuadMesh( - this->mesh, + &this->mesh, glm::vec2(0, 0), glm::vec2(0, 0), glm::vec2(this->width, this->height), glm::vec2(1, 1), 0, 0 diff --git a/src/dawnopengl/display/shader/Shader.cpp b/src/dawnopengl/display/shader/Shader.cpp index d1edbb2d..f8238bde 100644 --- a/src/dawnopengl/display/shader/Shader.cpp +++ b/src/dawnopengl/display/shader/Shader.cpp @@ -96,6 +96,10 @@ void Shader::setTexture( this->bindTexture(param, texture); } +void Shader::setFloat(shaderparameter_t param, float_t value) { + glUniform1f(param, value); +} + void Shader::bind() { if(this->shaderProgram == -1) throw "Shader has not yet been compiled"; glUseProgram(this->shaderProgram); diff --git a/src/dawnopengl/display/shader/Shader.hpp b/src/dawnopengl/display/shader/Shader.hpp index 35f6bc00..54c0d5bb 100644 --- a/src/dawnopengl/display/shader/Shader.hpp +++ b/src/dawnopengl/display/shader/Shader.hpp @@ -76,6 +76,7 @@ namespace Dawn { void setColor(shaderparameter_t parameter, struct Color color) override; void setVector3(shaderparameter_t parameter, glm::vec3 vector) override; void setTexture(shaderparameter_t parameter, Texture *texture) override; + void setFloat(shaderparameter_t parameter, float_t value) override; /** * Destroys and deletes the shader from the GPU. diff --git a/src/dawnosui/CMakeLists.txt b/src/dawnosui/CMakeLists.txt new file mode 100644 index 00000000..86f85f3d --- /dev/null +++ b/src/dawnosui/CMakeLists.txt @@ -0,0 +1,20 @@ +# Copyright (c) 2022 Dominic Masters +# +# This software is released under the MIT License. +# https://opensource.org/licenses/MIT + +# Set up the executable +set(DAWN_TARGET_NAME "DawnOS" CACHE INTERNAL ${DAWN_CACHE_TARGET}) + +# Build Project +add_executable(${DAWN_TARGET_NAME}) + +# Includes +target_include_directories(${DAWN_TARGET_NAME} + PUBLIC + ${CMAKE_CURRENT_LIST_DIR} +) + +# Subdirs +add_subdirectory(game) +add_subdirectory(display) \ No newline at end of file diff --git a/src/dawnosui/display/CMakeLists.txt b/src/dawnosui/display/CMakeLists.txt new file mode 100644 index 00000000..97421ebe --- /dev/null +++ b/src/dawnosui/display/CMakeLists.txt @@ -0,0 +1,7 @@ +# Copyright (c) 2022 Dominic Masters +# +# This software is released under the MIT License. +# https://opensource.org/licenses/MIT + +# Subdirs +add_subdirectory(shader) \ No newline at end of file diff --git a/src/dawnosui/display/shader/CMakeLists.txt b/src/dawnosui/display/shader/CMakeLists.txt new file mode 100644 index 00000000..f314bd49 --- /dev/null +++ b/src/dawnosui/display/shader/CMakeLists.txt @@ -0,0 +1,6 @@ +# Copyright (c) 2022 Dominic Masters +# +# This software is released under the MIT License. +# https://opensource.org/licenses/MIT + +# Sources \ No newline at end of file diff --git a/src/dawnosui/display/shader/TestBackgroundShader.hpp b/src/dawnosui/display/shader/TestBackgroundShader.hpp new file mode 100644 index 00000000..0097b4ca --- /dev/null +++ b/src/dawnosui/display/shader/TestBackgroundShader.hpp @@ -0,0 +1,94 @@ +// Copyright (c) 2022 Dominic Masters +// +// This software is released under the MIT License. +// https://opensource.org/licenses/MIT + +#pragma once +#include "display/shader/Shader.hpp" +#include "scene/components/Components.hpp" + +namespace Dawn { + class TestBackgroundShader : public Shader { + public: + shaderparameter_t paramProjection; + shaderparameter_t paramView; + shaderparameter_t paramTime; + + std::map + getParameters() override { + std::map ps; + ps[paramTime] = SHADER_PARAMETER_TYPE_FLOAT; + return ps; + } + + void setDefaultParameters(Material &material) override { + material.floatValues[this->paramTime] = 0.0f; + } + + void setGlobalParameters(glm::mat4 proj, glm::mat4 view) override { + this->setMatrix(this->paramProjection, proj); + this->setMatrix(this->paramView, view); + } + + void setMeshParameters(glm::mat4 transform) override {} + + void bindTexture( + shaderparameter_t param, + Texture *texture + ) override {} + + void compile() override { + this->compileShader(R"GLSL( + #version 330 core + layout (location = 0) in vec3 aPos; + layout (location = 1) in vec2 aTexCoord; + + uniform mat4 u_Proj; + uniform mat4 u_View; + + out vec2 o_TextCoord; + void main() { + gl_Position = u_Proj * u_View * vec4(aPos, 1.0); + o_TextCoord = vec2(aTexCoord.x, aTexCoord.y); + } + )GLSL", R"GLSL( + #version 330 core + out vec4 o_Color; + in vec2 o_TextCoord; + uniform float u_Time; + + void main() { + highp float tSpan = 4.0; + highp float halfTSpan = tSpan / 2.0; + highp float t = mod(u_Time, tSpan); + if(t > halfTSpan) { + t = halfTSpan + (halfTSpan - t); + } + t = t / halfTSpan; + + highp float x = o_TextCoord.x; + highp float y = o_TextCoord.y; + float h = sin(x + u_Time) / 4 + 0.5; + + highp float r = (0.6 + ((y * t) / 5.0)); + highp float g = 0.4 + ((x * t) / (10 + (t * 3))); + highp float b = 0.8 + ((0.2 * t) - (x / 5)); + highp float global = 0.7 + ((0.1 + (y * 0.6)) / h / 4.0); + + + o_Color = vec4( + r * global, + g * global, + b * global, + 1.0 + ); + } + )GLSL" + ); + + this->paramProjection = this->getParameterByName("u_Proj"); + this->paramView = this->getParameterByName("u_View"); + this->paramTime = this->getParameterByName("u_Time"); + } + }; +} \ No newline at end of file diff --git a/src/dawnosui/game/CMakeLists.txt b/src/dawnosui/game/CMakeLists.txt new file mode 100644 index 00000000..07f25903 --- /dev/null +++ b/src/dawnosui/game/CMakeLists.txt @@ -0,0 +1,10 @@ +# Copyright (c) 2022 Dominic Masters +# +# This software is released under the MIT License. +# https://opensource.org/licenses/MIT + +# Sources +target_sources(${DAWN_TARGET_NAME} + PRIVATE + DawnPokerGame.cpp +) \ No newline at end of file diff --git a/src/dawnosui/game/DawnPokerGame.cpp b/src/dawnosui/game/DawnPokerGame.cpp new file mode 100644 index 00000000..6618cb65 --- /dev/null +++ b/src/dawnosui/game/DawnPokerGame.cpp @@ -0,0 +1,69 @@ +// Copyright (c) 2022 Dominic Masters +// +// This software is released under the MIT License. +// https://opensource.org/licenses/MIT + +#include "DawnPokerGame.hpp" + +using namespace Dawn; + +std::shared_ptr material; +std::shared_ptr shader; + +DawnGame::DawnGame(DawnHost &host) : + host(host), + renderManager(*this), + inputManager(*this) +{ +} + +int32_t DawnGame::init() { + this->assetManager.init(); + this->renderManager.init(); + + this->scene = std::make_shared(*this); + + auto cameraObject = this->scene->createSceneItem(); + auto camera = cameraObject->addComponent(); + camera->type = CAMERA_TYPE_ORTHONOGRAPHIC; + camera->orthoLeft = 0.0f; + camera->orthoRight = 1.0f; + camera->orthoTop = 0.0f; + camera->orthoBottom = 1.0f; + camera->transform.lookAt(glm::vec3(0, 0, 10), glm::vec3(0, 0, 0)); + // camera->transform.lookAt(glm::vec3(50, 50, 50), glm::vec3(0, 0, 0)); + + auto quad = this->scene->createSceneItem(); + auto meshRenderer = quad->addComponent(); + meshRenderer->mesh = std::make_shared(); + meshRenderer->mesh->createBuffers(QUAD_VERTICE_COUNT, QUAD_INDICE_COUNT); + QuadMesh::bufferQuadMesh(meshRenderer->mesh.get(), + glm::vec2(0, 0), glm::vec2(0, 0), + glm::vec2(1.0f, 1.0f), glm::vec2(1.0f, 1.0f), + 0, 0 + ); + + shader = std::make_shared(); + shader->compile(); + material = quad->addComponent(); + material->setShader(shader); + + return DAWN_GAME_INIT_RESULT_SUCCESS; +} + +int32_t DawnGame::update(float_t delta) { + this->assetManager.update(); + this->inputManager.update(); + this->timeManager.update(delta); + + if(this->scene != nullptr) this->scene->update(); + + material->floatValues[shader->paramTime] = this->timeManager.time; + + this->renderManager.update(); + return DAWN_GAME_UPDATE_RESULT_SUCCESS; +} + +DawnGame::~DawnGame() { + +} \ No newline at end of file diff --git a/src/dawnosui/game/DawnPokerGame.hpp b/src/dawnosui/game/DawnPokerGame.hpp new file mode 100644 index 00000000..d73532d8 --- /dev/null +++ b/src/dawnosui/game/DawnPokerGame.hpp @@ -0,0 +1,10 @@ +// Copyright (c) 2022 Dominic Masters +// +// This software is released under the MIT License. +// https://opensource.org/licenses/MIT + +#pragma once +#include "game/DawnGame.hpp" +#include "scene/components/Components.hpp" +#include "display/mesh/QuadMesh.hpp" +#include "display/shader/TestBackgroundShader.hpp" \ No newline at end of file diff --git a/src/dawnosui/input/InputBinds.hpp b/src/dawnosui/input/InputBinds.hpp new file mode 100644 index 00000000..9e400ad8 --- /dev/null +++ b/src/dawnosui/input/InputBinds.hpp @@ -0,0 +1,9 @@ +// Copyright (c) 2022 Dominic Masters +// +// This software is released under the MIT License. +// https://opensource.org/licenses/MIT + +#pragma once +#include "input/InputManager.hpp" + +#define INPUT_BIND_ACCEPT ((inputbind_t)1) \ No newline at end of file