[mutter] surface-actor-wayland: Add API to pick a primary stage view
- From: Marge Bot <marge-bot src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [mutter] surface-actor-wayland: Add API to pick a primary stage view
- Date: Thu, 19 Nov 2020 19:03:50 +0000 (UTC)
commit ff94ed0ebff722d70204964af7a33513713ffd58
Author: Robert Mader <robert mader posteo de>
Date: Thu Oct 22 23:13:26 2020 +0200
surface-actor-wayland: Add API to pick a primary stage view
Add a simple heuristic how to choose the primary stage view to drive events
like frame callbacks for a given surface actor.
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/1468>
src/compositor/meta-surface-actor-wayland.c | 48 +++++++++++++++++++++++++++++
src/compositor/meta-surface-actor-wayland.h | 3 ++
2 files changed, 51 insertions(+)
---
diff --git a/src/compositor/meta-surface-actor-wayland.c b/src/compositor/meta-surface-actor-wayland.c
index b8071067bd..08b4f79f76 100644
--- a/src/compositor/meta-surface-actor-wayland.c
+++ b/src/compositor/meta-surface-actor-wayland.c
@@ -81,6 +81,54 @@ meta_surface_actor_wayland_try_acquire_scanout (MetaSurfaceActorWayland *self,
return scanout;
}
+#define UNOBSCURED_TRESHOLD 0.1
+
+ClutterStageView *
+meta_surface_actor_wayland_get_current_primary_view (MetaSurfaceActor *actor,
+ ClutterStage *stage)
+{
+ ClutterStageView *current_primary_view = NULL;
+ float highest_refresh_rate = 0;
+ float biggest_unobscurred_fraction = 0;
+ GList *l;
+
+ for (l = clutter_stage_peek_stage_views (stage); l; l = l->next)
+ {
+ ClutterStageView *stage_view = l->data;
+ float refresh_rate;
+ float unobscurred_fraction = 1.0;
+
+ if (clutter_actor_has_mapped_clones (CLUTTER_ACTOR (actor)))
+ {
+ if (!clutter_actor_is_effectively_on_stage_view (CLUTTER_ACTOR (actor),
+ stage_view))
+ continue;
+ }
+ else
+ {
+ if (meta_surface_actor_is_obscured_on_stage_view (actor,
+ stage_view,
+ &unobscurred_fraction))
+ continue;
+ }
+
+ refresh_rate = clutter_stage_view_get_refresh_rate (stage_view);
+
+ if ((refresh_rate > highest_refresh_rate &&
+ (unobscurred_fraction > UNOBSCURED_TRESHOLD ||
+ biggest_unobscurred_fraction < UNOBSCURED_TRESHOLD)) ||
+ (biggest_unobscurred_fraction < UNOBSCURED_TRESHOLD &&
+ unobscurred_fraction > UNOBSCURED_TRESHOLD))
+ {
+ current_primary_view = stage_view;
+ highest_refresh_rate = refresh_rate;
+ biggest_unobscurred_fraction = unobscurred_fraction;
+ }
+ }
+
+ return current_primary_view;
+}
+
static void
meta_surface_actor_wayland_dispose (GObject *object)
{
diff --git a/src/compositor/meta-surface-actor-wayland.h b/src/compositor/meta-surface-actor-wayland.h
index d61a4df572..10eb3326ae 100644
--- a/src/compositor/meta-surface-actor-wayland.h
+++ b/src/compositor/meta-surface-actor-wayland.h
@@ -55,6 +55,9 @@ void meta_surface_actor_wayland_add_frame_callbacks (MetaSurfaceActorWayland *se
CoglScanout * meta_surface_actor_wayland_try_acquire_scanout (MetaSurfaceActorWayland *self,
CoglOnscreen *onscreen);
+ClutterStageView * meta_surface_actor_wayland_get_current_primary_view (MetaSurfaceActor *actor,
+ ClutterStage *stage);
+
G_END_DECLS
#endif /* __META_SURFACE_ACTOR_WAYLAND_H__ */
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]