| 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 #ifndef ASH_WM_LOCK_WINDOW_STATE_H_ | 5 #ifndef ASH_WM_LOCK_WINDOW_STATE_H_ |
| 6 #define ASH_WM_LOCK_WINDOW_STATE_H_ | 6 #define ASH_WM_LOCK_WINDOW_STATE_H_ |
| 7 | 7 |
| 8 #include "ash/wm/window_state.h" | 8 #include "ash/wm/window_state.h" |
| 9 #include "base/macros.h" | 9 #include "base/macros.h" |
| 10 | 10 |
| 11 namespace ash { | 11 namespace ash { |
| 12 | 12 |
| 13 // The LockWindowState implementation which reduces all possible window | 13 // The LockWindowState implementation which reduces all possible window |
| 14 // states to maximized (or normal if can't be maximized)/minimized/full-screen | 14 // states to maximized (or normal if can't be maximized)/minimized/full-screen |
| 15 // and is applied only on lock (login) window container. | 15 // and is applied only on lock (login) window container and window containers |
| 16 // associated with apps handling lock screen tray actions. |
| 16 // LockWindowState implements Ash behavior without state machine. | 17 // LockWindowState implements Ash behavior without state machine. |
| 17 class LockWindowState : public wm::WindowState::State { | 18 class LockWindowState : public wm::WindowState::State { |
| 18 public: | 19 public: |
| 19 // The |window|'s state object will be modified to use this new window mode | 20 // The |window|'s state object will be modified to use this new window mode |
| 20 // state handler. | 21 // state handler. |
| 21 explicit LockWindowState(WmWindow* window); | 22 // |shelf_visible| - if set, the maximized window size will be |
| 23 // restricted to work area defined by ash shelf, rather than taking only |
| 24 // virtual keyboard window into consideration when calculating the window |
| 25 // size. |
| 26 LockWindowState(WmWindow* window, bool shelf_visible); |
| 22 ~LockWindowState() override; | 27 ~LockWindowState() override; |
| 23 | 28 |
| 24 // WindowState::State overrides: | 29 // WindowState::State overrides: |
| 25 void OnWMEvent(wm::WindowState* window_state, | 30 void OnWMEvent(wm::WindowState* window_state, |
| 26 const wm::WMEvent* event) override; | 31 const wm::WMEvent* event) override; |
| 27 wm::WindowStateType GetType() const override; | 32 wm::WindowStateType GetType() const override; |
| 28 void AttachState(wm::WindowState* window_state, | 33 void AttachState(wm::WindowState* window_state, |
| 29 wm::WindowState::State* previous_state) override; | 34 wm::WindowState::State* previous_state) override; |
| 30 void DetachState(wm::WindowState* window_state) override; | 35 void DetachState(wm::WindowState* window_state) override; |
| 31 | 36 |
| 32 // Creates new LockWindowState instance and attaches it to |window|. | 37 // Creates new LockWindowState instance and attaches it to |window|. |
| 33 static wm::WindowState* SetLockWindowState(WmWindow* window); | 38 static wm::WindowState* SetLockWindowState(WmWindow* window); |
| 39 static wm::WindowState* SetLockWindowStateWithVisibleShelf(WmWindow* window); |
| 34 | 40 |
| 35 private: | 41 private: |
| 36 // Updates the window to |new_state_type| and resulting bounds: | 42 // Updates the window to |new_state_type| and resulting bounds: |
| 37 // Either full screen, maximized centered or minimized. If the state does not | 43 // Either full screen, maximized centered or minimized. If the state does not |
| 38 // change, only the bounds will be changed. | 44 // change, only the bounds will be changed. |
| 39 void UpdateWindow(wm::WindowState* window_state, | 45 void UpdateWindow(wm::WindowState* window_state, |
| 40 wm::WindowStateType new_state_type); | 46 wm::WindowStateType new_state_type); |
| 41 | 47 |
| 42 // Depending on the capabilities of the window we either return | 48 // Depending on the capabilities of the window we either return |
| 43 // |WINDOW_STATE_TYPE_MAXIMIZED| or |WINDOW_STATE_TYPE_NORMAL|. | 49 // |WINDOW_STATE_TYPE_MAXIMIZED| or |WINDOW_STATE_TYPE_NORMAL|. |
| 44 wm::WindowStateType GetMaximizedOrCenteredWindowType( | 50 wm::WindowStateType GetMaximizedOrCenteredWindowType( |
| 45 wm::WindowState* window_state); | 51 wm::WindowState* window_state); |
| 46 | 52 |
| 53 // Returns boudns to be used for the provided window. |
| 54 gfx::Rect GetWindowBounds(aura::Window* window); |
| 55 |
| 47 // Updates the bounds taking virtual keyboard bounds into consideration. | 56 // Updates the bounds taking virtual keyboard bounds into consideration. |
| 48 void UpdateBounds(wm::WindowState* window_state); | 57 void UpdateBounds(wm::WindowState* window_state); |
| 49 | 58 |
| 50 // The current state type. Due to the nature of this state, this can only be | 59 // The current state type. Due to the nature of this state, this can only be |
| 51 // WM_STATE_TYPE{NORMAL, MINIMIZED, MAXIMIZED}. | 60 // WM_STATE_TYPE{NORMAL, MINIMIZED, MAXIMIZED}. |
| 52 wm::WindowStateType current_state_type_; | 61 wm::WindowStateType current_state_type_; |
| 53 | 62 |
| 63 // Restrict window size to the work area defined by the shelf. |
| 64 bool shelf_visible_ = false; |
| 65 |
| 54 DISALLOW_COPY_AND_ASSIGN(LockWindowState); | 66 DISALLOW_COPY_AND_ASSIGN(LockWindowState); |
| 55 }; | 67 }; |
| 56 | 68 |
| 57 } // namespace ash | 69 } // namespace ash |
| 58 | 70 |
| 59 #endif // ASH_WM_LOCK_WINDOW_STATE_H_ | 71 #endif // ASH_WM_LOCK_WINDOW_STATE_H_ |
| OLD | NEW |