Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1302)

Unified Diff: components/mus/public/interfaces/window_tree.mojom

Issue 1909733002: mus: Add EventObserver to allow passively listening to UI events (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: rebase Created 4 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « components/mus/public/interfaces/input_event_matcher.mojom ('k') | components/mus/ws/BUILD.gn » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: components/mus/public/interfaces/window_tree.mojom
diff --git a/components/mus/public/interfaces/window_tree.mojom b/components/mus/public/interfaces/window_tree.mojom
index eb2ef580ef31b7b8fb99e0eab0494d16f6976ed4..f899c62f81e65cd9b66e6cb6943dc8e64b22f5eb 100644
--- a/components/mus/public/interfaces/window_tree.mojom
+++ b/components/mus/public/interfaces/window_tree.mojom
@@ -7,6 +7,7 @@ module mus.mojom;
import "components/mus/public/interfaces/compositor_frame.mojom";
import "components/mus/public/interfaces/cursor.mojom";
import "components/mus/public/interfaces/input_events.mojom";
+import "components/mus/public/interfaces/input_event_matcher.mojom";
import "components/mus/public/interfaces/mus_constants.mojom";
import "components/mus/public/interfaces/surface_id.mojom";
import "components/mus/public/interfaces/window_manager.mojom";
@@ -109,6 +110,14 @@ interface WindowTree {
// if |window_id| does not currently have capture.
ReleaseCapture(uint32 change_id, uint32 window_id);
+ // Sets an observer that monitors all events, even if they are not targeted
+ // at a window in this tree. If an event matchs |matcher| the observer reports
+ // it to the WindowTreeClient via OnWindowInputEvent (if the event target is
+ // this window tree) or OnEventObserved (if the target is another tree). The
+ // client must supply a non-zero |observer_id|, which is reported back with
+ // observed events. Set the matcher to null to clear the observer.
+ SetEventObserver(EventMatcher? matcher, uint32 observer_id);
sadrul 2016/04/23 01:24:39 This feels fairly awkward. What happens if multipl
James Cook 2016/04/25 16:23:35 I don't understand. You can't have multiple EventM
sadrul 2016/04/25 16:33:34 I realized this after I left the comment. My initi
James Cook 2016/04/25 16:52:00 I agree that the observer_id thing feels weird (yo
+
// Sets the specified bounds of the specified window.
SetWindowBounds(uint32 change_id, uint32 window_id, mojo.Rect bounds);
@@ -358,9 +367,18 @@ interface WindowTreeClient {
// Invoked when an event is targeted at the specified window. The client must
// call WindowTree::OnWindowInputEventAck() with the same |event_id| to notify
// that the event has been processed, and with an EventResult value to notify
- // if the event was consumed. The client will not receive farther events until
- // the event is ack'ed.
- OnWindowInputEvent(uint32 event_id, uint32 window, Event event);
+ // if the event was consumed. |event_observer_id| is non-zero if the event
+ // also matched the active event observer for this client. The client will not
+ // receive farther events until the event is ack'ed.
+ OnWindowInputEvent(uint32 event_id,
+ uint32 window,
+ Event event,
+ uint32 event_observer_id);
+
+ // Invoked when an |event| is sent via the EventObserver and not targeted at a
+ // specific window. The |event_observer_id| is the one supplied to
+ // SetEventObserver. The client should not acknowledge these events.
+ OnEventObserved(Event event, uint32 event_observer_id);
// Called in two distinct cases: when a window known to the connection gains
// focus, or when focus moves from a window known to the connection to a
« no previous file with comments | « components/mus/public/interfaces/input_event_matcher.mojom ('k') | components/mus/ws/BUILD.gn » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698