scene: unify intersection logic in wlr_scene_node_at
Let's extract the common bits.
This commit is contained in:
parent
b25759cd20
commit
f6f0e010d1
|
@ -445,34 +445,29 @@ struct wlr_scene_node *wlr_scene_node_at(struct wlr_scene_node *node,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool intersects = false;
|
||||||
switch (node->type) {
|
switch (node->type) {
|
||||||
case WLR_SCENE_NODE_ROOT:
|
case WLR_SCENE_NODE_ROOT:
|
||||||
case WLR_SCENE_NODE_TREE:
|
case WLR_SCENE_NODE_TREE:
|
||||||
break;
|
break;
|
||||||
case WLR_SCENE_NODE_SURFACE:;
|
case WLR_SCENE_NODE_SURFACE:;
|
||||||
struct wlr_scene_surface *scene_surface = wlr_scene_surface_from_node(node);
|
struct wlr_scene_surface *scene_surface = wlr_scene_surface_from_node(node);
|
||||||
if (wlr_surface_point_accepts_input(scene_surface->surface, lx, ly)) {
|
intersects = wlr_surface_point_accepts_input(scene_surface->surface, lx, ly);
|
||||||
if (nx != NULL) {
|
|
||||||
*nx = lx;
|
|
||||||
}
|
|
||||||
if (ny != NULL) {
|
|
||||||
*ny = ly;
|
|
||||||
}
|
|
||||||
return &scene_surface->node;
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
case WLR_SCENE_NODE_RECT:;
|
case WLR_SCENE_NODE_RECT:;
|
||||||
struct wlr_scene_rect *rect = scene_rect_from_node(node);
|
struct wlr_scene_rect *rect = scene_rect_from_node(node);
|
||||||
if (lx >= 0 && lx < rect->width && ly >= 0 && ly < rect->height) {
|
intersects = lx >= 0 && lx < rect->width && ly >= 0 && ly < rect->height;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (intersects) {
|
||||||
if (nx != NULL) {
|
if (nx != NULL) {
|
||||||
*nx = lx;
|
*nx = lx;
|
||||||
}
|
}
|
||||||
if (ny != NULL) {
|
if (ny != NULL) {
|
||||||
*ny = ly;
|
*ny = ly;
|
||||||
}
|
}
|
||||||
return &rect->node;
|
return node;
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
Loading…
Reference in New Issue