From 9f101a9180e03fa146991ad1047ae89ba701871a Mon Sep 17 00:00:00 2001 From: Zang3th Date: Thu, 4 Jul 2024 18:23:44 +0200 Subject: [PATCH] RenderManager no longer acts as an interface just as a storage manager for the different renderers --- .clang-tidy | 1 - Apps/CellSim/CellSimApp.cpp | 13 +- Apps/CellSim/CellSimApp.hpp | 1 + Apps/GreenWorld/GreenWorldApp.cpp | 30 ++-- Apps/GreenWorld/GreenWorldApp.hpp | 9 +- Apps/Liquefied/LiquefiedApp.cpp | 3 +- Engine/Engine.hpp | 3 +- .../Physics/CellularAutomata/CellManager.cpp | 17 +-- .../Physics/CellularAutomata/CellManager.hpp | 7 +- Engine/Rendering/Renderer/CellRenderer.cpp | 18 +-- Engine/Rendering/Renderer/CellRenderer.hpp | 12 +- Engine/Rendering/Renderer/GridRenderer.cpp | 36 ++--- Engine/Rendering/Renderer/GridRenderer.hpp | 56 ++++---- .../Rendering/Renderer/ParticleRenderer.cpp | 45 +++--- .../Rendering/Renderer/ParticleRenderer.hpp | 22 ++- Engine/Rendering/Renderer/PixelRenderer.cpp | 4 +- Engine/Rendering/Renderer/PixelRenderer.hpp | 6 +- Engine/Rendering/Renderer/RenderManager.cpp | 129 +----------------- Engine/Rendering/Renderer/RenderManager.hpp | 49 +------ Engine/Rendering/Renderer/SceneRenderer.cpp | 34 ++--- Engine/Rendering/Renderer/SceneRenderer.hpp | 10 +- Engine/Rendering/Renderer/ShadowRenderer.cpp | 30 ++-- Engine/Rendering/Renderer/ShadowRenderer.hpp | 9 +- Engine/Rendering/Renderer/SpriteRenderer.cpp | 4 +- Engine/Rendering/Renderer/SpriteRenderer.hpp | 7 +- Engine/Rendering/Renderer/WaterRenderer.cpp | 16 +-- Engine/Rendering/Renderer/WaterRenderer.hpp | 8 +- Scripts/Profile.sh | 13 ++ 28 files changed, 216 insertions(+), 376 deletions(-) create mode 100755 Scripts/Profile.sh diff --git a/.clang-tidy b/.clang-tidy index 9ca58ba5..6f68d2f4 100644 --- a/.clang-tidy +++ b/.clang-tidy @@ -3,7 +3,6 @@ Checks: "*, -google-*, -llvm*, -cppcoreguidelines-*, - -perfomance-*, -readability-identifier-length, -hicpp-uppercase-literal-suffix, -readability-uppercase-literal-suffix, diff --git a/Apps/CellSim/CellSimApp.cpp b/Apps/CellSim/CellSimApp.cpp index ff303727..76d9997a 100644 --- a/Apps/CellSim/CellSimApp.cpp +++ b/Apps/CellSim/CellSimApp.cpp @@ -38,12 +38,15 @@ namespace CS LoadResources(); //Create application specific renderers - _sceneRenderer = Engine::RenderManager::AddSceneRenderer(); + _sceneRenderer = new Engine::SceneRenderer(); _sceneRenderer->SetModelShader("ModelShader"); + Engine::RenderManager::Submit(_sceneRenderer); + + _cellRenderer = new Engine::CellRenderer("CellShader", glm::vec3(-30.0f, 0.5f, -30.0f)); + Engine::RenderManager::Submit(_cellRenderer); //Create cell manager and add cell renderer - _cellManager = Engine::MakeScope(); - _cellManager->AddCellRenderer("CellShader", glm::vec3(-30.0f, 0.5f, -30.0f)); + _cellManager = Engine::MakeScope(_cellRenderer); //Create UI _interface = Engine::MakeScope(); @@ -239,13 +242,13 @@ namespace CS { Engine::PROFILE_SCOPE("Render scene"); - Engine::RenderManager::RenderScene(); + _sceneRenderer->Flush(nullptr); } { Engine::PROFILE_SCOPE("Render cells"); - Engine::RenderManager::RenderCells(); + _cellRenderer->Flush((Engine::Renderer*)_sceneRenderer); } { diff --git a/Apps/CellSim/CellSimApp.hpp b/Apps/CellSim/CellSimApp.hpp index 7feeaf93..4596b14e 100644 --- a/Apps/CellSim/CellSimApp.hpp +++ b/Apps/CellSim/CellSimApp.hpp @@ -12,6 +12,7 @@ namespace CS Engine::uint8 _tickCounter = 0; bool _calcPhysicsThisTurn = true; Engine::SceneRenderer* _sceneRenderer = nullptr; + Engine::CellRenderer* _cellRenderer = nullptr; Engine::Scope _cellManager; Engine::Scope _interface; diff --git a/Apps/GreenWorld/GreenWorldApp.cpp b/Apps/GreenWorld/GreenWorldApp.cpp index 754a31d4..e7abb3ef 100644 --- a/Apps/GreenWorld/GreenWorldApp.cpp +++ b/Apps/GreenWorld/GreenWorldApp.cpp @@ -48,14 +48,23 @@ namespace GW LoadResources(); //Create application specific renderers - _sceneRenderer = Engine::RenderManager::AddSceneRenderer(); + _sceneRenderer = new Engine::SceneRenderer(); _sceneRenderer->SetTerrainShader("TerrainShader"); _sceneRenderer->SetModelShader("ModelShader"); _sceneRenderer->SetWaterShader("WaterShader"); - _shadowRenderer = Engine::RenderManager::AddShadowRenderer(8192, glm::ortho(-90.0f, 90.0f, -90.0f, 90.0f, 110.0f, 210.0f), "ShadowCreateShader"); - _waterRenderer = Engine::RenderManager::AddWaterRenderer(); - _spriteRenderer = Engine::RenderManager::AddSpriteRenderer(); - Engine::RenderManager::AddParticleRenderer + Engine::RenderManager::Submit(_sceneRenderer); + + _shadowRenderer = new Engine::ShadowRenderer(8192, 8192, glm::ortho(-90.0f, 90.0f, -90.0f, 90.0f, 110.0f, 210.0f), "ShadowCreateShader"); + _sceneRenderer->AddLightProjection(_shadowRenderer->GetLightProjection()); + Engine::RenderManager::Submit(_shadowRenderer); + + _waterRenderer = new Engine::WaterRenderer(); + Engine::RenderManager::Submit(_waterRenderer); + + _spriteRenderer = new Engine::SpriteRenderer(); + Engine::RenderManager::Submit(_spriteRenderer); + + _particleRenderer = new Engine::ParticleRenderer ( 200, 5.0f, @@ -67,6 +76,7 @@ namespace GW "ParticleShader", glm::vec3(87.0f, 34.0f, 92.5f) ); + Engine::RenderManager::Submit(_particleRenderer); //Create UI _interface = Engine::MakeScope(); @@ -234,24 +244,24 @@ namespace GW { Engine::PROFILE_SCOPE("Render shadows"); - Engine::RenderManager::RenderShadows(); + _shadowRenderer->Flush((Engine::Renderer*)_sceneRenderer); } { Engine::PROFILE_SCOPE("Render water"); - Engine::RenderManager::RenderWater(); + _waterRenderer->Flush((Engine::Renderer*)_sceneRenderer); } { Engine::PROFILE_SCOPE("Render scene"); - Engine::RenderManager::RenderScene(); - Engine::RenderManager::RenderParticles(); + _sceneRenderer->Flush(nullptr); + _particleRenderer->Flush((Engine::Renderer*)_sceneRenderer); if(Engine::UIParams::debugSprites) { - Engine::RenderManager::RenderSprites(); + _spriteRenderer->Flush(nullptr); } } diff --git a/Apps/GreenWorld/GreenWorldApp.hpp b/Apps/GreenWorld/GreenWorldApp.hpp index e4a349b4..c4648783 100644 --- a/Apps/GreenWorld/GreenWorldApp.hpp +++ b/Apps/GreenWorld/GreenWorldApp.hpp @@ -8,10 +8,11 @@ namespace GW class GreenWorldApp final : public Engine::App { private: - Engine::SceneRenderer* _sceneRenderer = nullptr; - Engine::ShadowRenderer* _shadowRenderer = nullptr; - Engine::WaterRenderer* _waterRenderer = nullptr; - Engine::SpriteRenderer* _spriteRenderer = nullptr; + Engine::SceneRenderer* _sceneRenderer = nullptr; + Engine::ShadowRenderer* _shadowRenderer = nullptr; + Engine::WaterRenderer* _waterRenderer = nullptr; + Engine::ParticleRenderer* _particleRenderer = nullptr; + Engine::SpriteRenderer* _spriteRenderer = nullptr; Engine::Scope _interface; Engine::Scope _audio; diff --git a/Apps/Liquefied/LiquefiedApp.cpp b/Apps/Liquefied/LiquefiedApp.cpp index fbce1c4f..dd6b85e1 100644 --- a/Apps/Liquefied/LiquefiedApp.cpp +++ b/Apps/Liquefied/LiquefiedApp.cpp @@ -44,13 +44,14 @@ namespace Liq LoadResources(); //Create grid renderer - _gridRenderer = Engine::RenderManager::AddGridRenderer + _gridRenderer = new Engine::GridRenderer ( Engine::LiquiefiedParams::SIMULATION_WIDTH, Engine::LiquiefiedParams::SIMULATION_HEIGHT, 10, "GridShader" ); + Engine::RenderManager::Submit(_gridRenderer); //Create UI _interface = Engine::MakeScope(); diff --git a/Engine/Engine.hpp b/Engine/Engine.hpp index 768d5184..64fbb061 100644 --- a/Engine/Engine.hpp +++ b/Engine/Engine.hpp @@ -29,7 +29,8 @@ #include "SpriteRenderer.hpp" #include "WaterRenderer.hpp" #include "ParticleRenderer.hpp" +#include "GridRenderer.hpp" // ----- Physics ----- #include "CellManager.hpp" -#include "FluidSimulator.hpp" \ No newline at end of file +#include "FluidSimulator.hpp" diff --git a/Engine/Physics/CellularAutomata/CellManager.cpp b/Engine/Physics/CellularAutomata/CellManager.cpp index ebfa937f..9c220906 100644 --- a/Engine/Physics/CellularAutomata/CellManager.cpp +++ b/Engine/Physics/CellularAutomata/CellManager.cpp @@ -152,23 +152,12 @@ namespace Engine // ----- Public ----- - CellManager::CellManager() + CellManager::CellManager(CellRenderer* cellRenderer) + : _cellRenderer(cellRenderer) { _cellSpawnerStorage.reserve(5); } - void CellManager::AddCellRenderer(const std::string& shader, const glm::vec3& worldSpawnPos) - { - if(RenderManager::GetInitStatus()) - { - _cellRenderer = Engine::RenderManager::AddCellRenderer(shader, worldSpawnPos); - } - else - { - Logger::Error("Failed", "CellRenderer", "RenderManager wasn't initialized!"); - } - } - void CellManager::AddCell(const CellParams& cellParams) { uint32 cellCount = CellSimParams::cellsAlive; @@ -318,4 +307,4 @@ namespace Engine Logger::Print("Cells alive: " + std::to_string(CellSimParams::cellsAlive)); Logger::Print("Excessive cell counter: " + std::to_string(_excessiveCells)); } -} \ No newline at end of file +} diff --git a/Engine/Physics/CellularAutomata/CellManager.hpp b/Engine/Physics/CellularAutomata/CellManager.hpp index e2b2c896..f3bc794d 100644 --- a/Engine/Physics/CellularAutomata/CellManager.hpp +++ b/Engine/Physics/CellularAutomata/CellManager.hpp @@ -3,7 +3,8 @@ #include "CellStorage.hpp" #include "Types.hpp" #include "GlobalParams.hpp" -#include "RenderManager.hpp" +#include "CellRenderer.hpp" +#include "Random.hpp" namespace Engine { @@ -22,7 +23,7 @@ namespace Engine void HandleWaterCell(uint32 index, const glm::u32vec3& cellPos); public: - CellManager(); + explicit CellManager(CellRenderer* cellRenderer); void AddCellRenderer(const std::string& shader, const glm::vec3& worldSpawnPos); void AddCell(const CellParams& cellParams); void AddCellWithoutRender(const CellParams& cellParams); @@ -35,4 +36,4 @@ namespace Engine void CreateCellWorld(); void PrintDebug(); }; -} \ No newline at end of file +} diff --git a/Engine/Rendering/Renderer/CellRenderer.cpp b/Engine/Rendering/Renderer/CellRenderer.cpp index 500614a4..e89de22d 100644 --- a/Engine/Rendering/Renderer/CellRenderer.cpp +++ b/Engine/Rendering/Renderer/CellRenderer.cpp @@ -4,14 +4,6 @@ namespace Engine { // ----- Private ----- - CellRenderer::CellRenderer(Shader* shader, const glm::vec3& worldSpawnPos) - : _verticeCount(36), _shader(shader), _worldSpawnPos(worldSpawnPos), _positionStorage{glm::vec3(0.0f)}, - _colorStorage{glm::vec3(1.0f)} - { - Logger::Info("Created", "Renderer", __func__); - InitGpuStorage(); - } - void CellRenderer::InitGpuStorage() { //Create and bind vao @@ -52,6 +44,14 @@ namespace Engine // ----- Public ----- + CellRenderer::CellRenderer(const std::string& shader, const glm::vec3& worldSpawnPos) + : _verticeCount(36), _shader(ResourceManager::GetShader(shader)), _worldSpawnPos(worldSpawnPos), _positionStorage{glm::vec3(0.0f)}, + _colorStorage{glm::vec3(1.0f)} + { + Logger::Info("Created", "Renderer", __func__); + InitGpuStorage(); + } + void CellRenderer::Flush(Renderer* sceneRenderer) { uint32 cellCount = CellSimParams::cellsAlive; @@ -102,4 +102,4 @@ namespace Engine _positionStorage.at(index) = _worldSpawnPos + glm::vec3(cellPos); _colorStorage.at(index) = cellColor; } -} \ No newline at end of file +} diff --git a/Engine/Rendering/Renderer/CellRenderer.hpp b/Engine/Rendering/Renderer/CellRenderer.hpp index d11699a3..c4598313 100644 --- a/Engine/Rendering/Renderer/CellRenderer.hpp +++ b/Engine/Rendering/Renderer/CellRenderer.hpp @@ -15,8 +15,6 @@ namespace Engine { class CellRenderer final : public Renderer { - friend class RenderManager; - private: Scope _vao; Scope _vboVert, _vboPos, _vboColor; @@ -28,14 +26,14 @@ namespace Engine std::array _positionStorage; std::array _colorStorage; - CellRenderer(Shader* shader, const glm::vec3& worldSpawnPos); - ~CellRenderer() override = default; - void InitGpuStorage(); void UploadGPUStorage(); public: - void Flush(Renderer* renderer) override; + CellRenderer(const std::string& shader, const glm::vec3& worldSpawnPos); + ~CellRenderer() override = default; + + void Flush(Renderer* sceneRenderer) override; void UpdateGPUStorage(uint32 index, const glm::u32vec3& cellPos, const glm::vec3& cellColor); }; -} \ No newline at end of file +} diff --git a/Engine/Rendering/Renderer/GridRenderer.cpp b/Engine/Rendering/Renderer/GridRenderer.cpp index 66f6f0b4..f22b7879 100644 --- a/Engine/Rendering/Renderer/GridRenderer.cpp +++ b/Engine/Rendering/Renderer/GridRenderer.cpp @@ -4,23 +4,6 @@ namespace Engine { // ----- Private ----- - GridRenderer::GridRenderer - ( - const uint32 width, - const uint32 height, - const uint32 quadSize, - const std::string& shader - ) - : _gridWidth(width), _gridHeight(height), _quadSize(quadSize), _quadAmountTotal(_gridWidth * _gridHeight), - _defaultColor(glm::vec3(0.1f, 0.1f, 0.1f)), _defaultGradientFactor(0.000025f), _shader(ResourceManager::GetShader(shader)), - _orthoProj(glm::ortho(0.0f, (float)WindowParams::WIDTH, 0.0f, (float)WindowParams::HEIGHT, -1.0f, 1.0f)), - _model(glm::scale(glm::mat4(1.0f), glm::vec3(glm::vec2((float)_quadSize), 0.0f))) - { - Logger::Info("Created", "Renderer", __func__); - _colorStorage.reserve(_quadAmountTotal); - InitGpuStorage(); - } - void GridRenderer::InitGpuStorage() { //Create vertice data @@ -62,6 +45,23 @@ namespace Engine // ----- Public ----- + GridRenderer::GridRenderer + ( + const uint32 width, + const uint32 height, + const uint32 quadSize, + const std::string& shader + ) + : _gridWidth(width), _gridHeight(height), _quadSize(quadSize), _quadAmountTotal(_gridWidth * _gridHeight), + _defaultColor(glm::vec3(0.1f, 0.1f, 0.1f)), _defaultGradientFactor(0.000025f), _shader(ResourceManager::GetShader(shader)), + _orthoProj(glm::ortho(0.0f, (float)WindowParams::WIDTH, 0.0f, (float)WindowParams::HEIGHT, -1.0f, 1.0f)), + _model(glm::scale(glm::mat4(1.0f), glm::vec3(glm::vec2((float)_quadSize), 0.0f))) + { + Logger::Info("Created", "Renderer", __func__); + _colorStorage.reserve(_quadAmountTotal); + InitGpuStorage(); + } + void GridRenderer::Flush(Renderer* renderer) { //Check for Wireframe-Mode @@ -131,4 +131,4 @@ namespace Engine _vboColor->Update(&_backupStorage[0], _backupStorage.size() * 4 * sizeof(float)); _vboColor->Unbind(); } -} \ No newline at end of file +} diff --git a/Engine/Rendering/Renderer/GridRenderer.hpp b/Engine/Rendering/Renderer/GridRenderer.hpp index 5442dd2b..8206ee7c 100644 --- a/Engine/Rendering/Renderer/GridRenderer.hpp +++ b/Engine/Rendering/Renderer/GridRenderer.hpp @@ -12,33 +12,31 @@ namespace Engine { class GridRenderer final : public Renderer { - friend class RenderManager; - - private: - uint32 _gridWidth, _gridHeight, _quadSize, _quadAmountTotal; - glm::vec3 _defaultColor; - float _defaultGradientFactor; - Shader* _shader; - - Scope _vao; - Scope _vboVert, _vboColor; - glm::mat4 _orthoProj, _model; - - // R G B GF - // GF := Gradient factor := how much the background gradient adds to the final color - std::vector _colorStorage; - std::vector _backupStorage; - - void InitGpuStorage(); - - public: - void Flush(Renderer* renderer) override; - void UpdateGpuStorage() const; - void Set(uint32 x, uint32 y, const glm::vec3& color); - void Reset(uint32 x, uint32 y); - void SetConfigAsDefault(); - void UploadDefaultConfig() const; - - GridRenderer(uint32 width, uint32 height, uint32 quadSize, const std::string& shader); + private: + uint32 _gridWidth, _gridHeight, _quadSize, _quadAmountTotal; + glm::vec3 _defaultColor; + float _defaultGradientFactor; + Shader* _shader; + + Scope _vao; + Scope _vboVert, _vboColor; + glm::mat4 _orthoProj, _model; + + // R G B GF + // GF := Gradient factor := how much the background gradient adds to the final color + std::vector _colorStorage; + std::vector _backupStorage; + + void InitGpuStorage(); + + public: + GridRenderer(uint32 width, uint32 height, uint32 quadSize, const std::string& shader); + + void Flush(Renderer* renderer) override; + void UpdateGpuStorage() const; + void Set(uint32 x, uint32 y, const glm::vec3& color); + void Reset(uint32 x, uint32 y); + void SetConfigAsDefault(); + void UploadDefaultConfig() const; }; -} \ No newline at end of file +} // namespace Engine diff --git a/Engine/Rendering/Renderer/ParticleRenderer.cpp b/Engine/Rendering/Renderer/ParticleRenderer.cpp index 4d37eb5b..87f988dc 100644 --- a/Engine/Rendering/Renderer/ParticleRenderer.cpp +++ b/Engine/Rendering/Renderer/ParticleRenderer.cpp @@ -4,28 +4,6 @@ namespace Engine { // ----- Private ----- - ParticleRenderer::ParticleRenderer - ( - uint32 count, float size, float speed, float gravityCompliance, float lifeLength, - float respawnThreshold, Texture* textureAtlas, Shader* shader, const glm::vec3& position - ) - : _count(count), _numberOfRows(textureAtlas->GetNumberOfRows()), _verticeCount(4), _size(size), - _speed(speed), _gravityCompliance(gravityCompliance), _lifeLength(lifeLength), - _respawnTreshold(respawnThreshold), _textureAtlas(textureAtlas), _shader(shader), _position(position) - { - Logger::Info("Created", "Renderer", __func__); - GenerateParticles(); - InitGpuStorage(); - } - - ParticleRenderer::~ParticleRenderer() - { - for(auto const& p : _particleStorage) - { - delete p; - } - } - void ParticleRenderer::InitGpuStorage() { //Create vertice data @@ -141,6 +119,29 @@ namespace Engine // ----- Public ----- + ParticleRenderer::ParticleRenderer + ( + uint32 count, float size, float speed, float gravityCompliance, float lifeLength, + float respawnThreshold, const std::string& textureAtlas, const std::string& shader, const glm::vec3& position + ) + : _textureAtlas(ResourceManager::GetTexture(textureAtlas)), _shader(ResourceManager::GetShader(shader)), + _count(count), _numberOfRows(_textureAtlas->GetNumberOfRows()), _verticeCount(4), _size(size), + _speed(speed), _gravityCompliance(gravityCompliance), _lifeLength(lifeLength), + _respawnTreshold(respawnThreshold), _position(position) + { + Logger::Info("Created", "Renderer", __func__); + GenerateParticles(); + InitGpuStorage(); + } + + ParticleRenderer::~ParticleRenderer() + { + for(auto const& p : _particleStorage) + { + delete p; + } + } + void ParticleRenderer::Flush(Renderer* sceneRenderer) { GLRenderSettings::DisableDepthtest(); diff --git a/Engine/Rendering/Renderer/ParticleRenderer.hpp b/Engine/Rendering/Renderer/ParticleRenderer.hpp index 20e577a4..cdfd3fe2 100644 --- a/Engine/Rendering/Renderer/ParticleRenderer.hpp +++ b/Engine/Rendering/Renderer/ParticleRenderer.hpp @@ -17,16 +17,14 @@ namespace Engine { class ParticleRenderer final : public Renderer { - friend class RenderManager; - private: Scope _vao; Scope _vboVert, _vboModel, _vboTex, _vboBlend; - uint32 _count, _numberOfRows, _verticeCount; - float _size, _speed, _gravityCompliance, _lifeLength, _respawnTreshold; Texture* _textureAtlas; Shader* _shader; + uint32 _count, _numberOfRows, _verticeCount; + float _size, _speed, _gravityCompliance, _lifeLength, _respawnTreshold; glm::vec3 _position; std::vector _particleStorage; @@ -34,19 +32,19 @@ namespace Engine std::vector _texOffsetStorage; std::vector _blendFactorStorage; - ParticleRenderer - ( - uint32 count, float size, float speed, float gravityCompliance, float lifeLength, - float respawnThreshold, Texture* textureAtlas, Shader* shader, const glm::vec3& position - ); - ~ParticleRenderer() override; - void InitGpuStorage(); void UpdateGpuStorage(); void GenerateParticles(); glm::mat4 GetModelViewMatrix(const Particle* particle); public: + ParticleRenderer + ( + uint32 count, float size, float speed, float gravityCompliance, float lifeLength, + float respawnThreshold, const std::string& textureAtlas, const std::string& shader, const glm::vec3& position + ); + ~ParticleRenderer() override; + void Flush(Renderer* sceneRenderer) override; }; -} \ No newline at end of file +} diff --git a/Engine/Rendering/Renderer/PixelRenderer.cpp b/Engine/Rendering/Renderer/PixelRenderer.cpp index 2e764320..8b3caa11 100644 --- a/Engine/Rendering/Renderer/PixelRenderer.cpp +++ b/Engine/Rendering/Renderer/PixelRenderer.cpp @@ -2,7 +2,7 @@ namespace Engine { - // ----- Private ----- + // ----- Public ----- PixelRenderer::PixelRenderer ( @@ -21,8 +21,6 @@ namespace Engine Logger::Info("Created", "Renderer", __func__); } - // ----- Public ----- - void PixelRenderer::Flush(Renderer* renderer) { //Commit texture changes diff --git a/Engine/Rendering/Renderer/PixelRenderer.hpp b/Engine/Rendering/Renderer/PixelRenderer.hpp index 9618679a..b629b436 100644 --- a/Engine/Rendering/Renderer/PixelRenderer.hpp +++ b/Engine/Rendering/Renderer/PixelRenderer.hpp @@ -13,12 +13,11 @@ namespace Engine { class PixelRenderer final : public Renderer { - friend class RenderManager; - private: uint32 _width, _height, _pxSize; Sprite _canvasSprite; + public: PixelRenderer ( uint32 width, @@ -28,7 +27,6 @@ namespace Engine const std::string& shader ); - public: void Flush(Renderer* renderer) override; void Set(uint32 x, uint32 y, const glm::vec3& color) const; void SetArea(uint32 x_start, uint32 x_end, uint32 y_start, uint32 y_end, const glm::vec3& color) const; @@ -36,4 +34,4 @@ namespace Engine void SetScreen(const glm::vec3& color) const; void ClearScreen() const; }; -} \ No newline at end of file +} diff --git a/Engine/Rendering/Renderer/RenderManager.cpp b/Engine/Rendering/Renderer/RenderManager.cpp index 1fa8a6bc..d87adce7 100644 --- a/Engine/Rendering/Renderer/RenderManager.cpp +++ b/Engine/Rendering/Renderer/RenderManager.cpp @@ -7,7 +7,7 @@ namespace Engine void RenderManager::Init2D() { _rendererStorage.clear(); - _rendererStorage.reserve(5); + _rendererStorage.reserve(10); _initialized = true; } @@ -42,132 +42,13 @@ namespace Engine GLRenderSettings::ClearBuffers(); } - bool RenderManager::GetInitStatus() - { - return _initialized; - } - - SceneRenderer* RenderManager::AddSceneRenderer() - { - _sceneRenderer = new SceneRenderer(); - _rendererStorage.push_back(_sceneRenderer); - - return _sceneRenderer; - } - - ShadowRenderer* RenderManager::AddShadowRenderer(uint32 resolution, const glm::mat4& orthoProj, const std::string& shader) - { - _shadowRenderer = new ShadowRenderer(resolution, resolution, orthoProj, ResourceManager::GetShader(shader)); - _rendererStorage.push_back(_shadowRenderer); - _sceneRenderer->AddLightProjection(_shadowRenderer->GetLightProjection()); - - return _shadowRenderer; - } - - SpriteRenderer* RenderManager::AddSpriteRenderer() - { - _spriteRenderer = new SpriteRenderer(); - _rendererStorage.push_back(_spriteRenderer); - - return _spriteRenderer; - } - - WaterRenderer* RenderManager::AddWaterRenderer() - { - _waterRenderer = new WaterRenderer(); - _rendererStorage.push_back(_waterRenderer); - - return _waterRenderer; - } - - ParticleRenderer* RenderManager::AddParticleRenderer - ( - uint32 count, float size, float speed, float gravityCompliance, float lifeLength, - float respawnThreshold, const std::string& textureAtlas, const std::string& shader, const glm::vec3& position - ) - { - _particleRenderer = new ParticleRenderer - ( - count, - size, - speed, - gravityCompliance, - lifeLength, - respawnThreshold, - ResourceManager::GetTexture(textureAtlas), - ResourceManager::GetShader(shader), - position - ); - _rendererStorage.push_back(_particleRenderer); - - return _particleRenderer; - } - - CellRenderer* RenderManager::AddCellRenderer(const std::string& shader, const glm::vec3& worldSpawnPos) - { - _cellRenderer = new CellRenderer(ResourceManager::GetShader(shader), worldSpawnPos); - _rendererStorage.push_back(_cellRenderer); - - return _cellRenderer; - } - - PixelRenderer* RenderManager::AddPixelRenderer - ( - const uint32 width, const uint32 height, const uint32 pxSize, - const std::string& bgTexture, const std::string& shader - ) - { - _pixelRenderer = new PixelRenderer(width, height, pxSize, bgTexture, shader); - _rendererStorage.push_back(_pixelRenderer); - - return _pixelRenderer; - } - - GridRenderer* RenderManager::AddGridRenderer(uint32 width, uint32 height, uint32 quadSize, const std::string& shader) - { - _gridRenderer = new GridRenderer(width, height, quadSize, shader); - _rendererStorage.push_back(_gridRenderer); - - return _gridRenderer; - } - - void RenderManager::RenderScene() - { - _sceneRenderer->Flush(nullptr); - } - - void RenderManager::RenderShadows() - { - _shadowRenderer->Flush((Renderer*)_sceneRenderer); - } - - void RenderManager::RenderSprites() + void RenderManager::Submit(Renderer *renderer) { - _spriteRenderer->Flush(nullptr); + _rendererStorage.push_back(renderer); } - void RenderManager::RenderWater() - { - _waterRenderer->Flush((Renderer*)_sceneRenderer); - } - - void RenderManager::RenderParticles() - { - _particleRenderer->Flush((Renderer*)_sceneRenderer); - } - - void RenderManager::RenderCells() - { - _cellRenderer->Flush((Renderer*)_sceneRenderer); - } - - void RenderManager::RenderPixels() - { - _pixelRenderer->Flush(nullptr); - } - - void RenderManager::RenderGrid() + bool RenderManager::GetInitStatus() { - _gridRenderer->Flush(nullptr); + return _initialized; } } diff --git a/Engine/Rendering/Renderer/RenderManager.hpp b/Engine/Rendering/Renderer/RenderManager.hpp index d5b4a0d4..153572d0 100644 --- a/Engine/Rendering/Renderer/RenderManager.hpp +++ b/Engine/Rendering/Renderer/RenderManager.hpp @@ -1,16 +1,8 @@ #pragma once -#include "Types.hpp" -#include "ErrorManager.hpp" -#include "glm.hpp" +#include "GLRenderSettings.hpp" +#include "GlobalParams.hpp" #include "Renderer.hpp" -#include "SceneRenderer.hpp" -#include "SpriteRenderer.hpp" -#include "WaterRenderer.hpp" -#include "ParticleRenderer.hpp" -#include "CellRenderer.hpp" -#include "PixelRenderer.hpp" -#include "GridRenderer.hpp" #include @@ -20,14 +12,6 @@ namespace Engine { private: inline static std::vector _rendererStorage = std::vector(); - inline static SceneRenderer* _sceneRenderer = nullptr; - inline static ShadowRenderer* _shadowRenderer = nullptr; - inline static SpriteRenderer* _spriteRenderer = nullptr; - inline static WaterRenderer* _waterRenderer = nullptr; - inline static ParticleRenderer* _particleRenderer = nullptr; - inline static CellRenderer* _cellRenderer = nullptr; - inline static PixelRenderer* _pixelRenderer = nullptr; - inline static GridRenderer* _gridRenderer = nullptr; inline static bool _initialized = false; public: @@ -37,32 +21,7 @@ namespace Engine static void Init3D(); static void CleanUp(); static void PrepareFrame(); + static void Submit(Renderer* renderer); static bool GetInitStatus(); - - static SceneRenderer* AddSceneRenderer(); - static ShadowRenderer* AddShadowRenderer(uint32 resolution, const glm::mat4& orthoProj, const std::string& shader); - static SpriteRenderer* AddSpriteRenderer(); - static WaterRenderer* AddWaterRenderer(); - static ParticleRenderer* AddParticleRenderer - ( - uint32 count, float size, float speed, float gravityCompliance, float lifeLength, - float respawnThreshold, const std::string& textureAtlas, const std::string& shader, const glm::vec3& position - ); - static CellRenderer* AddCellRenderer(const std::string& shader, const glm::vec3& worldSpawnPos); - static PixelRenderer* AddPixelRenderer - ( - uint32 width, uint32 height, uint32 pxSize, - const std::string& bgTexture, const std::string& shader - ); - static GridRenderer* AddGridRenderer(uint32 width, uint32 height, uint32 quadSize, const std::string& shader); - - static void RenderScene(); - static void RenderShadows(); - static void RenderSprites(); - static void RenderWater(); - static void RenderParticles(); - static void RenderCells(); - static void RenderPixels(); - static void RenderGrid(); }; -} \ No newline at end of file +} diff --git a/Engine/Rendering/Renderer/SceneRenderer.cpp b/Engine/Rendering/Renderer/SceneRenderer.cpp index c5e1b1d7..82f444ad 100644 --- a/Engine/Rendering/Renderer/SceneRenderer.cpp +++ b/Engine/Rendering/Renderer/SceneRenderer.cpp @@ -4,23 +4,6 @@ namespace Engine { // ----- Private ----- - SceneRenderer::SceneRenderer() - : _moveFactor(0.0f), _waveSpeed(0.0f), _perspProj(glm::perspective(glm::radians(45.0f), Window::GetAspectRatio(), RenderParams::nearPlane, RenderParams::farPlane)), - _lightProj(0.0f), _terrainModel(nullptr), _waterModel(nullptr), _planeModel(nullptr), _terrainShader(nullptr), _modelShader(nullptr), _waterShader(nullptr) - { - Logger::Info("Created", "Renderer", __func__); - } - - SceneRenderer::~SceneRenderer() - { - for(auto const& model : _modelStorage) - delete model; - - delete _terrainModel; - delete _waterModel; - delete _planeModel; - } - void SceneRenderer::FlushModel(Model* model, Shader* shader) { //Get textures and bind them @@ -130,6 +113,23 @@ namespace Engine // ----- Public ----- + SceneRenderer::SceneRenderer() + : _moveFactor(0.0f), _waveSpeed(0.0f), _perspProj(glm::perspective(glm::radians(45.0f), Window::GetAspectRatio(), RenderParams::nearPlane, RenderParams::farPlane)), + _lightProj(0.0f), _terrainModel(nullptr), _waterModel(nullptr), _planeModel(nullptr), _terrainShader(nullptr), _modelShader(nullptr), _waterShader(nullptr) + { + Logger::Info("Created", "Renderer", __func__); + } + + SceneRenderer::~SceneRenderer() + { + for(auto const& model : _modelStorage) + delete model; + + delete _terrainModel; + delete _waterModel; + delete _planeModel; + } + void SceneRenderer::Flush(Renderer* renderer) { //Check for Wireframe-Mode diff --git a/Engine/Rendering/Renderer/SceneRenderer.hpp b/Engine/Rendering/Renderer/SceneRenderer.hpp index b81353bc..1156ab4f 100644 --- a/Engine/Rendering/Renderer/SceneRenderer.hpp +++ b/Engine/Rendering/Renderer/SceneRenderer.hpp @@ -21,8 +21,6 @@ namespace Engine { class SceneRenderer final : public Renderer { - friend class RenderManager; - private: float _moveFactor, _waveSpeed; glm::mat4 _perspProj, _lightProj; @@ -32,14 +30,14 @@ namespace Engine Model *_terrainModel, *_waterModel, *_planeModel; Shader *_terrainShader, *_modelShader, *_waterShader; - SceneRenderer(); - ~SceneRenderer() override; - void FlushModel(Model* model, Shader* shader); void FlushWater(); void UpdateMoveFactor(); public: + SceneRenderer(); + ~SceneRenderer() override; + void Flush(Renderer* renderer) override; void FlushModels(Shader* shader); void FlushCubemap(); @@ -78,4 +76,4 @@ namespace Engine [[nodiscard]] Shader* GetWaterShader(); [[nodiscard]] glm::mat4 GetProjMatrix(); }; -} \ No newline at end of file +} diff --git a/Engine/Rendering/Renderer/ShadowRenderer.cpp b/Engine/Rendering/Renderer/ShadowRenderer.cpp index 969b26ea..88e70d93 100644 --- a/Engine/Rendering/Renderer/ShadowRenderer.cpp +++ b/Engine/Rendering/Renderer/ShadowRenderer.cpp @@ -4,10 +4,22 @@ namespace Engine { // ----- Private ----- - ShadowRenderer::ShadowRenderer(uint32 width, uint32 height, const glm::mat4& orthoProj, Shader* shader) + void ShadowRenderer::StartFrame() + { + _fbo->Bind(_shadowWidth, _shadowHeight); + } + + void ShadowRenderer::EndFrame() + { + _fbo->Unbind(); + } + + // ----- Public ----- + + ShadowRenderer::ShadowRenderer(uint32 width, uint32 height, const glm::mat4& orthoProj, const std::string& shader) : _lightView(glm::lookAt(LightParams::position, LightParams::target, glm::vec3(0.0f, 1.0f, 0.0f))), _lightProjection(orthoProj * _lightView), - _shadowWidth(width), _shadowHeight(height), _shadowShader(shader) + _shadowWidth(width), _shadowHeight(height), _shadowShader(ResourceManager::GetShader(shader)) { //Create and configure framebuffer _fbo = MakeScope(); @@ -25,18 +37,6 @@ namespace Engine Logger::Info("Created", "Renderer", __func__); } - void ShadowRenderer::StartFrame() - { - _fbo->Bind(_shadowWidth, _shadowHeight); - } - - void ShadowRenderer::EndFrame() - { - _fbo->Unbind(); - } - - // ----- Public ----- - void ShadowRenderer::Flush(Renderer* sceneRenderer) { //Render scene to shadow framebuffer @@ -55,4 +55,4 @@ namespace Engine { return _lightProjection; } -} \ No newline at end of file +} diff --git a/Engine/Rendering/Renderer/ShadowRenderer.hpp b/Engine/Rendering/Renderer/ShadowRenderer.hpp index 1bfee1a1..67709359 100644 --- a/Engine/Rendering/Renderer/ShadowRenderer.hpp +++ b/Engine/Rendering/Renderer/ShadowRenderer.hpp @@ -14,23 +14,22 @@ namespace Engine { class ShadowRenderer final : public Renderer { - friend class RenderManager; - private: glm::mat4 _lightView, _lightProjection; Scope _fbo; uint32 _shadowWidth; uint32 _shadowHeight; Shader* _shadowShader; - - ShadowRenderer(uint32 width, uint32 height, const glm::mat4& orthoProj, Shader* shader); void StartFrame(); void EndFrame(); public: + ShadowRenderer(uint32 width, uint32 height, const glm::mat4& orthoProj, const std::string& shader); + void Flush(Renderer* sceneRenderer) override; + [[nodiscard]] Texture* GetDepthTexture() const; [[nodiscard]] glm::mat4 GetLightProjection() const; }; -} \ No newline at end of file +} diff --git a/Engine/Rendering/Renderer/SpriteRenderer.cpp b/Engine/Rendering/Renderer/SpriteRenderer.cpp index fb0b2dac..83d5c50f 100644 --- a/Engine/Rendering/Renderer/SpriteRenderer.cpp +++ b/Engine/Rendering/Renderer/SpriteRenderer.cpp @@ -2,15 +2,13 @@ namespace Engine { - // ----- Private ----- + // ----- Public ----- SpriteRenderer::SpriteRenderer() { Logger::Info("Created", "Renderer", __func__); } - // ----- Public ----- - void SpriteRenderer::Flush(Renderer* renderer) { GLRenderSettings::DisableWireframe(); diff --git a/Engine/Rendering/Renderer/SpriteRenderer.hpp b/Engine/Rendering/Renderer/SpriteRenderer.hpp index 210d6cc0..83bd45ed 100644 --- a/Engine/Rendering/Renderer/SpriteRenderer.hpp +++ b/Engine/Rendering/Renderer/SpriteRenderer.hpp @@ -14,15 +14,12 @@ namespace Engine { class SpriteRenderer final : public Renderer { - friend class RenderManager; - private: std::vector _spriteStorage; - SpriteRenderer(); - public: + SpriteRenderer(); void Flush(Renderer* renderer) override; void AddSprite(const glm::vec2& size, const glm::vec2& pos, Texture* texture, Shader* shader); }; -} \ No newline at end of file +} diff --git a/Engine/Rendering/Renderer/WaterRenderer.cpp b/Engine/Rendering/Renderer/WaterRenderer.cpp index d943adc5..b66f27c5 100644 --- a/Engine/Rendering/Renderer/WaterRenderer.cpp +++ b/Engine/Rendering/Renderer/WaterRenderer.cpp @@ -4,13 +4,6 @@ namespace Engine { // ----- Private ----- - WaterRenderer::WaterRenderer() - { - Logger::Info("Created", "Renderer", __func__); - InitReflectionFBO(); - InitRefractionFBO(); - } - void WaterRenderer::InitReflectionFBO() { //Create and configure framebuffer @@ -113,6 +106,13 @@ namespace Engine // ----- Public ----- + WaterRenderer::WaterRenderer() + { + Logger::Info("Created", "Renderer", __func__); + InitReflectionFBO(); + InitRefractionFBO(); + } + void WaterRenderer::Flush(Renderer* sceneRenderer) { GLRenderSettings::EnableClipDistance(GL_CLIP_DISTANCE0); @@ -135,4 +135,4 @@ namespace Engine { return _refractFBO->GetDepthTexture(); } -} \ No newline at end of file +} diff --git a/Engine/Rendering/Renderer/WaterRenderer.hpp b/Engine/Rendering/Renderer/WaterRenderer.hpp index 9c494c9b..240fd683 100644 --- a/Engine/Rendering/Renderer/WaterRenderer.hpp +++ b/Engine/Rendering/Renderer/WaterRenderer.hpp @@ -10,8 +10,6 @@ namespace Engine { class WaterRenderer final : public Renderer { - friend class RenderManager; - private: Scope _reflectFBO, _refractFBO; const uint32 _reflectionWidth = 1024; @@ -22,8 +20,6 @@ namespace Engine const glm::vec4 _reflectionClipPlane = glm::vec4(0.0f, 1.0f, 0.0f, -_waterHeight); const glm::vec4 _refractionClipPlane = glm::vec4(0.0f, -1.0f, 0.0f, _waterHeight); - WaterRenderer(); - void InitReflectionFBO(); void InitRefractionFBO(); void StartReflectionFrame(); @@ -34,10 +30,12 @@ namespace Engine void RenderRefractionFrame(SceneRenderer* sceneRenderer); public: + WaterRenderer(); + void Flush(Renderer* sceneRenderer) override; [[nodiscard]] Texture* GetReflectTexture() const; [[nodiscard]] Texture* GetRefractTexture() const; [[nodiscard]] Texture* GetRefractDepthTexture() const; }; -} \ No newline at end of file +} diff --git a/Scripts/Profile.sh b/Scripts/Profile.sh new file mode 100755 index 00000000..45798093 --- /dev/null +++ b/Scripts/Profile.sh @@ -0,0 +1,13 @@ +#!/bin/bash + +SCRIPT_DIR=$(dirname "$(realpath "$0")") +PROJECT_ROOT=$(realpath "$SCRIPT_DIR") +cd "$PROJECT_ROOT" || exit + +if [ -z "$1" ]; then + echo "Fehler: Kein Argument übergeben. Bitte als erstes Argument die PID angeben." >&2 + exit 1 +fi + +perf record -F 500 -p $1 --call-graph dwarf sleep 5 +hotspot perf.data