Index: android_webview/browser/scoped_app_gl_state_restore.cc |
diff --git a/android_webview/browser/scoped_app_gl_state_restore.cc b/android_webview/browser/scoped_app_gl_state_restore.cc |
index cb8d128901e67eaa89404c60425821c7cdc345d5..5f6df1ae1d0e3a3f60e48a85c0b7f6904d3b8161 100644 |
--- a/android_webview/browser/scoped_app_gl_state_restore.cc |
+++ b/android_webview/browser/scoped_app_gl_state_restore.cc |
@@ -4,6 +4,7 @@ |
#include "android_webview/browser/scoped_app_gl_state_restore.h" |
+#include "android_webview/browser/gl_surface_factory.h" |
#include "base/debug/trace_event.h" |
#include "base/lazy_instance.h" |
#include "ui/gl/gl_context.h" |
@@ -132,6 +133,8 @@ ScopedAppGLStateRestore::ScopedAppGLStateRestore(CallMode mode) : mode_(mode) { |
glGetIntegerv(GL_STENCIL_VALUE_MASK, &stencil_mask_); |
glGetIntegerv(GL_STENCIL_REF, &stencil_ref_); |
+ glGetIntegerv(GL_FRAMEBUFFER_BINDING_EXT, &framebuffer_binding_ext_); |
+ GLSurfaceFactory::SetCurrentFBO(framebuffer_binding_ext_); |
if (!g_gl_max_texture_units) { |
glGetIntegerv(GL_MAX_COMBINED_TEXTURE_IMAGE_UNITS, &g_gl_max_texture_units); |
@@ -155,6 +158,8 @@ ScopedAppGLStateRestore::~ScopedAppGLStateRestore() { |
TRACE_EVENT0("android_webview", "AppGLStateRestore"); |
MakeAppContextCurrent(); |
+ GLSurfaceFactory::SetCurrentFBO(0); |
+ glBindFramebufferEXT(GL_FRAMEBUFFER, framebuffer_binding_ext_); |
glBindBuffer(GL_ARRAY_BUFFER, vertex_array_buffer_binding_); |
glBindBuffer(GL_ELEMENT_ARRAY_BUFFER, index_array_buffer_binding_); |