From d7d7f3de39cd5972afeb55bbf79d476ddd32a0ff Mon Sep 17 00:00:00 2001 From: Rodney Dawes Date: Tue, 1 Mar 2022 10:40:54 -0500 Subject: [PATCH] wayland: Support for setting up the toplevel via layer-shell --- CMakeLists.txt | 4 ++-- src/waylandplatform.cpp | 27 +++++++++++++++++++++++++-- 2 files changed, 27 insertions(+), 4 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index 450cd153..b9aec99d 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -54,6 +54,7 @@ if(enable-wayland) find_package(Wayland REQUIRED) find_package(Qt5WaylandClient 5.14 REQUIRED PRIVATE) find_package(Qt5XkbCommonSupport REQUIRED PRIVATE) + find_package(LayerShellQt REQUIRED PRIVATE) pkg_check_modules(XKBCOMMON REQUIRED IMPORTED_TARGET xkbcommon) find_package(Gtk3) endif() @@ -108,7 +109,7 @@ qt5_add_dbus_interface(CONNECTION_SOURCES dbus_interfaces/minputmethodserver1int add_library(maliit-connection STATIC ${CONNECTION_SOURCES}) target_link_libraries(maliit-connection Qt5::Core Qt5::DBus Qt5::Gui maliit-common) if(enable-wayland) - target_link_libraries(maliit-connection Wayland::Client PkgConfig::XKBCOMMON) + target_link_libraries(maliit-connection Wayland::Client PkgConfig::XKBCOMMON LayerShellQt::Interface) target_include_directories(maliit-connection PRIVATE ${Qt5WaylandClient_PRIVATE_INCLUDE_DIRS}) endif() target_include_directories(maliit-connection PUBLIC connection) @@ -201,7 +202,6 @@ if(enable-wayland) list(APPEND PLUGINS_SOURCES src/waylandplatform.cpp src/waylandplatform.h) - endif() if(enable-hwkeyboard) diff --git a/src/waylandplatform.cpp b/src/waylandplatform.cpp index 33b36f90..cf67691c 100644 --- a/src/waylandplatform.cpp +++ b/src/waylandplatform.cpp @@ -12,12 +12,17 @@ #include +#include +#include #include #include +#include #include "waylandplatform.h" #include "windowdata.h" +using namespace LayerShellQt; + namespace Maliit { @@ -35,8 +40,26 @@ WaylandPlatform::WaylandPlatform() void WaylandPlatform::setupInputPanel(QWindow* window, Maliit::Position position) { - Q_UNUSED(window) - Q_UNUSED(position) + if (qgetenv("QT_WAYLAND_SHELL_INTEGRATION") == QByteArray("layer-shell")) { + auto ls_window = Window::get(window); + ls_window->setDesiredOutput(QGuiApplication::primaryScreen()); + ls_window->setLayer(Window::Layer::LayerOverlay); + Window::Anchors anchors = Window::Anchor::AnchorBottom; + switch (position) { + case PositionLeftBottom: { + anchors |= Window::Anchor::AnchorLeft; + break; + } + case PositionRightBottom: { + anchors |= Window::Anchor::AnchorRight; + break; + } + default: { + break; + } + } + ls_window->setAnchors(anchors); + } } void WaylandPlatform::setInputRegion(QWindow* window,