[Libreoffice-commits] core.git: include/vcl vcl/opengl vcl/source vcl/unx
Michael Meeks
michael.meeks at collabora.com
Thu Nov 20 01:55:32 PST 2014
include/vcl/opengl/OpenGLContext.hxx | 2 ++
vcl/opengl/x11/gdiimpl.cxx | 3 +++
vcl/source/opengl/OpenGLContext.cxx | 17 +++++++++++++++--
vcl/unx/generic/gdi/salvd.cxx | 9 +++++++++
4 files changed, 29 insertions(+), 2 deletions(-)
New commits:
commit 9557ae7baf3683a3c55bc55934fefba22a7c5759
Author: Michael Meeks <michael.meeks at collabora.com>
Date: Thu Nov 20 09:45:16 2014 +0000
vcl: update the OpenGLContext's pixmap when re-sizing a VirtualDevice.
Change-Id: Iee8089fc3bfbea60adee95dfb2c229f3efea28f8
diff --git a/include/vcl/opengl/OpenGLContext.hxx b/include/vcl/opengl/OpenGLContext.hxx
index 60746df1..471e6ce 100644
--- a/include/vcl/opengl/OpenGLContext.hxx
+++ b/include/vcl/opengl/OpenGLContext.hxx
@@ -195,6 +195,8 @@ public:
return mbInitialized;
}
+ void resetToReInitialize();
+
bool supportMultiSampling() const;
static SystemWindowData generateWinData(vcl::Window* pParent, bool bRequestLegacyContext);
diff --git a/vcl/opengl/x11/gdiimpl.cxx b/vcl/opengl/x11/gdiimpl.cxx
index b3cee49..bfc1bbb 100644
--- a/vcl/opengl/x11/gdiimpl.cxx
+++ b/vcl/opengl/x11/gdiimpl.cxx
@@ -62,6 +62,9 @@ GLfloat X11OpenGLSalGraphicsImpl::GetHeight() const
void X11OpenGLSalGraphicsImpl::Init()
{
X11WindowProvider *pProvider = dynamic_cast<X11WindowProvider*>(mrParent.m_pFrame);
+
+ // Called after eg. a vdev re-size where we need to update the underlying pixmap
+ maContext.resetToReInitialize();
if (pProvider)
{
Window aWin = pProvider->GetX11Window();
diff --git a/vcl/source/opengl/OpenGLContext.cxx b/vcl/source/opengl/OpenGLContext.cxx
index 6267a9f..d1c1b72 100644
--- a/vcl/source/opengl/OpenGLContext.cxx
+++ b/vcl/source/opengl/OpenGLContext.cxx
@@ -610,6 +610,14 @@ bool OpenGLContext::init(Display* dpy, Window win, int screen)
return ImplInit();
}
+void OpenGLContext::resetToReInitialize()
+{
+ if( !mbInitialized )
+ return;
+ resetCurrent();
+ mbInitialized = false;
+}
+
bool OpenGLContext::init(Display* dpy, Pixmap pix, unsigned int width, unsigned int height, int nScreen)
{
if(mbInitialized)
@@ -712,7 +720,12 @@ bool OpenGLContext::ImplInit()
SAL_INFO("vcl.opengl", "available GL extensions: " << m_aGLWin.GLExtensions);
XWindowAttributes xWinAttr;
- if( !XGetWindowAttributes( m_aGLWin.dpy, m_aGLWin.win, &xWinAttr ) )
+ if( mbPixmap )
+ {
+ m_aGLWin.Width = 0; // FIXME: correct ?
+ m_aGLWin.Height = 0;
+ }
+ else if( !XGetWindowAttributes( m_aGLWin.dpy, m_aGLWin.win, &xWinAttr ) )
{
SAL_WARN("vcl.opengl", "Failed to get window attributes on " << m_aGLWin.win);
m_aGLWin.Width = 0;
@@ -1159,7 +1172,7 @@ void OpenGLContext::makeCurrent()
SAL_INFO("vcl.opengl", "OpenGLContext::makeCurrent(): Avoid setting the same context");
}
else if (!glXMakeCurrent( m_aGLWin.dpy, nDrawable, m_aGLWin.ctx ))
- SAL_WARN("vcl.opengl", "OpenGLContext::makeCurrent failed");
+ SAL_WARN("vcl.opengl", "OpenGLContext::makeCurrent failed on drawable " << nDrawable << " pixmap? " << mbPixmap);
#endif
}
diff --git a/vcl/unx/generic/gdi/salvd.cxx b/vcl/unx/generic/gdi/salvd.cxx
index 8e08cc2..71ec509 100644
--- a/vcl/unx/generic/gdi/salvd.cxx
+++ b/vcl/unx/generic/gdi/salvd.cxx
@@ -196,6 +196,8 @@ SalGraphics* X11SalVirtualDevice::AcquireGraphics()
void X11SalVirtualDevice::ReleaseGraphics( SalGraphics* )
{ bGraphics_ = false; }
+#include "opengl/x11/gdiimpl.hxx"
+
bool X11SalVirtualDevice::SetSize( long nDX, long nDY )
{
if( bExternPixmap_ )
@@ -229,8 +231,15 @@ bool X11SalVirtualDevice::SetSize( long nDX, long nDY )
nDY_ = nDY;
if( pGraphics_ )
+ {
InitGraphics( this );
+ // re-initialize OpenGLContext [!] having freed it's underlying pixmap above
+ X11OpenGLSalGraphicsImpl *pImpl = dynamic_cast< X11OpenGLSalGraphicsImpl* >(pGraphics_->GetImpl());
+ if( pImpl )
+ pImpl->Init();
+ }
+
return true;
}
More information about the Libreoffice-commits
mailing list