OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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_WM_CORE_WINDOW_MODALITY_CONTROLLER_H_ | 5 #ifndef UI_WM_CORE_WINDOW_MODALITY_CONTROLLER_H_ |
6 #define UI_WM_CORE_WINDOW_MODALITY_CONTROLLER_H_ | 6 #define UI_WM_CORE_WINDOW_MODALITY_CONTROLLER_H_ |
7 | 7 |
8 #include <vector> | 8 #include <vector> |
9 | 9 |
10 #include "base/compiler_specific.h" | 10 #include "base/compiler_specific.h" |
11 #include "ui/aura/env_observer.h" | 11 #include "ui/aura/env_observer.h" |
12 #include "ui/aura/window_observer.h" | 12 #include "ui/aura/window_observer.h" |
13 #include "ui/events/event_handler.h" | 13 #include "ui/events/event_handler.h" |
14 #include "ui/wm/core/wm_core_export.h" | 14 #include "ui/wm/wm_export.h" |
15 | 15 |
16 namespace ui { | 16 namespace ui { |
17 class EventTarget; | 17 class EventTarget; |
18 class LocatedEvent; | 18 class LocatedEvent; |
19 } | 19 } |
20 | 20 |
21 namespace wm { | 21 namespace wm { |
22 | 22 |
23 // Sets the modal parent for the child. | 23 // Sets the modal parent for the child. |
24 WM_CORE_EXPORT void SetModalParent(aura::Window* child, aura::Window* parent); | 24 WM_EXPORT void SetModalParent(aura::Window* child, aura::Window* parent); |
25 | 25 |
26 // Returns the modal transient child of |window|, or NULL if |window| does not | 26 // Returns the modal transient child of |window|, or NULL if |window| does not |
27 // have any modal transient children. | 27 // have any modal transient children. |
28 WM_CORE_EXPORT aura::Window* GetModalTransient(aura::Window* window); | 28 WM_EXPORT aura::Window* GetModalTransient(aura::Window* window); |
29 | 29 |
30 // WindowModalityController is an event filter that consumes events sent to | 30 // WindowModalityController is an event filter that consumes events sent to |
31 // windows that are the transient parents of window-modal windows. This filter | 31 // windows that are the transient parents of window-modal windows. This filter |
32 // must be added to the CompoundEventFilter so that activation works properly. | 32 // must be added to the CompoundEventFilter so that activation works properly. |
33 class WM_CORE_EXPORT WindowModalityController : public ui::EventHandler, | 33 class WM_EXPORT WindowModalityController : public ui::EventHandler, |
34 public aura::EnvObserver, | 34 public aura::EnvObserver, |
35 public aura::WindowObserver { | 35 public aura::WindowObserver { |
36 public: | 36 public: |
37 explicit WindowModalityController(ui::EventTarget* event_target); | 37 explicit WindowModalityController(ui::EventTarget* event_target); |
38 virtual ~WindowModalityController(); | 38 virtual ~WindowModalityController(); |
39 | 39 |
40 // Overridden from ui::EventHandler: | 40 // Overridden from ui::EventHandler: |
41 virtual void OnKeyEvent(ui::KeyEvent* event) OVERRIDE; | 41 virtual void OnKeyEvent(ui::KeyEvent* event) OVERRIDE; |
42 virtual void OnMouseEvent(ui::MouseEvent* event) OVERRIDE; | 42 virtual void OnMouseEvent(ui::MouseEvent* event) OVERRIDE; |
43 virtual void OnTouchEvent(ui::TouchEvent* event) OVERRIDE; | 43 virtual void OnTouchEvent(ui::TouchEvent* event) OVERRIDE; |
44 | 44 |
45 // Overridden from aura::EnvObserver: | 45 // Overridden from aura::EnvObserver: |
(...skipping 16 matching lines...) Expand all Loading... |
62 std::vector<aura::Window*> windows_; | 62 std::vector<aura::Window*> windows_; |
63 | 63 |
64 ui::EventTarget* event_target_; | 64 ui::EventTarget* event_target_; |
65 | 65 |
66 DISALLOW_COPY_AND_ASSIGN(WindowModalityController); | 66 DISALLOW_COPY_AND_ASSIGN(WindowModalityController); |
67 }; | 67 }; |
68 | 68 |
69 } // namespace wm | 69 } // namespace wm |
70 | 70 |
71 #endif // UI_WM_CORE_WINDOW_MODALITY_CONTROLLER_H_ | 71 #endif // UI_WM_CORE_WINDOW_MODALITY_CONTROLLER_H_ |
OLD | NEW |