diff --git a/rawrbox.render/include/rawrbox/render/bindless.hpp b/rawrbox.render/include/rawrbox/render/bindless.hpp index 1b9e80a6..065e0419 100644 --- a/rawrbox.render/include/rawrbox/render/bindless.hpp +++ b/rawrbox.render/include/rawrbox/render/bindless.hpp @@ -62,7 +62,6 @@ namespace rawrbox { // SIGNATURES ------ static void createSignatures(); - static void bindSignatures(); // ----------------- static uint32_t internalRegister(Diligent::ITextureView* view, rawrbox::TEXTURE_TYPE type); @@ -80,6 +79,10 @@ namespace rawrbox { static void update(); + // SIGNATURES + static void bindSignatures(); + // ---------------- + // TEXTURES ------- static void registerTexture(rawrbox::TextureBase& texture); static void registerTexture(rawrbox::TextureRender& texture); diff --git a/rawrbox.render/include/rawrbox/render/cameras/base.hpp b/rawrbox.render/include/rawrbox/render/cameras/base.hpp index 4e746a12..1e0dadf6 100644 --- a/rawrbox.render/include/rawrbox/render/cameras/base.hpp +++ b/rawrbox.render/include/rawrbox/render/cameras/base.hpp @@ -3,6 +3,8 @@ #include #include #include +#include +#include #include #include @@ -11,6 +13,9 @@ #include +#define CREATE_FLAGS(name, value) \ + const uint32_t name = 1 << value; + namespace rawrbox { struct CameraStaticUniforms { // Uniforms that won't be updated that frequently rawrbox::Matrix4x4 gProjection = {}; @@ -26,6 +31,12 @@ namespace rawrbox { bool operator!=(const CameraStaticUniforms& other) const { return !operator==(other); } }; + namespace CameraLayers { + // USER DEFINED + RB_RENDER_CAMERA_LAYERS(CREATE_FLAGS) + // ------------ + }; // namespace CameraLayers + struct CameraUniforms { rawrbox::Matrix4x4 gView = {}; rawrbox::Matrix4x4 gViewInv = {}; @@ -47,6 +58,8 @@ namespace rawrbox { class CameraBase { protected: + bool _enabled = true; + rawrbox::Vector3f _pos = {}; rawrbox::Vector4f _angle = {}; @@ -55,12 +68,15 @@ namespace rawrbox { rawrbox::Matrix4x4 _world = {}; + uint32_t _layers = 0; // None by default, it's up to the user to use this or not + + // Renderer ---- + std::unique_ptr _renderTarget = nullptr; + // -------------------------- + float _z_near = 0.01F; float _z_far = 100.F; - Diligent::RefCntAutoPtr _staticUniforms; - Diligent::RefCntAutoPtr _uniforms; - // LOGGER ------ std::unique_ptr _logger = std::make_unique("RawrBox-Camera"); // ------------- @@ -68,14 +84,18 @@ namespace rawrbox { virtual void updateMtx(); virtual rawrbox::CameraStaticUniforms getStaticData(); + virtual void initializeBuffers(); + public: - virtual ~CameraBase(); + static Diligent::RefCntAutoPtr staticUniforms; + static Diligent::RefCntAutoPtr uniforms; - CameraBase() = default; + CameraBase(const rawrbox::Vector2u& renderSize, bool depth = true); CameraBase(CameraBase&&) = default; CameraBase& operator=(CameraBase&&) = default; CameraBase(const CameraBase&) = delete; CameraBase& operator=(const CameraBase&) = delete; + virtual ~CameraBase(); // UTILS ----- virtual void setPos(const rawrbox::Vector3f& pos); @@ -100,10 +120,23 @@ namespace rawrbox { [[nodiscard]] virtual rawrbox::Vector3f worldToScreen(const rawrbox::Vector3f& pos) const; [[nodiscard]] virtual rawrbox::Vector3f screenToWorld(const rawrbox::Vector2f& screen_pos, const rawrbox::Vector3f& origin = {0, 0, 0}) const; + + virtual bool isEnabled() const; + virtual void setEnabled(bool enabled); + + virtual uint32_t getLayers() const; + virtual void setLayers(uint32_t layers); + virtual bool shouldRenderLayer(uint32_t layer) const; // ---------------- - [[nodiscard]] virtual Diligent::IBuffer* uniforms() const; - [[nodiscard]] virtual Diligent::IBuffer* staticUniforms() const; + // RENDER TARGET ---- + virtual void begin(); + virtual void end(); + + [[nodiscard]] virtual Diligent::ITextureView* getDepth() const; + [[nodiscard]] virtual Diligent::ITextureView* getColor(bool rt = false) const; + [[nodiscard]] virtual rawrbox::TextureRender* getRenderTarget() const; + // ------------ virtual void initialize(); diff --git a/rawrbox.render/include/rawrbox/render/cameras/perspective.hpp b/rawrbox.render/include/rawrbox/render/cameras/perspective.hpp index ecb5b05f..1c6489c1 100644 --- a/rawrbox.render/include/rawrbox/render/cameras/perspective.hpp +++ b/rawrbox.render/include/rawrbox/render/cameras/perspective.hpp @@ -8,9 +8,7 @@ namespace rawrbox { class CameraPerspective : public rawrbox::CameraBase { protected: - rawrbox::Vector2u _winSize = {}; float _FOV = 60.F; - void updateMtx() override; public: @@ -20,7 +18,7 @@ namespace rawrbox { CameraPerspective& operator=(CameraPerspective&&) = default; ~CameraPerspective() override = default; - explicit CameraPerspective(const rawrbox::Vector2u& winSize, float FOV = 60.F, float near = 0.01F, float far = 100.F); + explicit CameraPerspective(const rawrbox::Vector2u& renderSize, float FOV = 60.F, float near = 0.01F, float far = 100.F, bool depth = true); [[nodiscard]] rawrbox::Vector3f worldToScreen(const rawrbox::Vector3f& pos) const override; [[nodiscard]] rawrbox::Vector3f screenToWorld(const rawrbox::Vector2f& screenPos, const rawrbox::Vector3f& origin = {0, 0, 0}) const override; diff --git a/rawrbox.render/include/rawrbox/render/plugins/base.hpp b/rawrbox.render/include/rawrbox/render/plugins/base.hpp index 96a7b7e1..a1912f53 100644 --- a/rawrbox.render/include/rawrbox/render/plugins/base.hpp +++ b/rawrbox.render/include/rawrbox/render/plugins/base.hpp @@ -1,6 +1,7 @@ #pragma once #include +#include #include #include @@ -40,8 +41,8 @@ namespace rawrbox { virtual void resize(const rawrbox::Vector2u& renderSize); virtual void upload(); - virtual void preRender(); - virtual void postRender(rawrbox::TextureRender& renderTarget); + virtual void preRender(const rawrbox::CameraBase& camera); + virtual void postRender(const rawrbox::CameraBase& camera); virtual void update(); diff --git a/rawrbox.render/include/rawrbox/render/plugins/clustered.hpp b/rawrbox.render/include/rawrbox/render/plugins/clustered.hpp index bb537e7b..da8d8a5d 100644 --- a/rawrbox.render/include/rawrbox/render/plugins/clustered.hpp +++ b/rawrbox.render/include/rawrbox/render/plugins/clustered.hpp @@ -71,7 +71,7 @@ namespace rawrbox { void signatures(std::vector& sig) override; void bindStatic(Diligent::IPipelineResourceSignature& sig) override; - void preRender() override; + void preRender(const rawrbox::CameraBase& camera) override; std::string getID() override; }; diff --git a/rawrbox.render/include/rawrbox/render/plugins/particle_engine.hpp b/rawrbox.render/include/rawrbox/render/plugins/particle_engine.hpp index a757b800..fa38bab7 100644 --- a/rawrbox.render/include/rawrbox/render/plugins/particle_engine.hpp +++ b/rawrbox.render/include/rawrbox/render/plugins/particle_engine.hpp @@ -50,7 +50,7 @@ namespace rawrbox { void signatures(std::vector& sig) override; void bindStatic(Diligent::IPipelineResourceSignature& sig) override; - void preRender() override; + void preRender(const rawrbox::CameraBase& camera) override; [[nodiscard]] Diligent::IPipelineResourceSignature* getSignature(bool dynamic = true) const; [[nodiscard]] Diligent::IShaderResourceBinding* getBind(bool dynamic = true) const; diff --git a/rawrbox.render/include/rawrbox/render/plugins/post_process.hpp b/rawrbox.render/include/rawrbox/render/plugins/post_process.hpp index 076ba70d..30aa4cb8 100644 --- a/rawrbox.render/include/rawrbox/render/plugins/post_process.hpp +++ b/rawrbox.render/include/rawrbox/render/plugins/post_process.hpp @@ -25,7 +25,7 @@ namespace rawrbox { void signatures(std::vector& sig) override; void bindStatic(Diligent::IPipelineResourceSignature& sig) override; - void postRender(rawrbox::TextureRender& render) override; + void postRender(const rawrbox::CameraBase& camera) override; // PLUGIN UTILS ---- template diff --git a/rawrbox.render/include/rawrbox/render/render_config.hpp b/rawrbox.render/include/rawrbox/render/render_config.hpp index a89e70bf..f4be9c87 100644 --- a/rawrbox.render/include/rawrbox/render/render_config.hpp +++ b/rawrbox.render/include/rawrbox/render/render_config.hpp @@ -40,3 +40,10 @@ #define RB_RENDER_THREAD_GROUP_SIZE (RB_RENDER_CLUSTERS_X_THREADS * RB_RENDER_CLUSTERS_Y_THREADS * RB_RENDER_CLUSTERS_Z_THREADS) // ---------------- + +// CAMERA ----- +// Add more layers if needed, you can then check if the camera should draw your model by checking if the layer is enabled +#define RB_RENDER_CAMERA_LAYERS(flag) \ + flag(MY_LAYER_1, 1) \ + flag(MY_LAYER_2, 2) +// ---------------- diff --git a/rawrbox.render/include/rawrbox/render/renderer.hpp b/rawrbox.render/include/rawrbox/render/renderer.hpp index 39fe6e02..1367d842 100644 --- a/rawrbox.render/include/rawrbox/render/renderer.hpp +++ b/rawrbox.render/include/rawrbox/render/renderer.hpp @@ -43,10 +43,6 @@ namespace rawrbox { std::map> _renderPlugins = {}; // -------------- - // Post process renderer ---- - std::unique_ptr _render = nullptr; - // -------------------------- - #ifdef _DEBUG // QUERIES --- std::unordered_map> _query = {}; @@ -64,8 +60,8 @@ namespace rawrbox { std::map _introList = {{"./assets/textures/rawrbox.webp", {1.4F, false}}}; // rawrbox intro, always the first //---- - std::function _drawCall = nullptr; - std::function _tempRender = nullptr; + std::function _drawCall = nullptr; + std::function _tempRender = nullptr; rawrbox::Colorf _clearColor = rawrbox::Colors::Black(); @@ -88,11 +84,14 @@ namespace rawrbox { // OTHER HANDLES std::unique_ptr _logger = std::make_unique("RawrBox-Renderer"); - std::unique_ptr _camera = nullptr; std::unique_ptr _stencil = nullptr; std::unique_ptr _GPUBlit = nullptr; // ------------- + // CAMERAS --- + std::vector> _cameras = {}; + // ---------- + // INTRO ------ virtual void playIntro(); virtual void introComplete(); @@ -151,7 +150,7 @@ namespace rawrbox { [[nodiscard]] virtual const std::map>& getPlugins() const; // ----------------------------------- - virtual void setDrawCall(std::function call); + virtual void setDrawCall(std::function call); virtual void update(); virtual void render(); @@ -163,15 +162,17 @@ namespace rawrbox { // CAMERA ------ template - T* setupCamera(CallbackArgs&&... args) { - this->_camera = std::make_unique(std::forward(args)...); - this->setMainCamera(this->_camera.get()); + T* createCamera(CallbackArgs&&... args) { + if (this->_initialized) CRITICAL_RAWRBOX("'createCamera' must be called before initializing the renderer!"); + auto camera = std::make_unique(std::forward(args)...); - return dynamic_cast(this->_camera.get()); + auto cameraPtr = camera.get(); + this->_cameras.push_back(std::move(camera)); + return dynamic_cast(cameraPtr); } - virtual void setMainCamera(rawrbox::CameraBase* camera) const; - [[nodiscard]] virtual rawrbox::CameraBase* camera() const; + virtual void setActiveCamera(rawrbox::CameraBase* camera) const; + [[nodiscard]] virtual rawrbox::CameraBase* getActiveCamera() const; // ---------------- // Utils ---- @@ -184,9 +185,6 @@ namespace rawrbox { // WARNING: NOT THREAD SAFE!! [[nodiscard]] virtual Diligent::IRenderDevice* device() const; - [[nodiscard]] virtual Diligent::ITextureView* getDepth() const; - [[nodiscard]] virtual Diligent::ITextureView* getColor(bool rt = false) const; - [[nodiscard]] virtual std::filesystem::path getShadersDirectory() const; [[nodiscard]] virtual const Diligent::RENDER_DEVICE_TYPE& getRenderType() const; diff --git a/rawrbox.render/src/bindless.cpp b/rawrbox.render/src/bindless.cpp index cc9c7b00..38d53630 100644 --- a/rawrbox.render/src/bindless.cpp +++ b/rawrbox.render/src/bindless.cpp @@ -85,11 +85,7 @@ namespace rawrbox { // Create signatures ------ createSignatures(); - // ------------- - - // Bind signatures ------ - bindSignatures(); - // ------------- + // ------------ } void BindlessManager::shutdown() { @@ -111,8 +107,6 @@ namespace rawrbox { // SIGNATURES --------- void BindlessManager::createSignatures() { auto* renderer = rawrbox::RENDERER; - - auto* camera = renderer->camera(); auto* device = renderer->device(); Diligent::PipelineResourceSignatureDesc PRSDesc; @@ -127,12 +121,9 @@ namespace rawrbox { {Diligent::SHADER_TYPE_PIXEL, "Constants", 1, Diligent::SHADER_RESOURCE_TYPE_CONSTANT_BUFFER, Diligent::SHADER_RESOURCE_VARIABLE_TYPE_STATIC}, {Diligent::SHADER_TYPE_PIXEL, "g_Textures", RB_RENDER_MAX_TEXTURES, Diligent::SHADER_RESOURCE_TYPE_TEXTURE_SRV, Diligent::SHADER_RESOURCE_VARIABLE_TYPE_MUTABLE, Diligent::PIPELINE_RESOURCE_FLAG_RUNTIME_ARRAY}, - }; - if (camera != nullptr) { - resources.emplace_back(Diligent::SHADER_TYPE_VERTEX | Diligent::SHADER_TYPE_PIXEL | Diligent::SHADER_TYPE_GEOMETRY, "Camera", 1, Diligent::SHADER_RESOURCE_TYPE_CONSTANT_BUFFER, Diligent::SHADER_RESOURCE_VARIABLE_TYPE_STATIC, Diligent::PIPELINE_RESOURCE_FLAG_NO_DYNAMIC_BUFFERS); - resources.emplace_back(Diligent::SHADER_TYPE_VERTEX | Diligent::SHADER_TYPE_PIXEL | Diligent::SHADER_TYPE_GEOMETRY, "SCamera", 1, Diligent::SHADER_RESOURCE_TYPE_CONSTANT_BUFFER, Diligent::SHADER_RESOURCE_VARIABLE_TYPE_STATIC, Diligent::PIPELINE_RESOURCE_FLAG_NO_DYNAMIC_BUFFERS); - } + {Diligent::SHADER_TYPE_VERTEX | Diligent::SHADER_TYPE_PIXEL | Diligent::SHADER_TYPE_GEOMETRY, "Camera", 1, Diligent::SHADER_RESOURCE_TYPE_CONSTANT_BUFFER, Diligent::SHADER_RESOURCE_VARIABLE_TYPE_STATIC, Diligent::PIPELINE_RESOURCE_FLAG_NO_DYNAMIC_BUFFERS}, + {Diligent::SHADER_TYPE_VERTEX | Diligent::SHADER_TYPE_PIXEL | Diligent::SHADER_TYPE_GEOMETRY, "SCamera", 1, Diligent::SHADER_RESOURCE_TYPE_CONSTANT_BUFFER, Diligent::SHADER_RESOURCE_VARIABLE_TYPE_STATIC, Diligent::PIPELINE_RESOURCE_FLAG_NO_DYNAMIC_BUFFERS}}; // Add extra signatures ---- for (const auto& plugin : renderer->getPlugins()) { @@ -162,22 +153,17 @@ namespace rawrbox { } void BindlessManager::bindSignatures() { - auto* renderer = rawrbox::RENDERER; - auto* camera = renderer->camera(); - // Setup graphic binds --- signature->GetStaticVariableByName(Diligent::SHADER_TYPE_VERTEX, "Constants")->Set(signatureBufferVertex); signature->GetStaticVariableByName(Diligent::SHADER_TYPE_VERTEX, "SkinnedConstants")->Set(signatureBufferVertexSkinned); - if (camera != nullptr) { - signature->GetStaticVariableByName(Diligent::SHADER_TYPE_VERTEX, "Camera")->Set(camera->uniforms()); - signature->GetStaticVariableByName(Diligent::SHADER_TYPE_PIXEL, "Camera")->Set(camera->uniforms()); - signature->GetStaticVariableByName(Diligent::SHADER_TYPE_GEOMETRY, "Camera")->Set(camera->uniforms()); + signature->GetStaticVariableByName(Diligent::SHADER_TYPE_VERTEX, "Camera")->Set(rawrbox::CameraBase::uniforms); + signature->GetStaticVariableByName(Diligent::SHADER_TYPE_PIXEL, "Camera")->Set(rawrbox::CameraBase::uniforms); + signature->GetStaticVariableByName(Diligent::SHADER_TYPE_GEOMETRY, "Camera")->Set(rawrbox::CameraBase::uniforms); - signature->GetStaticVariableByName(Diligent::SHADER_TYPE_VERTEX, "SCamera")->Set(camera->staticUniforms()); - signature->GetStaticVariableByName(Diligent::SHADER_TYPE_PIXEL, "SCamera")->Set(camera->staticUniforms()); - signature->GetStaticVariableByName(Diligent::SHADER_TYPE_GEOMETRY, "SCamera")->Set(camera->staticUniforms()); - } + signature->GetStaticVariableByName(Diligent::SHADER_TYPE_VERTEX, "SCamera")->Set(rawrbox::CameraBase::staticUniforms); + signature->GetStaticVariableByName(Diligent::SHADER_TYPE_PIXEL, "SCamera")->Set(rawrbox::CameraBase::staticUniforms); + signature->GetStaticVariableByName(Diligent::SHADER_TYPE_GEOMETRY, "SCamera")->Set(rawrbox::CameraBase::staticUniforms); signature->GetStaticVariableByName(Diligent::SHADER_TYPE_PIXEL, "Constants")->Set(signatureBufferPixel); // ------------ diff --git a/rawrbox.render/src/cameras/base.cpp b/rawrbox.render/src/cameras/base.cpp index 3846f0b8..308ba5d7 100644 --- a/rawrbox.render/src/cameras/base.cpp +++ b/rawrbox.render/src/cameras/base.cpp @@ -5,45 +5,67 @@ #include namespace rawrbox { - CameraBase::~CameraBase() { - RAWRBOX_DESTROY(this->_uniforms); - RAWRBOX_DESTROY(this->_staticUniforms); + Diligent::RefCntAutoPtr CameraBase::staticUniforms; + Diligent::RefCntAutoPtr CameraBase::uniforms; + + CameraBase::CameraBase(const rawrbox::Vector2u& renderSize, bool depth) { + this->_renderTarget = std::make_unique(renderSize, depth); } + CameraBase::~CameraBase() { this->_renderTarget.reset(); } + void CameraBase::initialize() { - if (this->_staticUniforms != nullptr) CRITICAL_RAWRBOX("Camera already initialized!"); - { - auto staticData = this->getStaticData(); + if (this->_renderTarget == nullptr) CRITICAL_RAWRBOX("Render target not initialized!"); + this->_renderTarget->upload(Diligent::TEX_FORMAT_RGBA8_UNORM); + + // ADD GPU PICKING TEXTURE + auto idIndex = this->_renderTarget->addTexture(Diligent::TEX_FORMAT_RGBA8_UNORM); + this->_renderTarget->addView(idIndex, Diligent::TEXTURE_VIEW_RENDER_TARGET); + // -------- + + this->initializeBuffers(); + } - Diligent::BufferDesc CBDesc; - CBDesc.Name = "rawrbox::Camera::Static::Uniforms"; - CBDesc.Usage = Diligent::USAGE_IMMUTABLE; - CBDesc.BindFlags = Diligent::BIND_UNIFORM_BUFFER; - CBDesc.Size = sizeof(rawrbox::CameraStaticUniforms); + void CameraBase::initializeBuffers() { // Initialize with a template? + if (rawrbox::RENDERER == nullptr) CRITICAL_RAWRBOX("Renderer not initialized!"); - Diligent::BufferData bData; - bData.DataSize = CBDesc.Size; - bData.pData = &staticData; + auto* device = rawrbox::RENDERER->device(); + if (device == nullptr) CRITICAL_RAWRBOX("Device not initialized!"); - rawrbox::RENDERER->device()->CreateBuffer(CBDesc, &bData, &this->_staticUniforms); - } + // These are shared across all the cameras. For performance reasons, we won't support different cameras (for now) + if (staticUniforms != nullptr || uniforms != nullptr) CRITICAL_RAWRBOX("Camera buffers already initialized!"); + auto staticData = this->getStaticData(); - { - Diligent::BufferDesc CBDesc; - CBDesc.Name = "rawrbox::Camera::Uniforms"; - CBDesc.Usage = Diligent::USAGE_DEFAULT; - CBDesc.BindFlags = Diligent::BIND_UNIFORM_BUFFER; - CBDesc.Size = sizeof(rawrbox::CameraUniforms); + // STATIC BUFFER --- + Diligent::BufferDesc StaticDesc; + StaticDesc.Name = "rawrbox::Camera::Static::Uniforms"; + StaticDesc.Usage = Diligent::USAGE_IMMUTABLE; + StaticDesc.BindFlags = Diligent::BIND_UNIFORM_BUFFER; + StaticDesc.Size = sizeof(rawrbox::CameraStaticUniforms); - rawrbox::RENDERER->device()->CreateBuffer(CBDesc, nullptr, &this->_uniforms); - } + Diligent::BufferData sData; + sData.DataSize = StaticDesc.Size; + sData.pData = &staticData; + + device->CreateBuffer(StaticDesc, &sData, &staticUniforms); + // ------------ + + // DYNAMIC BUFFER --- + Diligent::BufferDesc CBDesc; + CBDesc.Name = "rawrbox::Camera::Uniforms"; + CBDesc.Usage = Diligent::USAGE_DEFAULT; + CBDesc.BindFlags = Diligent::BIND_UNIFORM_BUFFER; + CBDesc.Size = sizeof(rawrbox::CameraUniforms); + + device->CreateBuffer(CBDesc, nullptr, &uniforms); + // ------------ // BARRIER ----- - rawrbox::BarrierUtils::barrier({{this->_staticUniforms, Diligent::RESOURCE_STATE_UNKNOWN, Diligent::RESOURCE_STATE_CONSTANT_BUFFER, Diligent::STATE_TRANSITION_FLAG_UPDATE_STATE}, - {this->_uniforms, Diligent::RESOURCE_STATE_UNKNOWN, Diligent::RESOURCE_STATE_CONSTANT_BUFFER, Diligent::STATE_TRANSITION_FLAG_UPDATE_STATE}}); + rawrbox::BarrierUtils::barrier({{staticUniforms, Diligent::RESOURCE_STATE_UNKNOWN, Diligent::RESOURCE_STATE_CONSTANT_BUFFER, Diligent::STATE_TRANSITION_FLAG_UPDATE_STATE}, + {uniforms, Diligent::RESOURCE_STATE_UNKNOWN, Diligent::RESOURCE_STATE_CONSTANT_BUFFER, Diligent::STATE_TRANSITION_FLAG_UPDATE_STATE}}); // ----------- - this->_logger->info("Initializing camera"); + this->_logger->info("Initializing camera buffers"); } void CameraBase::updateMtx() { CRITICAL_RAWRBOX("Not implemented"); }; @@ -134,8 +156,41 @@ namespace rawrbox { this->updateBuffer(); } + rawrbox::Vector3f CameraBase::worldToScreen(const rawrbox::Vector3f& /*pos*/) const { + CRITICAL_RAWRBOX("Not implemented"); + } + + rawrbox::Vector3f CameraBase::screenToWorld(const rawrbox::Vector2f& /*screen_pos*/, const rawrbox::Vector3f& /*origin*/) const { + CRITICAL_RAWRBOX("Not implemented"); + } + + bool CameraBase::isEnabled() const { return this->_enabled; } + void CameraBase::setEnabled(bool enabled) { this->_enabled = enabled; } + + uint32_t CameraBase::getLayers() const { return this->_layers; } + void CameraBase::setLayers(uint32_t layers) { this->_layers = layers; } + bool CameraBase::shouldRenderLayer(uint32_t layer) const { return (this->_layers & layer) > 1; } + // ----------- + + // RENDER TARGET ---- + void CameraBase::begin() { + if (this->_renderTarget == nullptr) CRITICAL_RAWRBOX("Render target not initialized!"); + this->_renderTarget->startRecord(); + } + + void CameraBase::end() { + if (this->_renderTarget == nullptr) CRITICAL_RAWRBOX("Render target not initialized!"); + this->_renderTarget->stopRecord(); + } + + Diligent::ITextureView* CameraBase::getDepth() const { return this->_renderTarget->getDepth(); } + Diligent::ITextureView* CameraBase::getColor(bool rt) const { return rt ? this->_renderTarget->getRT() : this->_renderTarget->getHandle(); } + + rawrbox::TextureRender* CameraBase::getRenderTarget() const { return this->_renderTarget.get(); } + // ---------------- + void CameraBase::updateBuffer() { - if (this->_uniforms == nullptr) CRITICAL_RAWRBOX("Buffer not initialized! Did you call initialize?"); + if (uniforms == nullptr) CRITICAL_RAWRBOX("Buffer not initialized! Did you call initialize?"); auto view = rawrbox::Matrix4x4::mtxTranspose(this->getViewMtx()); auto viewInv = rawrbox::Matrix4x4::mtxInverse(this->getViewMtx()); @@ -150,22 +205,12 @@ namespace rawrbox { data.gPos = this->getPos(); data.gDeltaTime = rawrbox::DELTA_TIME; - rawrbox::BarrierUtils::barrier({{this->_uniforms, Diligent::RESOURCE_STATE_CONSTANT_BUFFER, Diligent::RESOURCE_STATE_COPY_DEST, Diligent::STATE_TRANSITION_FLAG_UPDATE_STATE}}); - rawrbox::RENDERER->context()->UpdateBuffer(this->_uniforms, 0, sizeof(rawrbox::CameraUniforms), &data, Diligent::RESOURCE_STATE_TRANSITION_MODE_VERIFY); - rawrbox::BarrierUtils::barrier({{this->_uniforms, Diligent::RESOURCE_STATE_COPY_DEST, Diligent::RESOURCE_STATE_CONSTANT_BUFFER, Diligent::STATE_TRANSITION_FLAG_UPDATE_STATE}}); + rawrbox::BarrierUtils::barrier({{uniforms, Diligent::RESOURCE_STATE_CONSTANT_BUFFER, Diligent::RESOURCE_STATE_COPY_DEST, Diligent::STATE_TRANSITION_FLAG_UPDATE_STATE}}); + rawrbox::RENDERER->context()->UpdateBuffer(uniforms, 0, sizeof(rawrbox::CameraUniforms), &data, Diligent::RESOURCE_STATE_TRANSITION_MODE_VERIFY); + rawrbox::BarrierUtils::barrier({{uniforms, Diligent::RESOURCE_STATE_COPY_DEST, Diligent::RESOURCE_STATE_CONSTANT_BUFFER, Diligent::STATE_TRANSITION_FLAG_UPDATE_STATE}}); } void CameraBase::update() {} - - rawrbox::Vector3f CameraBase::worldToScreen(const rawrbox::Vector3f& /*pos*/) const { - CRITICAL_RAWRBOX("Not implemented"); - } - - rawrbox::Vector3f CameraBase::screenToWorld(const rawrbox::Vector2f& /*screen_pos*/, const rawrbox::Vector3f& /*origin*/) const { - CRITICAL_RAWRBOX("Not implemented"); - } - - Diligent::IBuffer* CameraBase::uniforms() const { return this->_uniforms; } - Diligent::IBuffer* CameraBase::staticUniforms() const { return this->_staticUniforms; } // ---------------- + } // namespace rawrbox diff --git a/rawrbox.render/src/cameras/perspective.cpp b/rawrbox.render/src/cameras/perspective.cpp index cd3bbe04..ca708dc5 100644 --- a/rawrbox.render/src/cameras/perspective.cpp +++ b/rawrbox.render/src/cameras/perspective.cpp @@ -4,11 +4,11 @@ namespace rawrbox { // NOLINTBEGIN(clang-analyzer-optin.cplusplus.VirtualCall) - CameraPerspective::CameraPerspective(const rawrbox::Vector2u& winSize, float FOV, float near, float far) : _winSize(winSize), _FOV(FOV) { + CameraPerspective::CameraPerspective(const rawrbox::Vector2u& renderSize, float FOV, float near, float far, bool depth) : rawrbox::CameraBase(renderSize, depth), _FOV(FOV) { this->_z_near = near; this->_z_far = far; - this->_projection = rawrbox::Matrix4x4::mtxProj(FOV, static_cast(winSize.x) / static_cast(winSize.y), this->_z_near, this->_z_far); + this->_projection = rawrbox::Matrix4x4::mtxProj(FOV, static_cast(renderSize.x) / static_cast(renderSize.y), this->_z_near, this->_z_far); this->updateMtx(); } // NOLINTEND(clang-analyzer-optin.cplusplus.VirtualCall) @@ -23,18 +23,19 @@ namespace rawrbox { } rawrbox::Vector3f CameraPerspective::worldToScreen(const rawrbox::Vector3f& pos) const { - return rawrbox::Matrix4x4::mtxProject(pos, this->_view, this->_projection, {0, 0, this->_winSize.x, this->_winSize.y}); + const auto& size = this->_renderTarget->getSize(); + return rawrbox::Matrix4x4::mtxProject(pos, this->_view, this->_projection, {0, 0, size.x, size.y}); } rawrbox::Vector3f CameraPerspective::screenToWorld(const rawrbox::Vector2f& screenPos, const rawrbox::Vector3f& origin) const { - rawrbox::Vector3f plane_normal = {0, 1, 0}; + static constexpr rawrbox::Vector3f plane_normal = {0, 1, 0}; // get our pos and force aim downwards, the getForward() seems to behave odd when aiming full down - auto campos = this->getPos(); + const auto& campos = this->getPos(); + const auto& size = this->_renderTarget->getSize(); rawrbox::Matrix4x4 viewproj_inv = this->getViewProjMtx().inverse(); - auto winPos = this->_winSize.cast(); - + auto winPos = size.cast(); float screenx_clip = 2.F * (screenPos.x / winPos.x) - 1.F; float screeny_clip = 1.F - 2.F * (screenPos.y) / winPos.y; diff --git a/rawrbox.render/src/plugins/base.cpp b/rawrbox.render/src/plugins/base.cpp index fb48831f..3983b5dd 100644 --- a/rawrbox.render/src/plugins/base.cpp +++ b/rawrbox.render/src/plugins/base.cpp @@ -17,8 +17,8 @@ namespace rawrbox { void RenderPlugin::resize(const rawrbox::Vector2u& /*renderSize*/) {} void RenderPlugin::upload() {} - void RenderPlugin::preRender() {} - void RenderPlugin::postRender(rawrbox::TextureRender& /*renderTarget*/) {} + void RenderPlugin::preRender(const rawrbox::CameraBase& /*camera*/) {} + void RenderPlugin::postRender(const rawrbox::CameraBase& /*camera*/) {} void RenderPlugin::update() {} } // namespace rawrbox diff --git a/rawrbox.render/src/plugins/clustered.cpp b/rawrbox.render/src/plugins/clustered.cpp index a17c83b1..5c611f27 100644 --- a/rawrbox.render/src/plugins/clustered.cpp +++ b/rawrbox.render/src/plugins/clustered.cpp @@ -91,13 +91,12 @@ namespace rawrbox { sig.GetStaticVariableByName(Diligent::SHADER_TYPE_PIXEL, "DecalsConstants")->Set(rawrbox::DECALS::uniforms); } - void ClusteredPlugin::preRender() { + void ClusteredPlugin::preRender(const rawrbox::CameraBase& camera) { auto* renderer = rawrbox::RENDERER; - auto* camera = renderer->camera(); - auto* context = renderer->context(); - if (renderer == nullptr) CRITICAL_RAWRBOX("Renderer not initialized!"); - if (camera == nullptr) CRITICAL_RAWRBOX("Camera not initialized!"); + + auto* context = renderer->context(); + if (context == nullptr) CRITICAL_RAWRBOX("Context not initialized!"); if (this->_clusterBuildingComputeProgram == nullptr || this->_cullingComputeProgram == nullptr || this->_cullingResetProgram == nullptr) CRITICAL_RAWRBOX("Compute pipelines not initialized, did you call 'initialize'"); @@ -118,7 +117,7 @@ namespace rawrbox { // ----------------------- // Rebuild clusters --- - auto proj = camera->getProjMtx(); + auto proj = camera.getProjMtx(); if (this->_oldProj != proj) { this->_oldProj = proj; @@ -233,8 +232,8 @@ namespace rawrbox { // ---------------------- // Compute bind --- - this->_signature->GetStaticVariableByName(Diligent::SHADER_TYPE_COMPUTE, "Camera")->Set(rawrbox::MAIN_CAMERA->uniforms()); - this->_signature->GetStaticVariableByName(Diligent::SHADER_TYPE_COMPUTE, "SCamera")->Set(rawrbox::MAIN_CAMERA->staticUniforms()); + this->_signature->GetStaticVariableByName(Diligent::SHADER_TYPE_COMPUTE, "Camera")->Set(rawrbox::CameraBase::uniforms); + this->_signature->GetStaticVariableByName(Diligent::SHADER_TYPE_COMPUTE, "SCamera")->Set(rawrbox::CameraBase::staticUniforms); this->_signature->GetStaticVariableByName(Diligent::SHADER_TYPE_COMPUTE, "Clusters")->Set(this->getClustersBuffer(false)); this->_signature->GetStaticVariableByName(Diligent::SHADER_TYPE_COMPUTE, "ClusterDataGrid")->Set(this->getDataGridBuffer(false)); diff --git a/rawrbox.render/src/plugins/particle_engine.cpp b/rawrbox.render/src/plugins/particle_engine.cpp index b0173462..87a3fb9c 100644 --- a/rawrbox.render/src/plugins/particle_engine.cpp +++ b/rawrbox.render/src/plugins/particle_engine.cpp @@ -46,8 +46,8 @@ namespace rawrbox { // ---------------------- // Compute bind --- - this->_signature->GetStaticVariableByName(Diligent::SHADER_TYPE_COMPUTE, "Camera")->Set(rawrbox::MAIN_CAMERA->uniforms()); - this->_signature->GetStaticVariableByName(Diligent::SHADER_TYPE_COMPUTE, "SCamera")->Set(rawrbox::MAIN_CAMERA->staticUniforms()); + this->_signature->GetStaticVariableByName(Diligent::SHADER_TYPE_COMPUTE, "Camera")->Set(rawrbox::CameraBase::uniforms); + this->_signature->GetStaticVariableByName(Diligent::SHADER_TYPE_COMPUTE, "SCamera")->Set(rawrbox::CameraBase::staticUniforms); this->_signature->GetStaticVariableByName(Diligent::SHADER_TYPE_COMPUTE, "EmitterConstants")->Set(this->_uniforms); @@ -109,7 +109,7 @@ namespace rawrbox { sig.GetStaticVariableByName(Diligent::SHADER_TYPE_GEOMETRY, "EmitterConstants")->Set(this->_uniforms); } - void ParticleEnginePlugin::preRender() { + void ParticleEnginePlugin::preRender(const rawrbox::CameraBase& /*camera*/) { for (auto* emitter : this->_registeredEmitters) { if (emitter == nullptr || !emitter->isEnabled()) continue; diff --git a/rawrbox.render/src/plugins/post_process.cpp b/rawrbox.render/src/plugins/post_process.cpp index 7b7e349a..3191aafb 100644 --- a/rawrbox.render/src/plugins/post_process.cpp +++ b/rawrbox.render/src/plugins/post_process.cpp @@ -36,14 +36,14 @@ namespace rawrbox { sig.GetStaticVariableByName(Diligent::SHADER_TYPE_PIXEL, "PostProcessConstants")->Set(this->_buffer); } - void PostProcessPlugin::postRender(rawrbox::TextureRender& renderTexture) { - for (auto& process : this->_postProcesses) { + void PostProcessPlugin::postRender(const rawrbox::CameraBase& camera) { + /*for (auto& process : this->_postProcesses) { if (!process->isEnabled()) continue; renderTexture.startRecord(false, 1); process->applyEffect(renderTexture); renderTexture.stopRecord(); - } + }*/ } // Post utils ---- diff --git a/rawrbox.render/src/renderer.cpp b/rawrbox.render/src/renderer.cpp index c9bf3c9a..124102f1 100644 --- a/rawrbox.render/src/renderer.cpp +++ b/rawrbox.render/src/renderer.cpp @@ -41,7 +41,6 @@ namespace rawrbox { RendererBase::RendererBase(Diligent::RENDER_DEVICE_TYPE type, Diligent::NativeWindow window, const rawrbox::Vector2u& size, const rawrbox::Vector2u& monitorSize, const rawrbox::Colorf& clearColor) : _clearColor(clearColor), _size(size), _monitorSize(monitorSize), _window(window), _type(type) {} RendererBase::~RendererBase() { - this->_render.reset(); this->_stencil.reset(); this->_logger.reset(); this->_GPUBlit.reset(); @@ -241,11 +240,6 @@ namespace rawrbox { // -------------- // ---------------------- - // Setup camera ----- - if (this->_camera == nullptr) CRITICAL_RAWRBOX("No camera found!"); - this->_camera->initialize(); - // ------------------ - // Init plugins --- for (auto& plugin : this->_renderPlugins) { if (plugin.second == nullptr) continue; @@ -258,6 +252,17 @@ namespace rawrbox { rawrbox::BindlessManager::init(); // ----------------- + // Init cameras --- + this->setActiveCamera(this->_cameras.back().get()); + for (auto& camera : this->_cameras) { + camera->initialize(); + } + // ----------------- + + // Bind signatures --- + rawrbox::BindlessManager::bindSignatures(); + // ------- + // Init default textures --- this->_logger->info("Initializing default textures"); @@ -335,15 +340,6 @@ namespace rawrbox { this->_stencil->upload(); // ------------------ - // Setup renderer -- - this->_render = std::make_unique(this->_size); // TODO: RESCALE - this->_render->upload(Diligent::TEX_FORMAT_RGBA8_UNORM); - - // GPU PICKING TEXTURE - auto idIndex = this->_render->addTexture(Diligent::TEX_FORMAT_RGBA8_UNORM); - this->_render->addView(idIndex, Diligent::TEXTURE_VIEW_RENDER_TARGET); - // -------- - this->playIntro(); this->_initialized = true; } @@ -370,7 +366,7 @@ namespace rawrbox { const std::map>& RendererBase::getPlugins() const { return this->_renderPlugins; } // ----------------------------------- - void RendererBase::setDrawCall(std::function call) { this->_drawCall = std::move(call); } + void RendererBase::setDrawCall(std::function call) { this->_drawCall = std::move(call); } void RendererBase::update() { if (this->_currentIntro != nullptr) { @@ -389,7 +385,12 @@ namespace rawrbox { return; } } else { - if (this->_camera != nullptr) this->_camera->update(); + // Update cameras --- + for (auto& camera : this->_cameras) { + if (!camera->isEnabled()) continue; + camera->update(); + } + // ----------------------- // Update plugins -- for (auto& plugin : this->_renderPlugins) { @@ -403,6 +404,7 @@ namespace rawrbox { void RendererBase::render() { if (this->_swapChain == nullptr || this->_context == nullptr || this->_device == nullptr) CRITICAL_RAWRBOX("Failed to bind swapChain / context / device! Did you call 'init' ?"); if (this->_drawCall == nullptr) CRITICAL_RAWRBOX("Missing draw call! Did you call 'setDrawCall' ?"); + if (rawrbox::MAIN_CAMERA == nullptr || this->_cameras.empty()) CRITICAL_RAWRBOX("Missing cameras! Did you call 'createCamera' ?"); // Clear backbuffer ---- this->clear(); @@ -412,70 +414,46 @@ namespace rawrbox { rawrbox::BindlessManager::update(); // -------------------- - // Update camera buffer -- - this->_camera->updateBuffer(); - // ----------- - - // Perform pre-render -- - for (auto& plugin : this->_renderPlugins) { - if (plugin.second == nullptr || !plugin.second->isEnabled()) continue; -#ifdef _DEBUG - // this->_context->BeginDebugGroup(plugin.first.c_str()); -#endif - plugin.second->preRender(); -#ifdef _DEBUG - // this->_context->EndDebugGroup(); -#endif - } - // ----------------------- - // Commit graphics signature -- this->_context->CommitShaderResources(rawrbox::BindlessManager::signatureBind, Diligent::RESOURCE_STATE_TRANSITION_MODE_VERIFY); // ----------------------- - // Perform world -- -#ifdef _DEBUG - // this->_context->BeginDebugGroup("OPAQUE"); - // this->beginQuery("OPAQUE"); -#endif - this->_render->startRecord(); - this->_drawCall(rawrbox::DrawPass::PASS_WORLD); - this->_render->stopRecord(); -#ifdef _DEBUG - // this->endQuery("OPAQUE"); - // this->_context->EndDebugGroup(); -#endif - // ----------------- + for (auto& camera : this->_cameras) { + if (!camera->isEnabled()) continue; - // Perform post-render -- - for (auto& plugin : this->_renderPlugins) { - if (plugin.second == nullptr || !plugin.second->isEnabled()) continue; -#ifdef _DEBUG - // this->_context->BeginDebugGroup(plugin.first.c_str()); -#endif - plugin.second->postRender(*this->_render); -#ifdef _DEBUG - // this->_context->EndDebugGroup(); -#endif + // Update camera buffer -- + camera->updateBuffer(); + // ----------- + + // Perform pre-render -- + for (auto& plugin : this->_renderPlugins) { + if (plugin.second == nullptr || !plugin.second->isEnabled()) continue; + plugin.second->preRender(*camera); + } + // ----------------------- + + // Perform world -- + camera->begin(); + this->_drawCall(*camera, rawrbox::DrawPass::PASS_WORLD); + camera->end(); + // ----------------- + + // Perform post-render -- + for (auto& plugin : this->_renderPlugins) { + if (plugin.second == nullptr || !plugin.second->isEnabled()) continue; + plugin.second->postRender(*camera); + } + // ----------------------- } - // ----------------------- - // Render world ---- - rawrbox::RenderUtils::renderQUAD(*this->_render); + // Render main camera ---- + rawrbox::RenderUtils::renderQUAD(*rawrbox::MAIN_CAMERA->getRenderTarget()); // ------------------ - // Perform overlay -- -#ifdef _DEBUG - // this->_context->BeginDebugGroup("OVERLAY"); - // this->beginQuery("OVERLAY"); -#endif - this->_drawCall(rawrbox::DrawPass::PASS_OVERLAY); + // Perform overlay, only MAIN camera does it -- + this->_drawCall(*rawrbox::MAIN_CAMERA, rawrbox::DrawPass::PASS_OVERLAY); if (this->_stencil != nullptr) this->_stencil->render(); -#ifdef _DEBUG - // this->endQuery("OVERLAY"); - // this->_context->EndDebugGroup(); -#endif - // ------------------ + // --------------------------------------------- // Submit --- this->frame(); @@ -522,7 +500,7 @@ namespace rawrbox { this->_tempRender = this->_drawCall; // ------------- - this->_drawCall = [this](const rawrbox::DrawPass& pass) { + this->_drawCall = [this](const rawrbox::CameraBase& /*camera*/, const rawrbox::DrawPass& pass) { if (pass != rawrbox::DrawPass::PASS_OVERLAY) return; auto screenSize = this->_size.cast(); @@ -668,22 +646,15 @@ namespace rawrbox { // ---------------- // Utils ---- - void RendererBase::setMainCamera(rawrbox::CameraBase* camera) const { rawrbox::MAIN_CAMERA = camera; } - rawrbox::CameraBase* RendererBase::camera() const { return this->_camera.get(); } + void RendererBase::setActiveCamera(rawrbox::CameraBase* camera) const { rawrbox::MAIN_CAMERA = camera; } + rawrbox::CameraBase* RendererBase::getActiveCamera() const { return rawrbox::MAIN_CAMERA; } + rawrbox::Stencil* RendererBase::stencil() const { return this->_stencil.get(); } Diligent::IDeviceContext* RendererBase::context() const { return this->_context; } Diligent::ISwapChain* RendererBase::swapChain() const { return this->_swapChain; } Diligent::IRenderDevice* RendererBase::device() const { return this->_device; } - Diligent::ITextureView* RendererBase::getDepth() const { - return this->_render->getDepth(); - } - - Diligent::ITextureView* RendererBase::getColor(bool rt) const { - return rt ? this->_render->getRT() : this->_render->getHandle(); - } - std::filesystem::path RendererBase::getShadersDirectory() const { return "./assets/shaders"; } @@ -711,8 +682,8 @@ namespace rawrbox { void RendererBase::setVSync(bool vsync) { this->_vsync = vsync; } void RendererBase::gpuPick(const rawrbox::Vector2i& pos, const std::function& callback) { - if (this->_render == nullptr) CRITICAL_RAWRBOX("Render target texture not initialized"); - if (callback == nullptr) CRITICAL_RAWRBOX("Render target texture not initialized"); + if (rawrbox::MAIN_CAMERA == nullptr) CRITICAL_RAWRBOX("Main camera not initialized"); + if (callback == nullptr) CRITICAL_RAWRBOX("Invalid callback"); auto size = this->_size.cast(); if (pos.x < 0 || pos.y < 0 || pos.x >= size.x || pos.y >= size.y) CRITICAL_RAWRBOX("Outside of window range"); @@ -723,7 +694,7 @@ namespace rawrbox { MapRegion.MaxX = MapRegion.MinX + RB_RENDER_GPU_PICK_SAMPLE_SIZE; MapRegion.MaxY = MapRegion.MinY + RB_RENDER_GPU_PICK_SAMPLE_SIZE; - auto* tex = this->_render->getTexture(1); // GPU pick texture + auto* tex = rawrbox::MAIN_CAMERA->getRenderTarget()->getTexture(1); // GPU pick texture this->_GPUBlit->copy(tex, &MapRegion, [this, callback]() { this->_GPUBlit->blit(nullptr, [callback](const uint8_t* pixels, const uint64_t stride) { uint32_t max = 0; diff --git a/samples/001-stencil/src/game.cpp b/samples/001-stencil/src/game.cpp index 12a37775..be9750eb 100644 --- a/samples/001-stencil/src/game.cpp +++ b/samples/001-stencil/src/game.cpp @@ -38,7 +38,7 @@ namespace stencil { // Setup renderer auto* render = window->createRenderer(rawrbox::Color::RGBAHex(0x443355FF)); render->onIntroCompleted = [this]() { this->loadContent(); }; - render->setDrawCall([this](const rawrbox::DrawPass& pass) { + render->setDrawCall([this](const rawrbox::CameraBase& /*camera*/, const rawrbox::DrawPass& pass) { if (pass == rawrbox::DrawPass::PASS_OVERLAY) { this->drawOverlay(); } else if (pass == rawrbox::DrawPass::PASS_WORLD) { @@ -48,7 +48,7 @@ namespace stencil { // --------------- // Setup camera -- - auto* cam = render->setupCamera(render->getSize()); + auto* cam = render->createCamera(render->getSize()); cam->setPos({-2.F, 5.F, -3.5F}); cam->setAngle({0.F, rawrbox::MathUtils::toRad(-45), 0.F, 0.F}); // --------------- diff --git a/samples/002-generated-models/src/game.cpp b/samples/002-generated-models/src/game.cpp index 06a2bfce..97e5277e 100644 --- a/samples/002-generated-models/src/game.cpp +++ b/samples/002-generated-models/src/game.cpp @@ -35,7 +35,7 @@ namespace model { // Setup renderer auto* render = window->createRenderer(); render->onIntroCompleted = [this]() { this->loadContent(); }; - render->setDrawCall([this](const rawrbox::DrawPass& pass) { + render->setDrawCall([this](const rawrbox::CameraBase& /*camera*/, const rawrbox::DrawPass& pass) { if (pass == rawrbox::DrawPass::PASS_WORLD) { this->drawWorld(); } else { @@ -45,7 +45,7 @@ namespace model { // --------------- // Setup camera - auto* cam = render->setupCamera(*window); + auto* cam = render->createCamera(*window); cam->setPos({0.F, 6.F, -6.F}); cam->setAngle({0.F, rawrbox::MathUtils::toRad(-55), 0.F, 0.F}); cam->onMovementStart = []() { fmt::print("Camera start\n"); }; diff --git a/samples/003-light/src/game.cpp b/samples/003-light/src/game.cpp index b07da3fb..506e73f1 100644 --- a/samples/003-light/src/game.cpp +++ b/samples/003-light/src/game.cpp @@ -38,7 +38,7 @@ namespace light { auto* render = window->createRenderer(); render->addPlugin(); render->onIntroCompleted = [this]() { this->loadContent(); }; - render->setDrawCall([this](const rawrbox::DrawPass& pass) { + render->setDrawCall([this](const rawrbox::CameraBase& /*camera*/, const rawrbox::DrawPass& pass) { if (pass == rawrbox::DrawPass::PASS_WORLD) { this->drawWorld(); } else { @@ -48,7 +48,7 @@ namespace light { // --------------- // Setup camera - auto* cam = render->setupCamera(*window); + auto* cam = render->createCamera(*window); cam->setPos({0.F, 5.F, -5.F}); cam->setAngle({0.F, rawrbox::MathUtils::toRad(-45), 0.F, 0.F}); // -------------- diff --git a/samples/004-instancing/src/game.cpp b/samples/004-instancing/src/game.cpp index dc1c2d29..4f41b074 100644 --- a/samples/004-instancing/src/game.cpp +++ b/samples/004-instancing/src/game.cpp @@ -39,14 +39,14 @@ namespace instance_test { // Setup renderer auto* render = window->createRenderer(); render->onIntroCompleted = [this]() { this->loadContent(); }; - render->setDrawCall([this](const rawrbox::DrawPass& pass) { + render->setDrawCall([this](const rawrbox::CameraBase& /*camera*/, const rawrbox::DrawPass& pass) { if (pass != rawrbox::DrawPass::PASS_WORLD) return; this->drawWorld(); }); // --------------- // Setup camera - auto* cam = render->setupCamera(*window); + auto* cam = render->createCamera(*window); cam->setPos({0.F, 5.F, -5.F}); cam->setAngle({0.F, rawrbox::MathUtils::toRad(-45), 0.F, 0.F}); // -------------- diff --git a/samples/005-post-process/src/game.cpp b/samples/005-post-process/src/game.cpp index a864bed9..b0582516 100644 --- a/samples/005-post-process/src/game.cpp +++ b/samples/005-post-process/src/game.cpp @@ -48,7 +48,7 @@ namespace post_process { this->_noise = postProcess->add(0.1F); // ----------------------- - render->setDrawCall([this](const rawrbox::DrawPass& pass) { + render->setDrawCall([this](const rawrbox::CameraBase& /*camera*/, const rawrbox::DrawPass& pass) { if (pass == rawrbox::DrawPass::PASS_WORLD) { this->drawWorld(); } else { @@ -61,7 +61,7 @@ namespace post_process { // --------------- // Setup camera - auto* cam = render->setupCamera(*window); + auto* cam = render->createCamera(*window); cam->setPos({0.F, 5.F, -5.F}); cam->setAngle({0.F, rawrbox::MathUtils::toRad(-45), 0.F, 0.F}); // -------------- diff --git a/samples/006-decals/src/game.cpp b/samples/006-decals/src/game.cpp index 66a8c760..93a2070d 100644 --- a/samples/006-decals/src/game.cpp +++ b/samples/006-decals/src/game.cpp @@ -41,7 +41,7 @@ namespace decal_test { auto* render = window->createRenderer(); render->addPlugin(); render->onIntroCompleted = [this]() { this->loadContent(); }; - render->setDrawCall([this](const rawrbox::DrawPass& pass) { + render->setDrawCall([this](const rawrbox::CameraBase& /*camera*/, const rawrbox::DrawPass& pass) { if (pass == rawrbox::DrawPass::PASS_WORLD) { this->drawWorld(); } else { @@ -51,7 +51,7 @@ namespace decal_test { // --------------- // Setup camera - auto* cam = render->setupCamera(*window); + auto* cam = render->createCamera(*window); cam->setPos({0.F, 5.F, -5.F}); cam->setAngle({0.F, rawrbox::MathUtils::toRad(-45), 0.F, 0.F}); // -------------- diff --git a/samples/007-particle-system/src/game.cpp b/samples/007-particle-system/src/game.cpp index 83065e84..bef48691 100644 --- a/samples/007-particle-system/src/game.cpp +++ b/samples/007-particle-system/src/game.cpp @@ -35,14 +35,14 @@ namespace particle_system { auto* render = window->createRenderer(); render->addPlugin(); render->onIntroCompleted = [this]() { this->loadContent(); }; - render->setDrawCall([this](const rawrbox::DrawPass& pass) { + render->setDrawCall([this](const rawrbox::CameraBase& /*camera*/, const rawrbox::DrawPass& pass) { if (pass != rawrbox::DrawPass::PASS_WORLD) return; this->drawWorld(); }); // --------------- // Setup camera - auto* cam = render->setupCamera(*window); + auto* cam = render->createCamera(*window); cam->setPos({0.F, 5.F, -5.F}); cam->setAngle({0.F, rawrbox::MathUtils::toRad(-45), 0.F, 0.F}); // -------------- diff --git a/samples/008-ui/src/game.cpp b/samples/008-ui/src/game.cpp index 784207c9..e28350e9 100644 --- a/samples/008-ui/src/game.cpp +++ b/samples/008-ui/src/game.cpp @@ -50,14 +50,14 @@ namespace ui_test { // Setup renderer auto* render = window->createRenderer(rawrbox::Color::RGBAHex(0x443355FF)); render->onIntroCompleted = [this]() { this->loadContent(); }; - render->setDrawCall([this](const rawrbox::DrawPass& pass) { + render->setDrawCall([this](const rawrbox::CameraBase& /*camera*/, const rawrbox::DrawPass& pass) { if (pass != rawrbox::DrawPass::PASS_OVERLAY) return; this->_ROOT_UI->render(); }); // --------------- // Setup camera -- - auto* cam = render->setupCamera(render->getSize()); + auto* cam = render->createCamera(render->getSize()); cam->setPos({-2.F, 5.F, -3.5F}); cam->setAngle({0.F, rawrbox::MathUtils::toRad(-45), 0.F, 0.F}); // --------------- diff --git a/samples/009-gltf/src/game.cpp b/samples/009-gltf/src/game.cpp index 1d3b70cd..68bb81d6 100644 --- a/samples/009-gltf/src/game.cpp +++ b/samples/009-gltf/src/game.cpp @@ -36,14 +36,14 @@ namespace gltf { auto* render = window->createRenderer(); render->onIntroCompleted = [this]() { this->loadContent(); }; render->addPlugin(); - render->setDrawCall([this](const rawrbox::DrawPass& pass) { + render->setDrawCall([this](const rawrbox::CameraBase& /*camera*/, const rawrbox::DrawPass& pass) { if (pass != rawrbox::DrawPass::PASS_WORLD) return; this->drawWorld(); }); // --------------- // Setup camera - auto* cam = render->setupCamera(*window); + auto* cam = render->createCamera(*window); cam->setPos({0.F, 5.F, -5.F}); cam->setAngle({0.F, rawrbox::MathUtils::toRad(-45), 0.F, 0.F}); // -------------- diff --git a/samples/010-bass-audio/src/game.cpp b/samples/010-bass-audio/src/game.cpp index 1fb6e03c..fa20f8c3 100644 --- a/samples/010-bass-audio/src/game.cpp +++ b/samples/010-bass-audio/src/game.cpp @@ -34,14 +34,14 @@ namespace bass_test { // Setup renderer auto* render = window->createRenderer(); render->onIntroCompleted = [this]() { this->loadContent(); }; - render->setDrawCall([this](const rawrbox::DrawPass& pass) { + render->setDrawCall([this](const rawrbox::CameraBase& /*camera*/, const rawrbox::DrawPass& pass) { if (pass != rawrbox::DrawPass::PASS_WORLD) return; this->drawWorld(); }); // --------------- // Setup camera - auto* cam = render->setupCamera(*window); + auto* cam = render->createCamera(*window); cam->setPos({0.F, 5.F, -5.F}); cam->setAngle({0.F, rawrbox::MathUtils::toRad(-45), 0.F, 0.F}); // -------------- diff --git a/samples/011-physics-3D/src/game.cpp b/samples/011-physics-3D/src/game.cpp index b1bc7750..28fbd2d0 100644 --- a/samples/011-physics-3D/src/game.cpp +++ b/samples/011-physics-3D/src/game.cpp @@ -34,7 +34,7 @@ namespace phys_3d_test { // Setup renderer auto* render = window->createRenderer(); render->onIntroCompleted = [this]() { this->loadContent(); }; - render->setDrawCall([this](const rawrbox::DrawPass& pass) { + render->setDrawCall([this](const rawrbox::CameraBase& /*camera*/, const rawrbox::DrawPass& pass) { if (pass == rawrbox::DrawPass::PASS_WORLD) { this->drawWorld(); } else { @@ -44,7 +44,7 @@ namespace phys_3d_test { // --------------- // Setup camera - auto* cam = render->setupCamera(*window); + auto* cam = render->createCamera(*window); cam->setPos({0.F, 5.F, -5.F}); cam->setAngle({0.F, rawrbox::MathUtils::toRad(-45), 0.F, 0.F}); // -------------- diff --git a/samples/012-physics-2D/src/game.cpp b/samples/012-physics-2D/src/game.cpp index efa96727..6fcd661b 100644 --- a/samples/012-physics-2D/src/game.cpp +++ b/samples/012-physics-2D/src/game.cpp @@ -35,7 +35,7 @@ namespace phys_2d_test { // Setup renderer auto* render = window->createRenderer(); render->onIntroCompleted = [this]() { this->loadContent(); }; - render->setDrawCall([this](const rawrbox::DrawPass& pass) { + render->setDrawCall([this](const rawrbox::CameraBase& /*camera*/, const rawrbox::DrawPass& pass) { if (pass == rawrbox::DrawPass::PASS_WORLD) { this->drawWorld(); } else { @@ -45,7 +45,7 @@ namespace phys_2d_test { // --------------- // Setup camera - auto* cam = render->setupCamera(*window); + auto* cam = render->createCamera(*window); cam->setPos({0.F, 5.F, -5.F}); cam->setAngle({0.F, 0.F, 0.F, 0.F}); // -------------- diff --git a/samples/013-webm/src/game.cpp b/samples/013-webm/src/game.cpp index 70df5a7c..5841b3a6 100644 --- a/samples/013-webm/src/game.cpp +++ b/samples/013-webm/src/game.cpp @@ -35,14 +35,14 @@ namespace webm_test { // Setup renderer auto* render = window->createRenderer(); render->onIntroCompleted = [this]() { this->loadContent(); }; - render->setDrawCall([this](const rawrbox::DrawPass& pass) { + render->setDrawCall([this](const rawrbox::CameraBase& /*camera*/, const rawrbox::DrawPass& pass) { if (pass != rawrbox::DrawPass::PASS_WORLD) return; this->drawWorld(); }); // --------------- // Setup camera - auto* cam = render->setupCamera(*window); + auto* cam = render->createCamera(*window); cam->setPos({0.F, 5.F, -10.F}); cam->setAngle({0.F, 0.F, 0.F, 0.F}); // -------------- diff --git a/samples/014-scripting/src/game.cpp b/samples/014-scripting/src/game.cpp index c47c87e9..e3115726 100644 --- a/samples/014-scripting/src/game.cpp +++ b/samples/014-scripting/src/game.cpp @@ -51,7 +51,7 @@ namespace scripting_test { // Setup renderer auto* render = window->createRenderer(); render->onIntroCompleted = [this]() { this->loadContent(); }; - render->setDrawCall([this](const rawrbox::DrawPass& pass) { + render->setDrawCall([this](const rawrbox::CameraBase& /*camera*/, const rawrbox::DrawPass& pass) { if (pass == rawrbox::DrawPass::PASS_WORLD) { this->drawWorld(); } else { @@ -61,7 +61,7 @@ namespace scripting_test { // --------------- // Setup camera - auto* cam = render->setupCamera(*window); + auto* cam = render->createCamera(*window); cam->setPos({0.F, 5.F, -5.F}); cam->setAngle({0.F, rawrbox::MathUtils::toRad(-45), 0.F, 0.F}); // -------------- diff --git a/samples/015-gpu-picking/src/game.cpp b/samples/015-gpu-picking/src/game.cpp index 589b2060..c29c70a1 100644 --- a/samples/015-gpu-picking/src/game.cpp +++ b/samples/015-gpu-picking/src/game.cpp @@ -31,14 +31,14 @@ namespace gpu { // Setup renderer auto* render = window->createRenderer(); render->onIntroCompleted = [this]() { this->loadContent(); }; - render->setDrawCall([this](const rawrbox::DrawPass& pass) { + render->setDrawCall([this](const rawrbox::CameraBase& /*camera*/, const rawrbox::DrawPass& pass) { if (pass != rawrbox::DrawPass::PASS_WORLD) return; this->drawWorld(); }); // --------------- // Setup camera - auto* cam = render->setupCamera(*window); + auto* cam = render->createCamera(*window); cam->setPos({0.F, 5.F, -5.F}); cam->setAngle({0.F, rawrbox::MathUtils::toRad(-45), 0.F, 0.F}); // -------------- diff --git a/samples/016-steamworks/src/game.cpp b/samples/016-steamworks/src/game.cpp index c254aca7..73f12856 100644 --- a/samples/016-steamworks/src/game.cpp +++ b/samples/016-steamworks/src/game.cpp @@ -33,7 +33,7 @@ namespace steamworks { // Setup renderer auto* render = window->createRenderer(); render->onIntroCompleted = [this]() { this->loadContent(); }; - render->setDrawCall([this](const rawrbox::DrawPass& pass) { + render->setDrawCall([this](const rawrbox::CameraBase& /*camera*/, const rawrbox::DrawPass& pass) { if (pass == rawrbox::DrawPass::PASS_OVERLAY) { this->drawOverlay(); } else { @@ -43,7 +43,7 @@ namespace steamworks { // --------------- // Setup camera - auto* cam = render->setupCamera(*window); + auto* cam = render->createCamera(*window); cam->setPos({0.F, 5.F, -5.F}); cam->setAngle({0.F, rawrbox::MathUtils::toRad(-45), 0.F, 0.F}); // -------------- diff --git a/samples/017-imgui/src/game.cpp b/samples/017-imgui/src/game.cpp index 83de2d45..0f95fd95 100644 --- a/samples/017-imgui/src/game.cpp +++ b/samples/017-imgui/src/game.cpp @@ -34,14 +34,14 @@ namespace imgui { // Setup renderer auto* render = window->createRenderer(); render->onIntroCompleted = [this]() { this->loadContent(); }; - render->setDrawCall([this](const rawrbox::DrawPass& pass) { + render->setDrawCall([this](const rawrbox::CameraBase& /*camera*/, const rawrbox::DrawPass& pass) { if (pass != rawrbox::DrawPass::PASS_OVERLAY) return; this->drawOverlay(); }); // --------------- // Setup camera -- - auto* cam = render->setupCamera(render->getSize()); + auto* cam = render->createCamera(render->getSize()); cam->setPos({-2.F, 5.F, -3.5F}); cam->setAngle({0.F, rawrbox::MathUtils::toRad(-45), 0.F, 0.F}); // ---------------