From 4f09f317c4e1fe8f9f70a26ffd72696d409e26a8 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Branimir=20Karad=C5=BEi=C4=87?= Date: Sat, 2 Apr 2016 09:00:14 -0700 Subject: [PATCH] GL: Reverted scissor change. --- src/renderer_gl.cpp | 21 ++++++++++++++------- 1 file changed, 14 insertions(+), 7 deletions(-) diff --git a/src/renderer_gl.cpp b/src/renderer_gl.cpp index 72bdbfa5a..154cf3bf4 100644 --- a/src/renderer_gl.cpp +++ b/src/renderer_gl.cpp @@ -5473,8 +5473,6 @@ namespace bgfx { namespace gl viewScissorRect.clear(); uint16_t discardFlags = BGFX_CLEAR_NONE; - GL_CHECK(glEnable(GL_SCISSOR_TEST) ); - const bool blendIndependentSupported = s_extension[Extension::ARB_draw_buffers_blend].m_supported; const bool computeSupported = (BX_ENABLED(BGFX_CONFIG_RENDERER_OPENGL) && s_extension[Extension::ARB_compute_shader].m_supported) || BX_ENABLED(BGFX_CONFIG_RENDERER_OPENGLES >= 31) @@ -5824,16 +5822,25 @@ namespace bgfx { namespace gl if (UINT16_MAX == scissor) { - GL_CHECK(glScissor(viewScissorRect.m_x - , resolutionHeight-viewScissorRect.m_height-viewScissorRect.m_y - , viewScissorRect.m_width - , viewScissorRect.m_height - ) ); + if (viewHasScissor) + { + GL_CHECK(glEnable(GL_SCISSOR_TEST) ); + GL_CHECK(glScissor(viewScissorRect.m_x + , resolutionHeight-viewScissorRect.m_height-viewScissorRect.m_y + , viewScissorRect.m_width + , viewScissorRect.m_height + ) ); + } + else + { + GL_CHECK(glDisable(GL_SCISSOR_TEST) ); + } } else { Rect scissorRect; scissorRect.intersect(viewScissorRect, _render->m_rectCache.m_cache[scissor]); + GL_CHECK(glEnable(GL_SCISSOR_TEST) ); GL_CHECK(glScissor(scissorRect.m_x , resolutionHeight-scissorRect.m_height-scissorRect.m_y , scissorRect.m_width