Use new wlr_*_surface_at functions

This commit is contained in:
emersion 2018-04-04 17:57:12 -04:00 committed by Drew DeVault
parent 8eff00f723
commit 44b8d30f52
2 changed files with 15 additions and 32 deletions

View file

@ -204,8 +204,6 @@ static void render_view(struct sway_container *view, void *data) {
case SWAY_VIEW_XWAYLAND: case SWAY_VIEW_XWAYLAND:
render_surface(surface, wlr_output, when, view->x, view->y, 0, alpha); render_surface(surface, wlr_output, when, view->x, view->y, 0, alpha);
break; break;
default:
break;
} }
} }

View file

@ -412,9 +412,17 @@ struct sway_container *container_at(struct sway_container *parent,
double view_sx = ox - swayc->x; double view_sx = ox - swayc->x;
double view_sy = oy - swayc->y; double view_sy = oy - swayc->y;
double _sx, _sy;
struct wlr_surface *_surface;
switch (sview->type) { switch (sview->type) {
case SWAY_VIEW_XWAYLAND: case SWAY_VIEW_XWAYLAND:
_surface = wlr_surface_surface_at(sview->surface,
view_sx, view_sy, &_sx, &_sy);
break;
case SWAY_VIEW_WL_SHELL: case SWAY_VIEW_WL_SHELL:
_surface = wlr_wl_shell_surface_surface_at(
sview->wlr_wl_shell_surface,
view_sx, view_sy, &_sx, &_sy);
break; break;
case SWAY_VIEW_XDG_SHELL_V6: case SWAY_VIEW_XDG_SHELL_V6:
// the top left corner of the sway container is the // the top left corner of the sway container is the
@ -422,38 +430,15 @@ struct sway_container *container_at(struct sway_container *parent,
view_sx += sview->wlr_xdg_surface_v6->geometry.x; view_sx += sview->wlr_xdg_surface_v6->geometry.x;
view_sy += sview->wlr_xdg_surface_v6->geometry.y; view_sy += sview->wlr_xdg_surface_v6->geometry.y;
// check for popups _surface = wlr_xdg_surface_v6_surface_at(
double popup_sx, popup_sy; sview->wlr_xdg_surface_v6,
struct wlr_xdg_surface_v6 *popup = view_sx, view_sy, &_sx, &_sy);
wlr_xdg_surface_v6_popup_at(sview->wlr_xdg_surface_v6,
view_sx, view_sy, &popup_sx, &popup_sy);
if (popup) {
*sx = view_sx - popup_sx;
*sy = view_sy - popup_sy;
*surface = popup->surface;
return swayc;
}
break; break;
} }
if (_surface) {
// check for subsurfaces *sx = _sx;
double sub_x, sub_y; *sy = _sy;
struct wlr_subsurface *subsurface = *surface = _surface;
wlr_surface_subsurface_at(sview->surface,
view_sx, view_sy, &sub_x, &sub_y);
if (subsurface) {
*sx = view_sx - sub_x;
*sy = view_sy - sub_y;
*surface = subsurface->surface;
return swayc;
}
if (wlr_surface_point_accepts_input(
sview->surface, view_sx, view_sy)) {
*sx = view_sx;
*sy = view_sy;
*surface = swayc->sway_view->surface;
return swayc; return swayc;
} }
} else { } else {