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

Side by Side Diff: ui/views/mus/window_manager_connection.h

Issue 2163453002: mus: Change PointerWatcher to watch for all events. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Add back location Created 4 years, 5 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 unified diff | Download patch
OLDNEW
1 // Copyright 2015 The Chromium Authors. All rights reserved. 1 // Copyright 2015 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #ifndef UI_VIEWS_MUS_WINDOW_MANAGER_CONNECTION_H_ 5 #ifndef UI_VIEWS_MUS_WINDOW_MANAGER_CONNECTION_H_
6 #define UI_VIEWS_MUS_WINDOW_MANAGER_CONNECTION_H_ 6 #define UI_VIEWS_MUS_WINDOW_MANAGER_CONNECTION_H_
7 7
8 #include <stdint.h> 8 #include <stdint.h>
9 9
10 #include <map> 10 #include <map>
(...skipping 10 matching lines...) Expand all
21 #include "ui/views/widget/widget.h" 21 #include "ui/views/widget/widget.h"
22 22
23 namespace shell { 23 namespace shell {
24 class Connector; 24 class Connector;
25 } 25 }
26 26
27 namespace views { 27 namespace views {
28 class ClipboardMus; 28 class ClipboardMus;
29 class NativeWidget; 29 class NativeWidget;
30 class PointerWatcher; 30 class PointerWatcher;
31 class TouchEventWatcher;
32 class ScreenMus; 31 class ScreenMus;
33 namespace internal { 32 namespace internal {
34 class NativeWidgetDelegate; 33 class NativeWidgetDelegate;
35 } 34 }
36 35
37 // Provides configuration to mus in views. This consists of the following: 36 // Provides configuration to mus in views. This consists of the following:
38 // . Provides a Screen implementation backed by mus. 37 // . Provides a Screen implementation backed by mus.
39 // . Provides a Clipboard implementation backed by mus. 38 // . Provides a Clipboard implementation backed by mus.
40 // . Creates and owns a WindowTreeClient. 39 // . Creates and owns a WindowTreeClient.
41 // . Registers itself as the factory for creating NativeWidgets so that a 40 // . Registers itself as the factory for creating NativeWidgets so that a
(...skipping 16 matching lines...) Expand all
58 shell::Connector* connector() { return connector_; } 57 shell::Connector* connector() { return connector_; }
59 58
60 ui::Window* NewWindow( 59 ui::Window* NewWindow(
61 const std::map<std::string, std::vector<uint8_t>>& properties); 60 const std::map<std::string, std::vector<uint8_t>>& properties);
62 61
63 NativeWidget* CreateNativeWidgetMus( 62 NativeWidget* CreateNativeWidgetMus(
64 const std::map<std::string, std::vector<uint8_t>>& properties, 63 const std::map<std::string, std::vector<uint8_t>>& properties,
65 const Widget::InitParams& init_params, 64 const Widget::InitParams& init_params,
66 internal::NativeWidgetDelegate* delegate); 65 internal::NativeWidgetDelegate* delegate);
67 66
68 void AddPointerWatcher(PointerWatcher* watcher); 67 void AddPointerWatcher(PointerWatcher* watcher,
68 ui::EventPointerType type,
69 bool want_moves);
69 void RemovePointerWatcher(PointerWatcher* watcher); 70 void RemovePointerWatcher(PointerWatcher* watcher);
70 71
71 void AddTouchEventWatcher(TouchEventWatcher* watcher);
72 void RemoveTouchEventWatcher(TouchEventWatcher* watcher);
73
74 const std::set<ui::Window*>& GetRoots() const; 72 const std::set<ui::Window*>& GetRoots() const;
75 73
76 private: 74 private:
77 friend class WindowManagerConnectionTest; 75 friend class WindowManagerConnectionTest;
78 76
79 WindowManagerConnection(shell::Connector* connector, 77 WindowManagerConnection(shell::Connector* connector,
80 const shell::Identity& identity); 78 const shell::Identity& identity);
81 79
82 // Returns true if there is one or more watchers for this client. 80 // Returns true if there is one or more watchers for this client.
83 bool HasPointerWatcher(); 81 bool HasPointerWatcher();
84 bool HasTouchEventWatcher();
85 82
86 // ui::WindowTreeClientDelegate: 83 // ui::WindowTreeClientDelegate:
87 void OnEmbed(ui::Window* root) override; 84 void OnEmbed(ui::Window* root) override;
88 void OnDidDestroyClient(ui::WindowTreeClient* client) override; 85 void OnDidDestroyClient(ui::WindowTreeClient* client) override;
89 void OnEventObserved(const ui::Event& event, ui::Window* target) override; 86 void OnEventObserved(const ui::Event& event, ui::Window* target) override;
90 87
91 // ScreenMusDelegate: 88 // ScreenMusDelegate:
92 void OnWindowManagerFrameValuesChanged() override; 89 void OnWindowManagerFrameValuesChanged() override;
93 gfx::Point GetCursorScreenPoint() override; 90 gfx::Point GetCursorScreenPoint() override;
94 91
95 shell::Connector* connector_; 92 shell::Connector* connector_;
96 shell::Identity identity_; 93 shell::Identity identity_;
97 std::unique_ptr<ScreenMus> screen_; 94 std::unique_ptr<ScreenMus> screen_;
98 std::unique_ptr<ui::WindowTreeClient> client_; 95 std::unique_ptr<ui::WindowTreeClient> client_;
99 // Must be empty on destruction. 96 // Must be empty on destruction.
100 base::ObserverList<PointerWatcher, true> pointer_watchers_; 97 base::ObserverList<PointerWatcher, true> pointer_watchers_;
101 base::ObserverList<TouchEventWatcher, true> touch_event_watchers_; 98 ui::EventPointerType event_pointer_type_;
102 99
103 DISALLOW_COPY_AND_ASSIGN(WindowManagerConnection); 100 DISALLOW_COPY_AND_ASSIGN(WindowManagerConnection);
104 }; 101 };
105 102
106 } // namespace views 103 } // namespace views
107 104
108 #endif // UI_VIEWS_MUS_WINDOW_MANAGER_CONNECTION_H_ 105 #endif // UI_VIEWS_MUS_WINDOW_MANAGER_CONNECTION_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698