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 #include "ash/wm/workspace_controller.h" | 5 #include "ash/wm/workspace_controller.h" |
6 | 6 |
7 #include "ash/wm/window_util.h" | 7 #include "ash/wm/window_util.h" |
8 #include "ash/wm/workspace/workspace_event_filter.h" | 8 #include "ash/wm/workspace/workspace_event_filter.h" |
9 #include "ash/wm/workspace/workspace_layout_manager.h" | 9 #include "ash/wm/workspace/workspace_layout_manager.h" |
10 #include "ash/wm/workspace/workspace_manager.h" | 10 #include "ash/wm/workspace/workspace_manager.h" |
11 #include "ui/aura/client/activation_client.h" | 11 #include "ui/aura/client/activation_client.h" |
12 #include "ui/aura/client/aura_constants.h" | 12 #include "ui/aura/client/aura_constants.h" |
13 #include "ui/aura/root_window.h" | 13 #include "ui/aura/root_window.h" |
14 #include "ui/aura/window.h" | 14 #include "ui/aura/window.h" |
15 | 15 |
16 namespace ash { | 16 namespace ash { |
17 namespace internal { | 17 namespace internal { |
18 | 18 |
19 namespace { | 19 namespace { |
20 | 20 |
21 // Size of the grid when a grid is enabled. | 21 // Size of the grid when a grid is enabled. |
22 const int kGridSize = 16; | 22 const int kGridSize = 16; |
23 | 23 |
24 } // namespace | 24 } // namespace |
25 | 25 |
26 WorkspaceController::WorkspaceController(aura::Window* viewport) | 26 WorkspaceController::WorkspaceController(aura::Window* viewport) |
27 : viewport_(viewport), | 27 : viewport_(viewport), |
28 workspace_manager_(new WorkspaceManager(viewport)), | |
29 layout_manager_(NULL), | 28 layout_manager_(NULL), |
30 event_filter_(NULL) { | 29 event_filter_(NULL) { |
31 aura::RootWindow* root_window = viewport->GetRootWindow(); | 30 aura::RootWindow* root_window = viewport->GetRootWindow(); |
32 event_filter_ = new WorkspaceEventFilter(viewport); | 31 event_filter_ = new WorkspaceEventFilter(viewport); |
33 viewport->SetEventFilter(event_filter_); | 32 viewport->SetEventFilter(event_filter_); |
34 layout_manager_ = new WorkspaceLayoutManager( | 33 WorkspaceManager* workspace_manager = new WorkspaceManager(viewport); |
35 root_window, workspace_manager_.get()); | 34 workspace_manager_.reset(workspace_manager); |
| 35 layout_manager_ = new WorkspaceLayoutManager(root_window, workspace_manager); |
36 viewport->SetLayoutManager(layout_manager_); | 36 viewport->SetLayoutManager(layout_manager_); |
37 aura::client::GetActivationClient(root_window)->AddObserver(this); | 37 aura::client::GetActivationClient(root_window)->AddObserver(this); |
38 SetGridSize(kGridSize); | 38 SetGridSize(kGridSize); |
39 } | 39 } |
40 | 40 |
41 WorkspaceController::~WorkspaceController() { | 41 WorkspaceController::~WorkspaceController() { |
42 aura::client::GetActivationClient(viewport_->GetRootWindow())-> | 42 aura::client::GetActivationClient(viewport_->GetRootWindow())-> |
43 RemoveObserver(this); | 43 RemoveObserver(this); |
44 // WorkspaceLayoutManager may attempt to access state from us. Destroy it now. | 44 // WorkspaceLayoutManager may attempt to access state from us. Destroy it now. |
45 if (viewport_->layout_manager() == layout_manager_) | 45 if (viewport_->layout_manager() == layout_manager_) |
46 viewport_->SetLayoutManager(NULL); | 46 viewport_->SetLayoutManager(NULL); |
47 } | 47 } |
48 | 48 |
49 bool WorkspaceController::IsInMaximizedMode() const { | 49 bool WorkspaceController::IsInMaximizedMode() const { |
50 return workspace_manager_->IsInMaximizedMode(); | 50 return workspace_manager_->IsInMaximizedMode(); |
51 } | 51 } |
52 | 52 |
53 void WorkspaceController::SetGridSize(int grid_size) { | 53 void WorkspaceController::SetGridSize(int grid_size) { |
54 workspace_manager_->SetGridSize(grid_size); | 54 workspace_manager_->SetGridSize(grid_size); |
55 event_filter_->set_grid_size(grid_size); | 55 if (event_filter_) |
| 56 event_filter_->set_grid_size(grid_size); |
56 } | 57 } |
57 | 58 |
58 int WorkspaceController::GetGridSize() const { | 59 int WorkspaceController::GetGridSize() const { |
59 return workspace_manager_->grid_size(); | 60 return workspace_manager_->GetGridSize(); |
60 } | 61 } |
61 | 62 |
62 WorkspaceWindowState WorkspaceController::GetWindowState() const { | 63 WorkspaceWindowState WorkspaceController::GetWindowState() const { |
63 return workspace_manager_->GetWindowState(); | 64 return workspace_manager_->GetWindowState(); |
64 } | 65 } |
65 | 66 |
66 void WorkspaceController::SetShelf(ShelfLayoutManager* shelf) { | 67 void WorkspaceController::SetShelf(ShelfLayoutManager* shelf) { |
67 workspace_manager_->set_shelf(shelf); | 68 workspace_manager_->SetShelf(shelf); |
68 } | 69 } |
69 | 70 |
| 71 void WorkspaceController::SetActiveWorkspaceByWindow(aura::Window* window) { |
| 72 return workspace_manager_->SetActiveWorkspaceByWindow(window); |
| 73 } |
| 74 |
| 75 aura::Window* WorkspaceController::GetParentForNewWindow(aura::Window* window) { |
| 76 return workspace_manager_->GetParentForNewWindow(window); |
| 77 } |
| 78 |
| 79 |
70 void WorkspaceController::OnWindowActivated(aura::Window* window, | 80 void WorkspaceController::OnWindowActivated(aura::Window* window, |
71 aura::Window* old_active) { | 81 aura::Window* old_active) { |
72 workspace_manager_->SetActiveWorkspaceByWindow(window); | 82 if (!window || window->GetRootWindow() == viewport_->GetRootWindow()) |
| 83 workspace_manager_->SetActiveWorkspaceByWindow(window); |
73 } | 84 } |
74 | 85 |
75 } // namespace internal | 86 } // namespace internal |
76 } // namespace ash | 87 } // namespace ash |
OLD | NEW |