From 7518745c1995f64b69cee80579eb951337a66515 Mon Sep 17 00:00:00 2001 From: KOPRajs Date: Tue, 28 Mar 2023 12:00:04 +0200 Subject: [PATCH] Add shaders support for DMA renderer --- .../VideoRenderers/RPRendererDMA.cpp | 163 ++++++++++++------ .../rendering/VideoRenderers/RPRendererDMA.h | 4 + 2 files changed, 111 insertions(+), 56 deletions(-) diff --git a/xbmc/cores/RetroPlayer/rendering/VideoRenderers/RPRendererDMA.cpp b/xbmc/cores/RetroPlayer/rendering/VideoRenderers/RPRendererDMA.cpp index 97a9eaa462f08..b27f68248f080 100644 --- a/xbmc/cores/RetroPlayer/rendering/VideoRenderers/RPRendererDMA.cpp +++ b/xbmc/cores/RetroPlayer/rendering/VideoRenderers/RPRendererDMA.cpp @@ -12,6 +12,7 @@ #include "cores/RetroPlayer/buffers/RenderBufferPoolDMA.h" #include "cores/RetroPlayer/rendering/RenderContext.h" #include "cores/RetroPlayer/rendering/RenderVideoSettings.h" +#include "cores/RetroPlayer/shaders/gl/ShaderPresetGL.h" #include "utils/BufferObjectFactory.h" #include "utils/GLUtils.h" @@ -62,73 +63,123 @@ void CRPRendererDMA::Render(uint8_t alpha) const uint32_t color = (alpha << 24) | 0xFFFFFF; - glBindTexture(m_textureTarget, renderBuffer->TextureID()); + RenderBufferTextures* rbTextures; + const auto it = m_RBTexturesMap.find(renderBuffer); + if (it != m_RBTexturesMap.end()) + { + rbTextures = it->second.get(); + } + else + { + // We can't copy or move CGLTexture, so construct source/target in-place + rbTextures = new RenderBufferTextures{ + // Source texture + { + static_cast(renderBuffer->GetWidth()), + static_cast(renderBuffer->GetHeight()), + XB_FMT_RGB8, + renderBuffer->TextureID(), + }, + // Target texture + { + static_cast(m_context.GetScreenWidth()), + static_cast(m_context.GetScreenHeight()), + }, + }; + m_RBTexturesMap.emplace(renderBuffer, rbTextures); + } + + const auto sourceTexture = &rbTextures->source; + const auto targetTexture = &rbTextures->target; + + glBindTexture(m_textureTarget, sourceTexture->getMTexture()); GLint filter = GL_NEAREST; if (GetRenderSettings().VideoSettings().GetScalingMethod() == SCALINGMETHOD::LINEAR) filter = GL_LINEAR; + glTexParameteri(m_textureTarget, GL_TEXTURE_MAG_FILTER, filter); glTexParameteri(m_textureTarget, GL_TEXTURE_MIN_FILTER, filter); glTexParameteri(m_textureTarget, GL_TEXTURE_WRAP_S, GL_CLAMP_TO_EDGE); glTexParameteri(m_textureTarget, GL_TEXTURE_WRAP_T, GL_CLAMP_TO_EDGE); - m_context.EnableGUIShader(GL_SHADER_METHOD::TEXTURE); + Updateshaders(); - GLubyte colour[4]; - GLubyte idx[4] = {0, 1, 3, 2}; // Determines order of triangle strip - struct PackedVertex + if (m_bUseShaderPreset) { - float x, y, z; - float u1, v1; - } vertex[4]; - - GLint vertLoc = m_context.GUIShaderGetPos(); - GLint loc = m_context.GUIShaderGetCoord0(); - GLint uniColLoc = m_context.GUIShaderGetUniCol(); - - // Setup color values - colour[0] = UTILS::GL::GetChannelFromARGB(UTILS::GL::ColorChannel::R, color); - colour[1] = UTILS::GL::GetChannelFromARGB(UTILS::GL::ColorChannel::G, color); - colour[2] = UTILS::GL::GetChannelFromARGB(UTILS::GL::ColorChannel::B, color); - colour[3] = UTILS::GL::GetChannelFromARGB(UTILS::GL::ColorChannel::A, color); - - for (unsigned int i = 0; i < 4; i++) + const CPoint destPoints[4] = {m_rotatedDestCoords[0], m_rotatedDestCoords[1], + m_rotatedDestCoords[2], m_rotatedDestCoords[3]}; + + targetTexture->CreateTextureObject(); + + SHADER::CShaderTextureGL source(*sourceTexture); + SHADER::CShaderTextureGL target(*targetTexture); + if (!m_shaderPreset->RenderUpdate(destPoints, &source, &target)) + { + m_shadersNeedUpdate = false; + m_bUseShaderPreset = false; + } + } + else { - // Setup vertex position values - vertex[i].x = m_rotatedDestCoords[i].x; - vertex[i].y = m_rotatedDestCoords[i].y; - vertex[i].z = 0.0f; + m_context.EnableGUIShader(GL_SHADER_METHOD::TEXTURE); + + GLubyte colour[4]; + GLubyte idx[4] = {0, 1, 3, 2}; // Determines order of triangle strip + struct PackedVertex + { + float x, y, z; + float u1, v1; + } vertex[4]; + + GLint vertLoc = m_context.GUIShaderGetPos(); + GLint loc = m_context.GUIShaderGetCoord0(); + GLint uniColLoc = m_context.GUIShaderGetUniCol(); + + // Setup color values + colour[0] = UTILS::GL::GetChannelFromARGB(UTILS::GL::ColorChannel::R, color); + colour[1] = UTILS::GL::GetChannelFromARGB(UTILS::GL::ColorChannel::G, color); + colour[2] = UTILS::GL::GetChannelFromARGB(UTILS::GL::ColorChannel::B, color); + colour[3] = UTILS::GL::GetChannelFromARGB(UTILS::GL::ColorChannel::A, color); + + for (unsigned int i = 0; i < 4; i++) + { + // Setup vertex position values + vertex[i].x = m_rotatedDestCoords[i].x; + vertex[i].y = m_rotatedDestCoords[i].y; + vertex[i].z = 0.0f; + } + + // Setup texture coordinates + vertex[0].u1 = vertex[3].u1 = rect.x1; + vertex[0].v1 = vertex[1].v1 = rect.y1; + vertex[1].u1 = vertex[2].u1 = rect.x2; + vertex[2].v1 = vertex[3].v1 = rect.y2; + + glBindBuffer(GL_ARRAY_BUFFER, m_mainVertexVBO); + glBufferData(GL_ARRAY_BUFFER, sizeof(PackedVertex) * 4, &vertex[0], GL_STATIC_DRAW); + + glVertexAttribPointer(vertLoc, 3, GL_FLOAT, 0, sizeof(PackedVertex), + reinterpret_cast(offsetof(PackedVertex, x))); + glVertexAttribPointer(loc, 2, GL_FLOAT, 0, sizeof(PackedVertex), + reinterpret_cast(offsetof(PackedVertex, u1))); + + glEnableVertexAttribArray(vertLoc); + glEnableVertexAttribArray(loc); + + glBindBuffer(GL_ELEMENT_ARRAY_BUFFER, m_mainIndexVBO); + glBufferData(GL_ELEMENT_ARRAY_BUFFER, sizeof(GLubyte) * 4, idx, GL_STATIC_DRAW); + + glUniform4f(uniColLoc, (colour[0] / 255.0f), (colour[1] / 255.0f), (colour[2] / 255.0f), + (colour[3] / 255.0f)); + glDrawElements(GL_TRIANGLE_STRIP, 4, GL_UNSIGNED_BYTE, 0); + + glDisableVertexAttribArray(vertLoc); + glDisableVertexAttribArray(loc); + + glBindBuffer(GL_ARRAY_BUFFER, 0); + glBindBuffer(GL_ELEMENT_ARRAY_BUFFER, 0); + + m_context.DisableGUIShader(); } - - // Setup texture coordinates - vertex[0].u1 = vertex[3].u1 = rect.x1; - vertex[0].v1 = vertex[1].v1 = rect.y1; - vertex[1].u1 = vertex[2].u1 = rect.x2; - vertex[2].v1 = vertex[3].v1 = rect.y2; - - glBindBuffer(GL_ARRAY_BUFFER, m_mainVertexVBO); - glBufferData(GL_ARRAY_BUFFER, sizeof(PackedVertex) * 4, &vertex[0], GL_STATIC_DRAW); - - glVertexAttribPointer(vertLoc, 3, GL_FLOAT, 0, sizeof(PackedVertex), - reinterpret_cast(offsetof(PackedVertex, x))); - glVertexAttribPointer(loc, 2, GL_FLOAT, 0, sizeof(PackedVertex), - reinterpret_cast(offsetof(PackedVertex, u1))); - - glEnableVertexAttribArray(vertLoc); - glEnableVertexAttribArray(loc); - - glBindBuffer(GL_ELEMENT_ARRAY_BUFFER, m_mainIndexVBO); - glBufferData(GL_ELEMENT_ARRAY_BUFFER, sizeof(GLubyte) * 4, idx, GL_STATIC_DRAW); - - glUniform4f(uniColLoc, (colour[0] / 255.0f), (colour[1] / 255.0f), (colour[2] / 255.0f), - (colour[3] / 255.0f)); - glDrawElements(GL_TRIANGLE_STRIP, 4, GL_UNSIGNED_BYTE, 0); - - glDisableVertexAttribArray(vertLoc); - glDisableVertexAttribArray(loc); - - glBindBuffer(GL_ARRAY_BUFFER, 0); - glBindBuffer(GL_ELEMENT_ARRAY_BUFFER, 0); - - m_context.DisableGUIShader(); } diff --git a/xbmc/cores/RetroPlayer/rendering/VideoRenderers/RPRendererDMA.h b/xbmc/cores/RetroPlayer/rendering/VideoRenderers/RPRendererDMA.h index 38d7baeb874d2..d3e8f0eec0568 100644 --- a/xbmc/cores/RetroPlayer/rendering/VideoRenderers/RPRendererDMA.h +++ b/xbmc/cores/RetroPlayer/rendering/VideoRenderers/RPRendererDMA.h @@ -16,6 +16,8 @@ namespace KODI { namespace RETRO { +class CRenderBufferDMA; + class CRendererFactoryDMA : public IRendererFactory { public: @@ -48,6 +50,8 @@ class CRPRendererDMA : public CRPRendererOpenGLES protected: // implementation of CRPRendererOpenGLES void Render(uint8_t alpha) override; + + std::map> m_RBTexturesMap; }; } // namespace RETRO } // namespace KODI