diff options
author | Michael Meeks <michael.meeks@collabora.com> | 2015-09-16 03:25:05 +0100 |
---|---|---|
committer | Tor Lillqvist <tml@collabora.com> | 2015-09-16 12:31:06 +0000 |
commit | 3891bd40f6cf513a020ac6c87acfd0af7fc5ffd8 (patch) | |
tree | f634914ea8a3853bf5de5543df8ab6abf21d7b1e | |
parent | 0ff1cd30959b4e2eba9372cfb786c6bf3947bd38 (diff) |
tdf#94252 - avoid switching contexts un-necessarily to reduce flicker.
Change-Id: Id4ac387174fa03c5886a990d89fd53a4f18db11c
Reviewed-on: https://gerrit.libreoffice.org/18610
Tested-by: Jenkins <ci@libreoffice.org>
Reviewed-by: Tor Lillqvist <tml@collabora.com>
-rw-r--r-- | vcl/opengl/gdiimpl.cxx | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/vcl/opengl/gdiimpl.cxx b/vcl/opengl/gdiimpl.cxx index 37b21f36edc1..9ea8a7c87fc8 100644 --- a/vcl/opengl/gdiimpl.cxx +++ b/vcl/opengl/gdiimpl.cxx @@ -77,8 +77,17 @@ bool OpenGLSalGraphicsImpl::AcquireContext( ) { ImplSVData* pSVData = ImplGetSVData(); + // We always prefer to bind our VirtualDevice / offscreen graphics + // to the current OpenGLContext - to avoid switching contexts. + if (mpContext.is() && mbOffscreen) + { + if (OpenGLContext::hasCurrent() && !mpContext->isCurrent()) + mpContext.clear(); + } + if( mpContext.is() ) { + // Check whether the context was reset underneath us. if( mpContext->isInitialized() ) return true; mpContext.clear(); |