From c67d81aeb983606fe121887fbc50b99d58b59ef2 Mon Sep 17 00:00:00 2001 From: David Edmundson Date: Wed, 28 Aug 2019 17:34:28 +0100 Subject: [PATCH] [Aurorae] Don't delay initial blit. Summary: Aurorae has a timer between request update and updating the contents. This makes some sense. However on initial creation we want to snap the contents immediately as otherwise we may be out by a frame between a new window being mapped and the window decoration being rendered. Test Plan: Ran with Auroae Windows opened immediately seemed to have a deco straight away Reviewers: #kwin, zzag Reviewed By: #kwin, zzag Subscribers: zzag, romangg, kwin Tags: #kwin Differential Revision: https://phabricator.kde.org/D23332 --- plugins/kdecorations/aurorae/src/aurorae.cpp | 70 +++++++++++--------- plugins/kdecorations/aurorae/src/aurorae.h | 1 + 2 files changed, 39 insertions(+), 32 deletions(-) diff --git a/plugins/kdecorations/aurorae/src/aurorae.cpp b/plugins/kdecorations/aurorae/src/aurorae.cpp index 9407d64e4a..a212be76f7 100644 --- a/plugins/kdecorations/aurorae/src/aurorae.cpp +++ b/plugins/kdecorations/aurorae/src/aurorae.cpp @@ -331,7 +331,7 @@ void Decoration::init() } else { m_renderControl = new QQuickRenderControl(this); m_view = new QQuickWindow(m_renderControl); - bool usingGL = m_view->rendererInterface()->graphicsApi() == QSGRendererInterface::OpenGL; + const bool usingGL = m_view->rendererInterface()->graphicsApi() == QSGRendererInterface::OpenGL; m_view->setColor(Qt::transparent); m_view->setFlags(Qt::FramelessWindowHint); if (usingGL) { @@ -353,38 +353,8 @@ void Decoration::init() m_updateTimer.reset(new QTimer); m_updateTimer->setSingleShot(true); m_updateTimer->setInterval(5); - connect(m_updateTimer.data(), &QTimer::timeout, this, - [this, usingGL] { - if (usingGL) { - if (!m_context->makeCurrent(m_offscreenSurface.data())) { - return; - } - if (m_fbo.isNull() || m_fbo->size() != m_view->size()) { - m_fbo.reset(new QOpenGLFramebufferObject(m_view->size(), QOpenGLFramebufferObject::CombinedDepthStencil)); - if (!m_fbo->isValid()) { - qCWarning(AURORAE) << "Creating FBO as render target failed"; - m_fbo.reset(); - return; - } - } - m_view->setRenderTarget(m_fbo.data()); - m_view->resetOpenGLState(); - } - m_buffer = m_renderControl->grab(); - - m_contentRect = QRect(QPoint(0, 0), m_buffer.size()); - if (m_padding && - (m_padding->left() > 0 || m_padding->top() > 0 || m_padding->right() > 0 || m_padding->bottom() > 0) && - !client().data()->isMaximized()) { - m_contentRect = m_contentRect.adjusted(m_padding->left(), m_padding->top(), -m_padding->right(), -m_padding->bottom()); - } - updateShadow(); - - QOpenGLFramebufferObject::bindDefault(); - update(); - } - ); + connect(m_updateTimer.data(), &QTimer::timeout, this, &Decoration::updateBuffer); auto requestUpdate = [this] { if (m_updateTimer->isActive()) { return; @@ -442,6 +412,7 @@ void Decoration::init() connect(client().data(), &KDecoration2::DecoratedClient::maximizedChanged, this, resizeWindow); connect(client().data(), &KDecoration2::DecoratedClient::shadedChanged, this, resizeWindow); resizeWindow(); + updateBuffer(); } else { // create a dummy shadow for the configuration interface if (m_padding) { @@ -633,6 +604,41 @@ void Decoration::installTitleItem(QQuickItem *item) connect(item, &QQuickItem::yChanged, this, update); } +void Decoration::updateBuffer() +{ + Q_ASSERT(m_view); + const bool usingGL = m_view->rendererInterface()->graphicsApi() == QSGRendererInterface::OpenGL; + if (usingGL) { + Q_ASSERT(m_view->size().isValid()); + if (!m_context->makeCurrent(m_offscreenSurface.data())) { + return; + } + if (m_fbo.isNull() || m_fbo->size() != m_view->size()) { + m_fbo.reset(new QOpenGLFramebufferObject(m_view->size(), QOpenGLFramebufferObject::CombinedDepthStencil)); + if (!m_fbo->isValid()) { + qCWarning(AURORAE) << "Creating FBO as render target failed"; + m_fbo.reset(); + return; + } + } + m_view->setRenderTarget(m_fbo.data()); + m_view->resetOpenGLState(); + } + + m_buffer = m_renderControl->grab(); + + m_contentRect = QRect(QPoint(0, 0), m_buffer.size()); + if (m_padding && + (m_padding->left() > 0 || m_padding->top() > 0 || m_padding->right() > 0 || m_padding->bottom() > 0) && + !client().data()->isMaximized()) { + m_contentRect = m_contentRect.adjusted(m_padding->left(), m_padding->top(), -m_padding->right(), -m_padding->bottom()); + } + updateShadow(); + + QOpenGLFramebufferObject::bindDefault(); + update(); +} + KDecoration2::DecoratedClient *Decoration::clientPointer() const { return client().data(); diff --git a/plugins/kdecorations/aurorae/src/aurorae.h b/plugins/kdecorations/aurorae/src/aurorae.h index 7a1c8a2757..cb41be1eb5 100644 --- a/plugins/kdecorations/aurorae/src/aurorae.h +++ b/plugins/kdecorations/aurorae/src/aurorae.h @@ -76,6 +76,7 @@ protected: private: void setupBorders(QQuickItem *item); void updateBorders(); + void updateBuffer(); QMouseEvent translatedMouseEvent(QMouseEvent *orig); QScopedPointer m_fbo; QImage m_buffer;