From 4c6010b0783fc33198c822699d762e624e291c4f Mon Sep 17 00:00:00 2001 From: Kai Uwe Broulik Date: Thu, 28 Jul 2022 09:23:56 +0200 Subject: [PATCH] scenes/opengl: Check whether pixmap is valid before generating quads Quad generation needs a valid surface pixmap. This did not surface before as the pixmap was only accessed when looping the region which typically was empty without a pixmap. Signed-off-by: Victoria Fischer --- src/scenes/opengl/scene_opengl.cpp | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/src/scenes/opengl/scene_opengl.cpp b/src/scenes/opengl/scene_opengl.cpp index 560096a4ab..f3d71222cd 100644 --- a/src/scenes/opengl/scene_opengl.cpp +++ b/src/scenes/opengl/scene_opengl.cpp @@ -363,10 +363,10 @@ void SceneOpenGL::createRenderNode(Item *item, RenderContext *context) }); } } else if (auto surfaceItem = qobject_cast(item)) { - WindowQuadList quads = clipQuads(item, context); - if (!quads.isEmpty()) { - SurfacePixmap *pixmap = surfaceItem->pixmap(); - if (pixmap) { + SurfacePixmap *pixmap = surfaceItem->pixmap(); + if (pixmap) { + WindowQuadList quads = clipQuads(item, context); + if (!quads.isEmpty()) { // Don't bother with blending if the entire surface is opaque bool hasAlpha = pixmap->hasAlphaChannel() && !surfaceItem->shape().subtracted(surfaceItem->opaque()).isEmpty(); context->renderNodes.append(RenderNode{