From b4ad18a3ea4db2749acfb5e72941b87f938801f8 Mon Sep 17 00:00:00 2001 From: Maciej Suminski Date: Fri, 3 Jun 2016 15:46:13 +0200 Subject: [PATCH] Do not rebuild shaders on each OPENGL_GAL construction. --- common/gal/opengl/opengl_gal.cpp | 23 +++++++++++++---------- include/gal/opengl/opengl_gal.h | 2 +- include/gal/opengl/shader.h | 8 ++++++++ 3 files changed, 22 insertions(+), 11 deletions(-) diff --git a/common/gal/opengl/opengl_gal.cpp b/common/gal/opengl/opengl_gal.cpp index fcd73670b0..0191112655 100644 --- a/common/gal/opengl/opengl_gal.cpp +++ b/common/gal/opengl/opengl_gal.cpp @@ -53,6 +53,7 @@ static const int glAttributes[] = { WX_GL_RGBA, WX_GL_DOUBLEBUFFER, WX_GL_DEPTH_ wxGLContext* OPENGL_GAL::glMainContext = NULL; GLuint OPENGL_GAL::fontTexture = 0; bool OPENGL_GAL::isBitmapFontLoaded = false; +SHADER* OPENGL_GAL::shader = NULL; OPENGL_GAL::OPENGL_GAL( wxWindow* aParent, wxEvtHandler* aMouseListener, @@ -69,6 +70,7 @@ OPENGL_GAL::OPENGL_GAL( wxWindow* aParent, wxEvtHandler* aMouseListener, { glMainContext = GL_CONTEXT_MANAGER::Get().CreateCtx( this ); glPrivContext = glMainContext; + shader = new SHADER(); } else { @@ -79,9 +81,9 @@ OPENGL_GAL::OPENGL_GAL( wxWindow* aParent, wxEvtHandler* aMouseListener, runTest(); // Make VBOs use shaders - cachedManager.SetShader( shader ); - nonCachedManager.SetShader( shader ); - overlayManager.SetShader( shader ); + cachedManager.SetShader( *shader ); + nonCachedManager.SetShader( *shader ); + overlayManager.SetShader( *shader ); // Initialize the flags isFramebufferInitialized = false; @@ -151,6 +153,7 @@ OPENGL_GAL::~OPENGL_GAL() isBitmapFontLoaded = false; } + delete shader; glMainContext = NULL; } @@ -266,10 +269,10 @@ void OPENGL_GAL::BeginDrawing() } // Set shader parameter - GLint ufm_fontTexture = shader.AddParameter( "fontTexture" ); - shader.Use(); - shader.SetParameter( ufm_fontTexture, (int) FONT_TEXTURE_UNIT ); - shader.Deactivate(); + GLint ufm_fontTexture = shader->AddParameter( "fontTexture" ); + shader->Use(); + shader->SetParameter( ufm_fontTexture, (int) FONT_TEXTURE_UNIT ); + shader->Deactivate(); checkGlError( "setting bitmap font sampler as shader parameter" ); isBitmapFontInitialized = true; @@ -1529,13 +1532,13 @@ void OPENGL_GAL::OPENGL_TEST::Render( wxPaintEvent& WXUNUSED( aEvent ) ) error( "Vertex buffer objects are not supported!" ); // Prepare shaders - else if( !m_gal->shader.LoadBuiltinShader( 0, SHADER_TYPE_VERTEX ) ) + else if( !m_gal->shader->IsLinked() && !m_gal->shader->LoadBuiltinShader( 0, SHADER_TYPE_VERTEX ) ) error( "Cannot compile vertex shader!" ); - else if( !m_gal->shader.LoadBuiltinShader( 1, SHADER_TYPE_FRAGMENT ) ) + else if( !m_gal->shader->IsLinked() && !m_gal->shader->LoadBuiltinShader( 1, SHADER_TYPE_FRAGMENT ) ) error( "Cannot compile fragment shader!" ); - else if( !m_gal->shader.Link() ) + else if( !m_gal->shader->IsLinked() && !m_gal->shader->Link() ) error( "Cannot link the shaders!" ); // Check if video card supports textures big enough to fit font atlas diff --git a/include/gal/opengl/opengl_gal.h b/include/gal/opengl/opengl_gal.h index 60430b6e3c..35e1c441bd 100644 --- a/include/gal/opengl/opengl_gal.h +++ b/include/gal/opengl/opengl_gal.h @@ -296,7 +296,7 @@ private: RENDER_TARGET currentTarget; ///< Current rendering target // Shader - SHADER shader; ///< There is only one shader used for different objects + static SHADER* shader; ///< There is only one shader used for different objects // Internal flags bool isFramebufferInitialized; ///< Are the framebuffers initialized? diff --git a/include/gal/opengl/shader.h b/include/gal/opengl/shader.h index a83de846e3..0ecbdd5101 100644 --- a/include/gal/opengl/shader.h +++ b/include/gal/opengl/shader.h @@ -95,6 +95,14 @@ public: */ bool Link(); + /** + * @brief Returns true if shaders are linked correctly. + */ + bool IsLinked() const + { + return isShaderLinked; + } + /** * @brief Use the shader. */