| OLD | NEW |
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 #include "mojo/services/view_manager/root_view_manager.h" | 5 #include "mojo/services/view_manager/root_view_manager.h" |
| 6 | 6 |
| 7 #include "base/auto_reset.h" | 7 #include "base/auto_reset.h" |
| 8 #include "base/scoped_observer.h" | 8 #include "base/scoped_observer.h" |
| 9 #include "mojo/public/cpp/application/application_connection.h" | 9 #include "mojo/public/cpp/application/application_connection.h" |
| 10 #include "mojo/services/view_manager/root_node_manager.h" | 10 #include "mojo/services/view_manager/root_node_manager.h" |
| 11 #include "mojo/services/view_manager/root_view_manager_delegate.h" | 11 #include "mojo/services/view_manager/root_view_manager_delegate.h" |
| 12 #include "mojo/services/view_manager/screen_impl.h" | 12 #include "mojo/services/view_manager/screen_impl.h" |
| 13 #include "mojo/services/view_manager/window_tree_host_impl.h" | 13 #include "mojo/services/view_manager/window_tree_host_impl.h" |
| 14 #include "ui/aura/client/default_capture_client.h" | 14 #include "ui/aura/client/default_capture_client.h" |
| 15 #include "ui/aura/client/focus_change_observer.h" | |
| 16 #include "ui/aura/client/focus_client.h" | 15 #include "ui/aura/client/focus_client.h" |
| 17 #include "ui/aura/client/window_tree_client.h" | 16 #include "ui/aura/client/window_tree_client.h" |
| 18 #include "ui/aura/window.h" | 17 #include "ui/aura/window.h" |
| 19 #include "ui/aura/window_observer.h" | 18 #include "ui/aura/window_observer.h" |
| 20 | 19 |
| 21 namespace mojo { | 20 namespace mojo { |
| 22 namespace service { | 21 namespace service { |
| 23 | 22 |
| 24 // TODO(sky): revisit this, we may need a more sophisticated FocusClient | 23 // TODO(sky): Remove once aura is removed from the service. |
| 25 // implementation. | 24 class FocusClientImpl : public aura::client::FocusClient { |
| 26 class FocusClientImpl : public aura::client::FocusClient, | |
| 27 public aura::WindowObserver { | |
| 28 public: | 25 public: |
| 29 FocusClientImpl() | 26 FocusClientImpl() {} |
| 30 : focused_window_(NULL), | |
| 31 observer_manager_(this) { | |
| 32 } | |
| 33 virtual ~FocusClientImpl() {} | 27 virtual ~FocusClientImpl() {} |
| 34 | 28 |
| 35 private: | 29 private: |
| 36 // Overridden from aura::client::FocusClient: | 30 // Overridden from aura::client::FocusClient: |
| 37 virtual void AddObserver(aura::client::FocusChangeObserver* observer) | 31 virtual void AddObserver( |
| 38 OVERRIDE { | 32 aura::client::FocusChangeObserver* observer) OVERRIDE {} |
| 39 observers_.AddObserver(observer); | 33 virtual void RemoveObserver( |
| 40 } | 34 aura::client::FocusChangeObserver* observer) OVERRIDE {} |
| 41 virtual void RemoveObserver(aura::client::FocusChangeObserver* observer) | 35 virtual void FocusWindow(aura::Window* window) OVERRIDE {} |
| 42 OVERRIDE { | 36 virtual void ResetFocusWithinActiveWindow(aura::Window* window) OVERRIDE {} |
| 43 observers_.RemoveObserver(observer); | 37 virtual aura::Window* GetFocusedWindow() OVERRIDE { return NULL; } |
| 44 } | |
| 45 virtual void FocusWindow(aura::Window* window) OVERRIDE { | |
| 46 if (window && !window->CanFocus()) | |
| 47 return; | |
| 48 if (window == focused_window_) | |
| 49 return; | |
| 50 if (focused_window_) | |
| 51 observer_manager_.Remove(focused_window_); | |
| 52 aura::Window* old_focused_window = focused_window_; | |
| 53 focused_window_ = window; | |
| 54 if (focused_window_) | |
| 55 observer_manager_.Add(focused_window_); | |
| 56 | |
| 57 FOR_EACH_OBSERVER(aura::client::FocusChangeObserver, | |
| 58 observers_, | |
| 59 OnWindowFocused(focused_window_, old_focused_window)); | |
| 60 aura::client::FocusChangeObserver* observer = | |
| 61 aura::client::GetFocusChangeObserver(old_focused_window); | |
| 62 if (observer) | |
| 63 observer->OnWindowFocused(focused_window_, old_focused_window); | |
| 64 observer = aura::client::GetFocusChangeObserver(focused_window_); | |
| 65 if (observer) | |
| 66 observer->OnWindowFocused(focused_window_, old_focused_window); | |
| 67 } | |
| 68 virtual void ResetFocusWithinActiveWindow(aura::Window* window) OVERRIDE { | |
| 69 if (!window->Contains(focused_window_)) | |
| 70 FocusWindow(window); | |
| 71 } | |
| 72 virtual aura::Window* GetFocusedWindow() OVERRIDE { | |
| 73 return focused_window_; | |
| 74 } | |
| 75 | |
| 76 // Overridden from WindowObserver: | |
| 77 virtual void OnWindowDestroying(aura::Window* window) OVERRIDE { | |
| 78 DCHECK_EQ(window, focused_window_); | |
| 79 FocusWindow(NULL); | |
| 80 } | |
| 81 | |
| 82 aura::Window* focused_window_; | |
| 83 ScopedObserver<aura::Window, aura::WindowObserver> observer_manager_; | |
| 84 ObserverList<aura::client::FocusChangeObserver> observers_; | |
| 85 | 38 |
| 86 DISALLOW_COPY_AND_ASSIGN(FocusClientImpl); | 39 DISALLOW_COPY_AND_ASSIGN(FocusClientImpl); |
| 87 }; | 40 }; |
| 88 | 41 |
| 89 class WindowTreeClientImpl : public aura::client::WindowTreeClient { | 42 class WindowTreeClientImpl : public aura::client::WindowTreeClient { |
| 90 public: | 43 public: |
| 91 explicit WindowTreeClientImpl(aura::Window* window) : window_(window) { | 44 explicit WindowTreeClientImpl(aura::Window* window) : window_(window) { |
| 92 aura::client::SetWindowTreeClient(window_, this); | 45 aura::client::SetWindowTreeClient(window_, this); |
| 93 } | 46 } |
| 94 | 47 |
| (...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 126 screen_.reset(ScreenImpl::Create()); | 79 screen_.reset(ScreenImpl::Create()); |
| 127 gfx::Screen::SetScreenInstance(gfx::SCREEN_TYPE_NATIVE, screen_.get()); | 80 gfx::Screen::SetScreenInstance(gfx::SCREEN_TYPE_NATIVE, screen_.get()); |
| 128 NativeViewportPtr viewport; | 81 NativeViewportPtr viewport; |
| 129 app_connection->ConnectToService( | 82 app_connection->ConnectToService( |
| 130 "mojo:mojo_native_viewport_service", &viewport); | 83 "mojo:mojo_native_viewport_service", &viewport); |
| 131 window_tree_host_.reset(new WindowTreeHostImpl( | 84 window_tree_host_.reset(new WindowTreeHostImpl( |
| 132 viewport.Pass(), | 85 viewport.Pass(), |
| 133 gfx::Rect(800, 600), | 86 gfx::Rect(800, 600), |
| 134 base::Bind(&RootViewManager::OnCompositorCreated, | 87 base::Bind(&RootViewManager::OnCompositorCreated, |
| 135 base::Unretained(this)), | 88 base::Unretained(this)), |
| 136 native_viewport_closed_callback)); | 89 native_viewport_closed_callback, |
| 90 base::Bind(&RootNodeManager::DispatchNodeInputEventToWindowManager, |
| 91 base::Unretained(root_node_manager_)))); |
| 137 } | 92 } |
| 138 | 93 |
| 139 RootViewManager::~RootViewManager() { | 94 RootViewManager::~RootViewManager() { |
| 140 window_tree_client_.reset(); | 95 window_tree_client_.reset(); |
| 141 window_tree_host_.reset(); | 96 window_tree_host_.reset(); |
| 142 gfx::Screen::SetScreenInstance(gfx::SCREEN_TYPE_NATIVE, NULL); | 97 gfx::Screen::SetScreenInstance(gfx::SCREEN_TYPE_NATIVE, NULL); |
| 143 } | 98 } |
| 144 | 99 |
| 145 void RootViewManager::OnCompositorCreated() { | 100 void RootViewManager::OnCompositorCreated() { |
| 146 base::AutoReset<bool> resetter(&in_setup_, true); | 101 base::AutoReset<bool> resetter(&in_setup_, true); |
| 147 window_tree_host_->InitHost(); | 102 window_tree_host_->InitHost(); |
| 148 | 103 |
| 149 aura::Window* root = root_node_manager_->root()->window(); | 104 aura::Window* root = root_node_manager_->root()->window(); |
| 150 window_tree_host_->window()->AddChild(root); | 105 window_tree_host_->window()->AddChild(root); |
| 151 root->SetBounds(gfx::Rect(window_tree_host_->window()->bounds().size())); | 106 root->SetBounds(gfx::Rect(window_tree_host_->window()->bounds().size())); |
| 152 root_node_manager_->root()->window()->Show(); | 107 root_node_manager_->root()->window()->Show(); |
| 153 | 108 |
| 154 window_tree_client_.reset( | 109 window_tree_client_.reset( |
| 155 new WindowTreeClientImpl(window_tree_host_->window())); | 110 new WindowTreeClientImpl(window_tree_host_->window())); |
| 156 | 111 |
| 157 focus_client_.reset(new FocusClientImpl()); | 112 focus_client_.reset(new FocusClientImpl); |
| 158 aura::client::SetFocusClient(window_tree_host_->window(), | 113 aura::client::SetFocusClient(window_tree_host_->window(), |
| 159 focus_client_.get()); | 114 focus_client_.get()); |
| 160 focus_client_->AddObserver(root_node_manager_); | |
| 161 | 115 |
| 162 window_tree_host_->Show(); | 116 window_tree_host_->Show(); |
| 163 | 117 |
| 164 delegate_->OnRootViewManagerWindowTreeHostCreated(); | 118 delegate_->OnRootViewManagerWindowTreeHostCreated(); |
| 165 } | 119 } |
| 166 | 120 |
| 167 } // namespace service | 121 } // namespace service |
| 168 } // namespace mojo | 122 } // namespace mojo |
| OLD | NEW |