Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 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/common/wm/maximize_mode/maximize_mode_event_handler.h" | 5 #include "ash/common/wm/maximize_mode/maximize_mode_event_handler.h" |
| 6 | 6 |
| 7 #include "ash/common/session/session_controller.h" | 7 #include "ash/common/session/session_controller.h" |
| 8 #include "ash/common/system/tray/system_tray_delegate.h" | 8 #include "ash/common/system/tray/system_tray_delegate.h" |
| 9 #include "ash/common/wm/window_state.h" | 9 #include "ash/common/wm/window_state.h" |
| 10 #include "ash/common/wm/wm_event.h" | 10 #include "ash/common/wm/wm_event.h" |
| 11 #include "ash/common/wm_shell.h" | 11 #include "ash/common/wm_shell.h" |
|
James Cook
2017/03/31 19:29:52
still needed?
sky
2017/03/31 20:15:14
Done.
| |
| 12 #include "ash/common/wm_window.h" | 12 #include "ash/common/wm_window.h" |
| 13 #include "ash/shell.h" | 13 #include "ash/shell.h" |
| 14 #include "ash/wm/window_util.h" | |
| 14 #include "ui/events/event.h" | 15 #include "ui/events/event.h" |
| 15 | 16 |
| 16 namespace ash { | 17 namespace ash { |
| 17 namespace wm { | 18 namespace wm { |
| 18 namespace { | 19 namespace { |
| 19 | 20 |
| 20 // The height of the area in which a touch operation leads to exiting the | 21 // The height of the area in which a touch operation leads to exiting the |
| 21 // full screen mode. | 22 // full screen mode. |
| 22 const int kLeaveFullScreenAreaHeightInPixel = 2; | 23 const int kLeaveFullScreenAreaHeightInPixel = 2; |
| 23 | 24 |
| 24 } // namespace | 25 } // namespace |
| 25 | 26 |
| 26 MaximizeModeEventHandler::MaximizeModeEventHandler() {} | 27 MaximizeModeEventHandler::MaximizeModeEventHandler() {} |
| 27 | 28 |
| 28 MaximizeModeEventHandler::~MaximizeModeEventHandler() {} | 29 MaximizeModeEventHandler::~MaximizeModeEventHandler() {} |
| 29 | 30 |
| 30 bool MaximizeModeEventHandler::ToggleFullscreen(const ui::TouchEvent& event) { | 31 bool MaximizeModeEventHandler::ToggleFullscreen(const ui::TouchEvent& event) { |
| 31 if (event.type() != ui::ET_TOUCH_PRESSED) | 32 if (event.type() != ui::ET_TOUCH_PRESSED) |
| 32 return false; | 33 return false; |
| 33 | 34 |
| 34 const SessionController* controller = Shell::Get()->session_controller(); | 35 const SessionController* controller = Shell::Get()->session_controller(); |
| 35 | 36 |
| 36 if (controller->IsScreenLocked() || | 37 if (controller->IsScreenLocked() || |
| 37 controller->GetSessionState() != session_manager::SessionState::ACTIVE) { | 38 controller->GetSessionState() != session_manager::SessionState::ACTIVE) { |
| 38 return false; | 39 return false; |
| 39 } | 40 } |
| 40 | 41 |
| 41 // Find the active window (from the primary screen) to un-fullscreen. | 42 // Find the active window (from the primary screen) to un-fullscreen. |
| 42 WmWindow* window = WmShell::Get()->GetActiveWindow(); | 43 WmWindow* window = WmWindow::Get(GetActiveWindow()); |
| 43 if (!window) | 44 if (!window) |
| 44 return false; | 45 return false; |
| 45 | 46 |
| 46 WindowState* window_state = window->GetWindowState(); | 47 WindowState* window_state = window->GetWindowState(); |
| 47 if (!window_state->IsFullscreen() || window_state->in_immersive_fullscreen()) | 48 if (!window_state->IsFullscreen() || window_state->in_immersive_fullscreen()) |
| 48 return false; | 49 return false; |
| 49 | 50 |
| 50 // Test that the touch happened in the top or bottom lines. | 51 // Test that the touch happened in the top or bottom lines. |
| 51 int y = event.y(); | 52 int y = event.y(); |
| 52 if (y >= kLeaveFullScreenAreaHeightInPixel && | 53 if (y >= kLeaveFullScreenAreaHeightInPixel && |
| (...skipping 10 matching lines...) Expand all Loading... | |
| 63 return false; | 64 return false; |
| 64 } | 65 } |
| 65 | 66 |
| 66 WMEvent toggle_fullscreen(WM_EVENT_TOGGLE_FULLSCREEN); | 67 WMEvent toggle_fullscreen(WM_EVENT_TOGGLE_FULLSCREEN); |
| 67 window->GetWindowState()->OnWMEvent(&toggle_fullscreen); | 68 window->GetWindowState()->OnWMEvent(&toggle_fullscreen); |
| 68 return true; | 69 return true; |
| 69 } | 70 } |
| 70 | 71 |
| 71 } // namespace wm | 72 } // namespace wm |
| 72 } // namespace ash | 73 } // namespace ash |
| OLD | NEW |