More work with xdg_shell

This commit is contained in:
Deve 2018-01-10 21:31:54 +01:00
parent 74b071494c
commit 4f9b46b20c
2 changed files with 94 additions and 80 deletions

View File

@ -566,18 +566,17 @@ public:
return; return;
std::string interface_str = interface; std::string interface_str = interface;
printf("interface: %s\n", interface_str.c_str());
if (interface_str == "wl_compositor") if (interface_str == "wl_compositor")
{ {
device->m_compositor = static_cast<wl_compositor*>(wl_registry_bind( device->m_compositor = static_cast<wl_compositor*>(wl_registry_bind(
registry, name, &wl_compositor_interface, 1)); registry, name, &wl_compositor_interface, 1));
} }
//~ else if (interface_str == "wl_shell") else if (interface_str == "wl_shell")
//~ { {
//~ device->m_shell = static_cast<wl_shell*>(wl_registry_bind(registry, device->m_shell = static_cast<wl_shell*>(wl_registry_bind(registry,
//~ name, &wl_shell_interface, 1)); name, &wl_shell_interface, 1));
//~ } }
else if (interface_str == "wl_seat") else if (interface_str == "wl_seat")
{ {
device->m_seat = static_cast<wl_seat*>(wl_registry_bind(registry, device->m_seat = static_cast<wl_seat*>(wl_registry_bind(registry,
@ -715,8 +714,8 @@ CIrrDeviceWayland::CIrrDeviceWayland(const SIrrlichtCreationParameters& params)
m_pointer = NULL; m_pointer = NULL;
m_registry = NULL; m_registry = NULL;
m_seat = NULL; m_seat = NULL;
//~ m_shell = NULL; m_shell = NULL;
//~ m_shell_surface = NULL; m_shell_surface = NULL;
m_shm = NULL; m_shm = NULL;
m_cursor_surface = NULL; m_cursor_surface = NULL;
m_surface = NULL; m_surface = NULL;
@ -774,9 +773,13 @@ CIrrDeviceWayland::CIrrDeviceWayland(const SIrrlichtCreationParameters& params)
createKeyMap(); createKeyMap();
m_display = wl_display_connect(NULL); m_display = wl_display_connect(NULL);
m_registry = wl_display_get_registry(m_display); m_registry = wl_display_get_registry(m_display);
wl_registry_add_listener(m_registry, &WaylandCallbacks::registry_listener, this); wl_registry_add_listener(m_registry, &WaylandCallbacks::registry_listener,
this);
wl_display_dispatch(m_display); wl_display_dispatch(m_display);
wl_display_roundtrip(m_display);
m_xkb_context = xkb_context_new(XKB_CONTEXT_NO_FLAGS); m_xkb_context = xkb_context_new(XKB_CONTEXT_NO_FLAGS);
@ -790,8 +793,6 @@ CIrrDeviceWayland::CIrrDeviceWayland(const SIrrlichtCreationParameters& params)
if (VideoDriver) if (VideoDriver)
createGUIAndScene(); createGUIAndScene();
wl_display_dispatch(m_display);
} }
//! destructor //! destructor
@ -805,9 +806,6 @@ CIrrDeviceWayland::~CIrrDeviceWayland()
if (m_decoration_manager) if (m_decoration_manager)
org_kde_kwin_server_decoration_manager_destroy(m_decoration_manager); org_kde_kwin_server_decoration_manager_destroy(m_decoration_manager);
if (m_egl_window)
wl_egl_window_destroy(m_egl_window);
if (m_keyboard) if (m_keyboard)
wl_keyboard_destroy(m_keyboard); wl_keyboard_destroy(m_keyboard);
@ -829,11 +827,14 @@ CIrrDeviceWayland::~CIrrDeviceWayland()
if (m_xdg_shell) if (m_xdg_shell)
zxdg_shell_v6_destroy(m_xdg_shell); zxdg_shell_v6_destroy(m_xdg_shell);
//~ if (m_shell_surface) if (m_shell_surface)
//~ wl_shell_surface_destroy(m_shell_surface); wl_shell_surface_destroy(m_shell_surface);
//~ if (m_shell) if (m_shell)
//~ wl_shell_destroy(m_shell); wl_shell_destroy(m_shell);
if (m_egl_window)
wl_egl_window_destroy(m_egl_window);
if (m_surface) if (m_surface)
wl_surface_destroy(m_surface); wl_surface_destroy(m_surface);
@ -924,30 +925,28 @@ bool CIrrDeviceWayland::initEGL()
bool CIrrDeviceWayland::createWindow() bool CIrrDeviceWayland::createWindow()
{ {
m_surface = wl_compositor_create_surface(m_compositor); m_surface = wl_compositor_create_surface(m_compositor);
//~ m_shell_surface = wl_shell_get_shell_surface(m_shell, m_surface);
//~ wl_shell_surface_add_listener(m_shell_surface, bool success = initEGL();
//~ &WaylandCallbacks::shell_surface_listener, this);
//~ if (CreationParams.Fullscreen) if (!success)
//~ { {
//~ wl_shell_surface_set_fullscreen(m_shell_surface, os::Printer::log("Couldn't create OpenGL context.", ELL_ERROR);
//~ WL_SHELL_SURFACE_FULLSCREEN_METHOD_DEFAULT, 0, m_output); return false;
//~ } }
//~ else
//~ {
//~ wl_shell_surface_set_toplevel(m_shell_surface);
//~ }
if (m_xdg_shell != NULL)
{
m_xdg_surface = zxdg_shell_v6_get_xdg_surface(m_xdg_shell, m_surface); m_xdg_surface = zxdg_shell_v6_get_xdg_surface(m_xdg_shell, m_surface);
zxdg_surface_v6_add_listener(m_xdg_surface, zxdg_surface_v6_add_listener(m_xdg_surface,
&WaylandCallbacks::xdg_surface_listener, this); &WaylandCallbacks::xdg_surface_listener,
this);
m_xdg_toplevel = zxdg_surface_v6_get_toplevel(m_xdg_surface); m_xdg_toplevel = zxdg_surface_v6_get_toplevel(m_xdg_surface);
zxdg_toplevel_v6_add_listener(m_xdg_toplevel, zxdg_toplevel_v6_add_listener(m_xdg_toplevel,
&WaylandCallbacks::xdg_toplevel_listener, this); &WaylandCallbacks::xdg_toplevel_listener,
this);
wl_surface_commit(m_surface); wl_surface_commit(m_surface);
@ -956,6 +955,36 @@ bool CIrrDeviceWayland::createWindow()
zxdg_toplevel_v6_set_fullscreen(m_xdg_toplevel, NULL); zxdg_toplevel_v6_set_fullscreen(m_xdg_toplevel, NULL);
} }
zxdg_surface_v6_set_window_geometry(m_xdg_surface, 0, 0, m_width,
m_height);
}
else if (m_shell != NULL)
{
m_shell_surface = wl_shell_get_shell_surface(m_shell, m_surface);
wl_shell_surface_add_listener(m_shell_surface,
&WaylandCallbacks::shell_surface_listener,
this);
if (CreationParams.Fullscreen)
{
wl_shell_surface_set_fullscreen(m_shell_surface,
WL_SHELL_SURFACE_FULLSCREEN_METHOD_DEFAULT, 0, m_output);
}
else
{
wl_shell_surface_set_toplevel(m_shell_surface);
}
}
else
{
os::Printer::log("Couldn't create shell surface.", ELL_ERROR);
return false;
}
wl_display_dispatch(m_display);
wl_display_roundtrip(m_display);
if (m_decoration_manager != NULL) if (m_decoration_manager != NULL)
{ {
m_decoration = org_kde_kwin_server_decoration_manager_create( m_decoration = org_kde_kwin_server_decoration_manager_create(
@ -968,25 +997,11 @@ bool CIrrDeviceWayland::createWindow()
ORG_KDE_KWIN_SERVER_DECORATION_MODE_SERVER); ORG_KDE_KWIN_SERVER_DECORATION_MODE_SERVER);
} }
wl_display_flush(m_display);
bool success = initEGL();
if (!success)
{
os::Printer::log("Couldn't create OpenGL context.", ELL_ERROR);
return false;
}
zxdg_surface_v6_set_window_geometry(m_xdg_surface, 0, 0, m_width, m_height);
wl_region* region = wl_compositor_create_region(m_compositor); wl_region* region = wl_compositor_create_region(m_compositor);
wl_region_add(region, 0, 0, m_width, m_height); wl_region_add(region, 0, 0, m_width, m_height);
wl_surface_set_opaque_region(m_surface, region); wl_surface_set_opaque_region(m_surface, region);
wl_region_destroy(region); wl_region_destroy(region);
wl_display_flush(m_display);
m_cursor_surface = wl_compositor_create_surface(m_compositor); m_cursor_surface = wl_compositor_create_surface(m_compositor);
m_cursor_theme = wl_cursor_theme_load(NULL, 32, m_shm); m_cursor_theme = wl_cursor_theme_load(NULL, 32, m_shm);
@ -1007,7 +1022,6 @@ bool CIrrDeviceWayland::createWindow()
return true; return true;
} }
//! create the driver
void CIrrDeviceWayland::createDriver() void CIrrDeviceWayland::createDriver()
{ {
switch(CreationParams.DriverType) switch(CreationParams.DriverType)
@ -1122,32 +1136,32 @@ void CIrrDeviceWayland::sleep(u32 timeMs, bool pauseTimer=false)
//! sets the caption of the window //! sets the caption of the window
void CIrrDeviceWayland::setWindowCaption(const wchar_t* text) void CIrrDeviceWayland::setWindowCaption(const wchar_t* text)
{ {
//~ if (!m_shell_surface)
//~ return;
if (!m_xdg_toplevel)
return;
char title[1024]; char title[1024];
wcstombs(title, text, sizeof(title)); wcstombs(title, text, sizeof(title));
title[1023] = '\0'; title[1023] = '\0';
//~ wl_shell_surface_set_title(m_shell_surface, title); if (m_xdg_toplevel)
{
zxdg_toplevel_v6_set_title(m_xdg_toplevel, title); zxdg_toplevel_v6_set_title(m_xdg_toplevel, title);
} }
else if (m_shell_surface)
{
wl_shell_surface_set_title(m_shell_surface, title);
}
}
//! sets the class of the window //! sets the class of the window
void CIrrDeviceWayland::setWindowClass(const char* text) void CIrrDeviceWayland::setWindowClass(const char* text)
{ {
//~ if (!m_shell_surface) if (m_xdg_toplevel)
//~ return; {
if (!m_xdg_toplevel)
return;
//~ wl_shell_surface_set_class(m_shell_surface, text);
zxdg_toplevel_v6_set_app_id(m_xdg_toplevel, text); zxdg_toplevel_v6_set_app_id(m_xdg_toplevel, text);
} }
else if (m_shell_surface)
{
wl_shell_surface_set_class(m_shell_surface, text);
}
}
//! presents a surface in the client area //! presents a surface in the client area
bool CIrrDeviceWayland::present(video::IImage* image, void* windowId, bool CIrrDeviceWayland::present(video::IImage* image, void* windowId,

View File

@ -173,8 +173,8 @@ namespace irr
wl_pointer* m_pointer; wl_pointer* m_pointer;
wl_registry* m_registry; wl_registry* m_registry;
wl_seat* m_seat; wl_seat* m_seat;
//~ wl_shell* m_shell; wl_shell* m_shell;
//~ wl_shell_surface* m_shell_surface; wl_shell_surface* m_shell_surface;
wl_shm* m_shm; wl_shm* m_shm;
wl_surface* m_cursor_surface; wl_surface* m_cursor_surface;
wl_surface* m_surface; wl_surface* m_surface;