From 449e9cf33923f2685356596f82bc596e1f05407c Mon Sep 17 00:00:00 2001 From: Alyssa Milburn Date: Mon, 4 Apr 2011 12:21:30 +0200 Subject: ANDROID: Fix non-fullscreen corruption on HTC devices. HTC's drivers don't preserve the color buffer between frames (as allowed by the spec, apparently), so we have to force-clear it every frame when we're not rendering a texture over the whole screen. --- backends/platform/android/gfx.cpp | 12 +++--------- 1 file changed, 3 insertions(+), 9 deletions(-) (limited to 'backends/platform/android') diff --git a/backends/platform/android/gfx.cpp b/backends/platform/android/gfx.cpp index b2f5427f01..19cfd7f5a3 100644 --- a/backends/platform/android/gfx.cpp +++ b/backends/platform/android/gfx.cpp @@ -430,7 +430,9 @@ void OSystem_Android::updateScreen() { _force_redraw = false; // clear pointer leftovers in dead areas - if (_show_overlay && !_fullscreen) + // also, HTC's GLES drivers are made of fail and don't preserve the buffer + // ( http://www.khronos.org/registry/egl/specs/EGLTechNote0001.html ) + if ((_show_overlay || _htc_fail) && !_fullscreen) clearScreen(kClear); GLCALL(glPushMatrix()); @@ -525,14 +527,6 @@ void OSystem_Android::updateScreen() { if (!JNI::swapBuffers()) LOGW("swapBuffers failed: 0x%x", glGetError()); - - // HTC's GLES drivers are made of fail - // http://code.google.com/p/android/issues/detail?id=3047 - if (!_show_overlay && _htc_fail) { - const Common::Rect &rect = _game_texture->getDrawRect(); - - glScissor(rect.left, rect.top, rect.width(), rect.height()); - } } Graphics::Surface *OSystem_Android::lockScreen() { -- cgit v1.2.3