mirror of
https://github.com/hyprwm/wlroots-hyprland.git
synced 2024-11-29 16:05:59 +01:00
Find layer surfaces for input events
This commit is contained in:
parent
662f40b8ae
commit
dc412c514b
3 changed files with 64 additions and 11 deletions
|
@ -1,6 +1,5 @@
|
||||||
#ifndef ROOTSTON_DESKTOP_H
|
#ifndef ROOTSTON_DESKTOP_H
|
||||||
#define ROOTSTON_DESKTOP_H
|
#define ROOTSTON_DESKTOP_H
|
||||||
|
|
||||||
#include <time.h>
|
#include <time.h>
|
||||||
#include <wayland-server.h>
|
#include <wayland-server.h>
|
||||||
#include <wlr/config.h>
|
#include <wlr/config.h>
|
||||||
|
@ -74,8 +73,6 @@ void desktop_destroy(struct roots_desktop *desktop);
|
||||||
struct roots_output *desktop_output_from_wlr_output(
|
struct roots_output *desktop_output_from_wlr_output(
|
||||||
struct roots_desktop *desktop, struct wlr_output *output);
|
struct roots_desktop *desktop, struct wlr_output *output);
|
||||||
|
|
||||||
struct roots_view *desktop_view_at(struct roots_desktop *desktop, double lx,
|
|
||||||
double ly, struct wlr_surface **surface, double *sx, double *sy);
|
|
||||||
struct wlr_surface *desktop_surface_at(struct roots_desktop *desktop,
|
struct wlr_surface *desktop_surface_at(struct roots_desktop *desktop,
|
||||||
double lx, double ly, double *sx, double *sy,
|
double lx, double ly, double *sx, double *sy,
|
||||||
struct roots_view **view);
|
struct roots_view **view);
|
||||||
|
|
|
@ -1,6 +1,5 @@
|
||||||
#ifndef ROOTSTON_OUTPUT_H
|
#ifndef ROOTSTON_OUTPUT_H
|
||||||
#define ROOTSTON_OUTPUT_H
|
#define ROOTSTON_OUTPUT_H
|
||||||
|
|
||||||
#include <pixman.h>
|
#include <pixman.h>
|
||||||
#include <time.h>
|
#include <time.h>
|
||||||
#include <wayland-server.h>
|
#include <wayland-server.h>
|
||||||
|
|
|
@ -20,10 +20,12 @@
|
||||||
#include <wlr/types/wlr_xdg_shell_v6.h>
|
#include <wlr/types/wlr_xdg_shell_v6.h>
|
||||||
#include <wlr/types/wlr_xdg_shell.h>
|
#include <wlr/types/wlr_xdg_shell.h>
|
||||||
#include <wlr/util/log.h>
|
#include <wlr/util/log.h>
|
||||||
|
#include "rootston/layers.h"
|
||||||
#include "rootston/seat.h"
|
#include "rootston/seat.h"
|
||||||
#include "rootston/server.h"
|
#include "rootston/server.h"
|
||||||
#include "rootston/view.h"
|
#include "rootston/view.h"
|
||||||
#include "rootston/xcursor.h"
|
#include "rootston/xcursor.h"
|
||||||
|
#include "wlr-layer-shell-unstable-v1-protocol.h"
|
||||||
|
|
||||||
struct roots_view *view_create(struct roots_desktop *desktop) {
|
struct roots_view *view_create(struct roots_desktop *desktop) {
|
||||||
struct roots_view *view = calloc(1, sizeof(struct roots_view));
|
struct roots_view *view = calloc(1, sizeof(struct roots_view));
|
||||||
|
@ -632,8 +634,9 @@ static bool view_at(struct roots_view *view, double lx, double ly,
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
struct roots_view *desktop_view_at(struct roots_desktop *desktop, double lx,
|
static struct roots_view *desktop_view_at(struct roots_desktop *desktop,
|
||||||
double ly, struct wlr_surface **surface, double *sx, double *sy) {
|
double lx, double ly, struct wlr_surface **surface,
|
||||||
|
double *sx, double *sy) {
|
||||||
struct wlr_output *wlr_output =
|
struct wlr_output *wlr_output =
|
||||||
wlr_output_layout_output_at(desktop->layout, lx, ly);
|
wlr_output_layout_output_at(desktop->layout, lx, ly);
|
||||||
if (wlr_output != NULL) {
|
if (wlr_output != NULL) {
|
||||||
|
@ -657,22 +660,76 @@ struct roots_view *desktop_view_at(struct roots_desktop *desktop, double lx,
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static struct wlr_surface *layer_surface_at(struct roots_output *output,
|
||||||
|
struct wl_list *layer, double ox, double oy, double *sx, double *sy) {
|
||||||
|
struct roots_layer_surface *roots_surface;
|
||||||
|
wl_list_for_each_reverse(roots_surface, layer, link) {
|
||||||
|
struct wlr_surface *wlr_surface =
|
||||||
|
roots_surface->layer_surface->surface;
|
||||||
|
double _sx = ox - roots_surface->geo.x;
|
||||||
|
double _sy = oy - roots_surface->geo.y;
|
||||||
|
struct wlr_box box = {
|
||||||
|
.x = 0, .y = 0,
|
||||||
|
.width = roots_surface->geo.width,
|
||||||
|
.height = roots_surface->geo.height,
|
||||||
|
};
|
||||||
|
// TODO: Test popups/subsurfaces
|
||||||
|
if (wlr_box_contains_point(&box, _sx, _sy) &&
|
||||||
|
pixman_region32_contains_point(&wlr_surface->current->input,
|
||||||
|
_sx, _sy, NULL)) {
|
||||||
|
*sx = _sx;
|
||||||
|
*sy = _sy;
|
||||||
|
return wlr_surface;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
struct wlr_surface *desktop_surface_at(struct roots_desktop *desktop,
|
struct wlr_surface *desktop_surface_at(struct roots_desktop *desktop,
|
||||||
double lx, double ly, double *sx, double *sy,
|
double lx, double ly, double *sx, double *sy,
|
||||||
struct roots_view **view) {
|
struct roots_view **view) {
|
||||||
//struct wlr_output *wlr_output =
|
struct wlr_surface *surface = NULL;
|
||||||
// wlr_output_layout_output_at(desktop->layout, lx, ly);
|
struct wlr_output *wlr_output =
|
||||||
// TODO: Iterate over layers
|
wlr_output_layout_output_at(desktop->layout, lx, ly);
|
||||||
|
struct roots_output *roots_output;
|
||||||
|
double ox, oy;
|
||||||
|
if (wlr_output) {
|
||||||
|
roots_output = wlr_output->data;
|
||||||
|
wlr_output_layout_output_coords(desktop->layout, wlr_output, &ox, &oy);
|
||||||
|
|
||||||
|
if ((surface = layer_surface_at(roots_output,
|
||||||
|
&roots_output->layers[ZWLR_LAYER_SHELL_V1_LAYER_OVERLAY],
|
||||||
|
ox, oy, sx, sy))) {
|
||||||
|
return surface;
|
||||||
|
}
|
||||||
|
if ((surface = layer_surface_at(roots_output,
|
||||||
|
&roots_output->layers[ZWLR_LAYER_SHELL_V1_LAYER_TOP],
|
||||||
|
ox, oy, sx, sy))) {
|
||||||
|
return surface;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
*view = NULL;
|
*view = NULL;
|
||||||
struct roots_view *_view;
|
struct roots_view *_view;
|
||||||
struct wlr_surface *surface = NULL;
|
|
||||||
if ((_view = desktop_view_at(desktop, lx, ly, &surface, sx, sy))) {
|
if ((_view = desktop_view_at(desktop, lx, ly, &surface, sx, sy))) {
|
||||||
if (view) {
|
if (view) {
|
||||||
*view = _view;
|
*view = _view;
|
||||||
}
|
}
|
||||||
return surface;
|
return surface;
|
||||||
}
|
}
|
||||||
// TODO: Iterate over layers
|
|
||||||
|
if (wlr_output) {
|
||||||
|
if ((surface = layer_surface_at(roots_output,
|
||||||
|
&roots_output->layers[ZWLR_LAYER_SHELL_V1_LAYER_BOTTOM],
|
||||||
|
ox, oy, sx, sy))) {
|
||||||
|
return surface;
|
||||||
|
}
|
||||||
|
if ((surface = layer_surface_at(roots_output,
|
||||||
|
&roots_output->layers[ZWLR_LAYER_SHELL_V1_LAYER_BACKGROUND],
|
||||||
|
ox, oy, sx, sy))) {
|
||||||
|
return surface;
|
||||||
|
}
|
||||||
|
}
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue