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 |