summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSimon Ser <[email protected]>2021-10-20 18:16:27 +0200
committerIsaac Freund <[email protected]>2021-10-22 22:29:35 +0200
commitad910d4a900f6f61affddc298d135324e4e09c62 (patch)
tree3e341856f76725819f5e7b1d371a0f618d7dcd68
parentd0da010a72e4d5eced4ea18fff280bb28ddd9d40 (diff)
scene: add wlr_scene_output_for_each_surface
This allows compositors to more easily implement sending wl_surface.frame callback done events.
-rw-r--r--wlr_scene.c38
1 files changed, 38 insertions, 0 deletions
diff --git a/wlr_scene.c b/wlr_scene.c
index 30d5deb..ddb6f21 100644
--- a/wlr_scene.c
+++ b/wlr_scene.c
@@ -887,3 +887,41 @@ bool wlr_scene_output_commit(struct wlr_scene_output *scene_output) {
return wlr_output_commit(output);
}
+
+static void scene_output_for_each_surface(const struct wlr_box *output_box,
+ struct wlr_scene_node *node, int lx, int ly,
+ wlr_surface_iterator_func_t user_iterator, void *user_data) {
+ if (!node->state.enabled) {
+ return;
+ }
+
+ lx += node->state.x;
+ ly += node->state.y;
+
+ if (node->type == WLR_SCENE_NODE_SURFACE) {
+ struct wlr_box node_box = { .x = lx, .y = ly };
+ scene_node_get_size(node, &node_box.width, &node_box.height);
+
+ struct wlr_box intersection;
+ if (wlr_box_intersection(&intersection, output_box, &node_box)) {
+ struct wlr_scene_surface *scene_surface =
+ wlr_scene_surface_from_node(node);
+ user_iterator(scene_surface->surface, lx, ly, user_data);
+ }
+ }
+
+ struct wlr_scene_node *child;
+ wl_list_for_each(child, &node->state.children, state.link) {
+ scene_output_for_each_surface(output_box, child, lx, ly,
+ user_iterator, user_data);
+ }
+}
+
+void wlr_scene_output_for_each_surface(struct wlr_scene_output *scene_output,
+ wlr_surface_iterator_func_t iterator, void *user_data) {
+ struct wlr_box box = { .x = scene_output->x, .y = scene_output->y };
+ wlr_output_effective_resolution(scene_output->output,
+ &box.width, &box.height);
+ scene_output_for_each_surface(&box, &scene_output->scene->node, 0, 0,
+ iterator, user_data);
+}