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/shelf_layout_manager.h" | 5 #include "ash/wm/shelf_layout_manager.h" |
6 | 6 |
7 #include <algorithm> | 7 #include <algorithm> |
8 #include <cmath> | 8 #include <cmath> |
9 | 9 |
10 #include "ash/ash_switches.h" | 10 #include "ash/ash_switches.h" |
(...skipping 229 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
240 GetLayer(status_area_widget_)->SetOpacity(target_bounds.opacity); | 240 GetLayer(status_area_widget_)->SetOpacity(target_bounds.opacity); |
241 status_area_widget_->SetBounds( | 241 status_area_widget_->SetBounds( |
242 ScreenAsh::ConvertRectToScreen( | 242 ScreenAsh::ConvertRectToScreen( |
243 status_area_widget_->GetNativeView()->parent(), | 243 status_area_widget_->GetNativeView()->parent(), |
244 target_bounds.status_bounds_in_root)); | 244 target_bounds.status_bounds_in_root)); |
245 Shell::GetInstance()->SetDisplayWorkAreaInsets( | 245 Shell::GetInstance()->SetDisplayWorkAreaInsets( |
246 root_window_, target_bounds.work_area_insets); | 246 root_window_, target_bounds.work_area_insets); |
247 UpdateHitTestBounds(); | 247 UpdateHitTestBounds(); |
248 } | 248 } |
249 | 249 |
| 250 ShelfVisibilityState ShelfLayoutManager::GetShelfVisibilityState() { |
| 251 switch(auto_hide_behavior_) { |
| 252 case SHELF_AUTO_HIDE_BEHAVIOR_ALWAYS: |
| 253 return SHELF_AUTO_HIDE; |
| 254 case SHELF_AUTO_HIDE_BEHAVIOR_NEVER: |
| 255 return SHELF_VISIBLE; |
| 256 case SHELF_AUTO_HIDE_ALWAYS_HIDDEN: |
| 257 return SHELF_HIDDEN; |
| 258 } |
| 259 return SHELF_VISIBLE; |
| 260 } |
| 261 |
250 void ShelfLayoutManager::UpdateVisibilityState() { | 262 void ShelfLayoutManager::UpdateVisibilityState() { |
251 ShellDelegate* delegate = Shell::GetInstance()->delegate(); | 263 ShellDelegate* delegate = Shell::GetInstance()->delegate(); |
252 if (delegate && delegate->IsScreenLocked()) { | 264 if (delegate && delegate->IsScreenLocked()) { |
253 SetState(SHELF_VISIBLE); | 265 SetState(SHELF_VISIBLE); |
254 } else if (gesture_drag_status_ == GESTURE_DRAG_COMPLETE_IN_PROGRESS) { | 266 } else if (gesture_drag_status_ == GESTURE_DRAG_COMPLETE_IN_PROGRESS) { |
255 SetState(SHELF_AUTO_HIDE); | 267 SetState(SHELF_AUTO_HIDE); |
256 } else if (GetRootWindowController(root_window_)->IsImmersiveMode()) { | 268 } else if (GetRootWindowController(root_window_)->IsImmersiveMode()) { |
257 // The user choosing immersive mode indicates he or she wants to maximize | 269 // The user choosing immersive mode indicates he or she wants to maximize |
258 // screen real-estate for content, so always auto-hide the shelf. | 270 // screen real-estate for content, so always auto-hide the shelf. |
259 SetState(SHELF_AUTO_HIDE); | 271 SetState(SHELF_AUTO_HIDE); |
260 } else { | 272 } else { |
261 WorkspaceWindowState window_state(workspace_controller_->GetWindowState()); | 273 WorkspaceWindowState window_state(workspace_controller_->GetWindowState()); |
262 switch (window_state) { | 274 switch (window_state) { |
263 case WORKSPACE_WINDOW_STATE_FULL_SCREEN: | 275 case WORKSPACE_WINDOW_STATE_FULL_SCREEN: |
264 SetState(SHELF_HIDDEN); | 276 SetState(SHELF_HIDDEN); |
265 break; | 277 break; |
266 | 278 |
267 case WORKSPACE_WINDOW_STATE_MAXIMIZED: | 279 case WORKSPACE_WINDOW_STATE_MAXIMIZED: |
268 SetState(auto_hide_behavior_ == SHELF_AUTO_HIDE_BEHAVIOR_ALWAYS ? | 280 SetState(GetShelfVisibilityState()); |
269 SHELF_AUTO_HIDE : SHELF_VISIBLE); | |
270 break; | 281 break; |
271 | 282 |
272 case WORKSPACE_WINDOW_STATE_WINDOW_OVERLAPS_SHELF: | 283 case WORKSPACE_WINDOW_STATE_WINDOW_OVERLAPS_SHELF: |
273 case WORKSPACE_WINDOW_STATE_DEFAULT: | 284 case WORKSPACE_WINDOW_STATE_DEFAULT: |
274 SetState(auto_hide_behavior_ == SHELF_AUTO_HIDE_BEHAVIOR_ALWAYS ? | 285 SetState(GetShelfVisibilityState()); |
275 SHELF_AUTO_HIDE : SHELF_VISIBLE); | |
276 SetWindowOverlapsShelf(window_state == | 286 SetWindowOverlapsShelf(window_state == |
277 WORKSPACE_WINDOW_STATE_WINDOW_OVERLAPS_SHELF); | 287 WORKSPACE_WINDOW_STATE_WINDOW_OVERLAPS_SHELF); |
278 break; | 288 break; |
279 } | 289 } |
280 } | 290 } |
281 } | 291 } |
282 | 292 |
283 void ShelfLayoutManager::UpdateAutoHideState() { | 293 void ShelfLayoutManager::UpdateAutoHideState() { |
284 ShelfAutoHideState auto_hide_state = | 294 ShelfAutoHideState auto_hide_state = |
285 CalculateAutoHideState(state_.visibility_state); | 295 CalculateAutoHideState(state_.visibility_state); |
(...skipping 633 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
919 int ShelfLayoutManager::GetWorkAreaSize(const State& state, int size) const { | 929 int ShelfLayoutManager::GetWorkAreaSize(const State& state, int size) const { |
920 if (state.visibility_state == SHELF_VISIBLE) | 930 if (state.visibility_state == SHELF_VISIBLE) |
921 return size; | 931 return size; |
922 if (state.visibility_state == SHELF_AUTO_HIDE) | 932 if (state.visibility_state == SHELF_AUTO_HIDE) |
923 return kAutoHideSize; | 933 return kAutoHideSize; |
924 return 0; | 934 return 0; |
925 } | 935 } |
926 | 936 |
927 } // namespace internal | 937 } // namespace internal |
928 } // namespace ash | 938 } // namespace ash |
OLD | NEW |