wayland: Implement GetDisplayBounds
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61
diff --git a/src/video/wayland/SDL_waylandvideo.c b/src/video/wayland/SDL_waylandvideo.c
index ea5e5b2..b0cc5a8 100644
--- a/src/video/wayland/SDL_waylandvideo.c
+++ b/src/video/wayland/SDL_waylandvideo.c
@@ -62,6 +62,8 @@ static void
Wayland_GetDisplayModes(_THIS, SDL_VideoDisplay *sdl_display);
static int
Wayland_SetDisplayMode(_THIS, SDL_VideoDisplay *display, SDL_DisplayMode *mode);
+static int
+Wayland_GetDisplayBounds(_THIS, SDL_VideoDisplay *display, SDL_Rect *rect);
static void
Wayland_VideoQuit(_THIS);
@@ -179,6 +181,7 @@ Wayland_CreateDevice(int devindex)
device->VideoQuit = Wayland_VideoQuit;
device->SetDisplayMode = Wayland_SetDisplayMode;
device->GetDisplayModes = Wayland_GetDisplayModes;
+ device->GetDisplayBounds = Wayland_GetDisplayBounds;
device->GetWindowWMInfo = Wayland_GetWindowWMInfo;
device->SuspendScreenSaver = Wayland_SuspendScreenSaver;
@@ -251,6 +254,8 @@ display_handle_geometry(void *data,
{
SDL_WaylandOutputData *driverdata = data;
+ driverdata->x = x;
+ driverdata->y = y;
driverdata->placeholder.name = SDL_strdup(model);
driverdata->transform = transform;
}
@@ -513,6 +518,17 @@ Wayland_SetDisplayMode(_THIS, SDL_VideoDisplay *display, SDL_DisplayMode *mode)
return SDL_Unsupported();
}
+static int
+Wayland_GetDisplayBounds(_THIS, SDL_VideoDisplay *display, SDL_Rect *rect)
+{
+ SDL_WaylandOutputData *driverdata = (SDL_WaylandOutputData *)display->driverdata;
+ rect->x = driverdata->x;
+ rect->y = driverdata->y;
+ rect->w = display->current_mode.w;
+ rect->h = display->current_mode.h;
+ return 0;
+}
+
void
Wayland_VideoQuit(_THIS)
{
diff --git a/src/video/wayland/SDL_waylandvideo.h b/src/video/wayland/SDL_waylandvideo.h
index 1c01dfd..91dac36 100644
--- a/src/video/wayland/SDL_waylandvideo.h
+++ b/src/video/wayland/SDL_waylandvideo.h
@@ -93,7 +93,7 @@ typedef struct {
typedef struct {
struct wl_output *output;
float scale_factor;
- int width, height, refresh, transform;
+ int x, y, width, height, refresh, transform;
SDL_VideoDisplay placeholder;
SDL_bool done;
} SDL_WaylandOutputData;