From 3bd24d34a183ecb1e3cf0d05f57ba080936254ef Mon Sep 17 00:00:00 2001 From: Sergey Lipskiy Date: Thu, 24 Sep 2015 18:06:07 +0600 Subject: [PATCH] Disable FBO draw when current buffer set to NULL. --- src/FrameBuffer.cpp | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) diff --git a/src/FrameBuffer.cpp b/src/FrameBuffer.cpp index 73f61d01..ac28f8cf 100644 --- a/src/FrameBuffer.cpp +++ b/src/FrameBuffer.cpp @@ -358,12 +358,14 @@ void FrameBufferList::init() { m_pCurrent = NULL; m_pCopy = NULL; + glBindFramebuffer(GL_DRAW_FRAMEBUFFER, 0); } void FrameBufferList::destroy() { m_list.clear(); m_pCurrent = NULL; m_pCopy = NULL; + glBindFramebuffer(GL_DRAW_FRAMEBUFFER, 0); } void FrameBufferList::setBufferChanged() @@ -527,8 +529,10 @@ void FrameBufferList::removeBuffer(u32 _address ) { for (FrameBuffers::iterator iter = m_list.begin(); iter != m_list.end(); ++iter) if (iter->m_startAddress == _address) { - if (&(*iter) == m_pCurrent) + if (&(*iter) == m_pCurrent) { m_pCurrent = NULL; + glBindFramebuffer(GL_DRAW_FRAMEBUFFER, 0); + } m_list.erase(iter); return; } @@ -539,8 +543,10 @@ void FrameBufferList::removeBuffers(u32 _width) m_pCurrent = NULL; for (FrameBuffers::iterator iter = m_list.begin(); iter != m_list.end(); ++iter) { while (iter->m_width == _width) { - if (&(*iter) == m_pCurrent) + if (&(*iter) == m_pCurrent) { m_pCurrent = NULL; + glBindFramebuffer(GL_DRAW_FRAMEBUFFER, 0); + } iter = m_list.erase(iter); if (iter == m_list.end()) return;