From b3180bc4a6558ce43b41f75eeeaaa62c8f93e837 Mon Sep 17 00:00:00 2001 From: Colin Kinloch Date: Sun, 26 Mar 2023 18:03:27 +0100 Subject: [PATCH] Fix GamePad window when using vulkan with wayland --- src/gui/canvas/VulkanCanvas.cpp | 19 +++++++------------ 1 file changed, 7 insertions(+), 12 deletions(-) diff --git a/src/gui/canvas/VulkanCanvas.cpp b/src/gui/canvas/VulkanCanvas.cpp index 671cba439..de22e55cf 100644 --- a/src/gui/canvas/VulkanCanvas.cpp +++ b/src/gui/canvas/VulkanCanvas.cpp @@ -14,20 +14,15 @@ VulkanCanvas::VulkanCanvas(wxWindow* parent, const wxSize& size, bool is_main_wi Bind(wxEVT_PAINT, &VulkanCanvas::OnPaint, this); Bind(wxEVT_SIZE, &VulkanCanvas::OnResize, this); - if(is_main_window) + WindowHandleInfo& canvas = is_main_window ? gui_getWindowInfo().canvas_main : gui_getWindowInfo().canvas_pad; + gui_initHandleContextFromWxWidgetsWindow(canvas, this); + #if BOOST_OS_LINUX && HAS_WAYLAND + if (canvas.backend == WindowHandleInfo::Backend::WAYLAND) { - WindowHandleInfo& canvasMain = gui_getWindowInfo().canvas_main; - gui_initHandleContextFromWxWidgetsWindow(canvasMain, this); - #if BOOST_OS_LINUX && HAS_WAYLAND - if(canvasMain.backend == WindowHandleInfo::Backend::WAYLAND) - { - m_subsurface = std::make_unique(this); - canvasMain.surface = m_subsurface->getSurface(); - } - #endif + m_subsurface = std::make_unique(this); + canvas.surface = m_subsurface->getSurface(); } - else - gui_initHandleContextFromWxWidgetsWindow(gui_getWindowInfo().canvas_pad, this); + #endif cemu_assert(g_vulkan_available);