Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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 UI_AURA_SHELL_WORKSPACE_WORKSPACE_H_ | 5 #ifndef UI_AURA_SHELL_WORKSPACE_WORKSPACE_H_ |
| 6 #define UI_AURA_SHELL_WORKSPACE_WORKSPACE_H_ | 6 #define UI_AURA_SHELL_WORKSPACE_WORKSPACE_H_ |
| 7 | 7 |
| 8 #include <vector> | 8 #include <vector> |
| 9 | 9 |
| 10 #include "base/basictypes.h" | 10 #include "base/basictypes.h" |
| (...skipping 14 matching lines...) Expand all Loading... | |
| 25 // generally the same as the size of the monitor, and the desktop can | 25 // generally the same as the size of the monitor, and the desktop can |
| 26 // have multiple workspaces. | 26 // have multiple workspaces. |
| 27 // A workspace contains a limited number of windows and the workspace | 27 // A workspace contains a limited number of windows and the workspace |
| 28 // manager may create a new workspace if there is not enough room for | 28 // manager may create a new workspace if there is not enough room for |
| 29 // a new window. | 29 // a new window. |
| 30 class AURA_SHELL_EXPORT Workspace { | 30 class AURA_SHELL_EXPORT Workspace { |
| 31 public: | 31 public: |
| 32 explicit Workspace(WorkspaceManager* manager); | 32 explicit Workspace(WorkspaceManager* manager); |
| 33 virtual ~Workspace(); | 33 virtual ~Workspace(); |
| 34 | 34 |
| 35 // Specifies the direction to shift windows in |ShiftWindows()|. | |
| 36 enum ShiftDirection { | |
| 37 SHIFT_TO_RIGHT, | |
| 38 SHIFT_TO_LEFT | |
| 39 }; | |
| 40 | |
| 35 // Returns true if this workspace has no windows. | 41 // Returns true if this workspace has no windows. |
| 36 bool is_empty() const { return windows_.empty(); } | 42 bool is_empty() const { return windows_.empty(); } |
| 37 | 43 |
| 38 // Sets/gets bounds of this workspace. | 44 // Sets/gets bounds of this workspace. |
| 39 const gfx::Rect& bounds() { return bounds_; } | 45 const gfx::Rect& bounds() { return bounds_; } |
| 40 void SetBounds(const gfx::Rect& bounds); | 46 void SetBounds(const gfx::Rect& bounds); |
| 41 | 47 |
| 42 // Returns the work area bounds of this workspace in viewport | 48 // Returns the work area bounds of this workspace in viewport |
| 43 // coordinates. | 49 // coordinates. |
| 44 gfx::Rect GetWorkAreaBounds() const; | 50 gfx::Rect GetWorkAreaBounds() const; |
| 45 | 51 |
| 46 // Adds the |window| at the position after the window |after|. It | 52 // Adds the |window| at the position after the window |after|. It |
| 47 // inserts at the end if |after| is NULL. Return true if the | 53 // inserts at the end if |after| is NULL. Return true if the |
| 48 // |window| was successfully added to this workspace, or false if it | 54 // |window| was successfully added to this workspace, or false if it |
| 49 // failed. | 55 // failed. |
| 50 bool AddWindowAfter(aura::Window* window, aura::Window* after); | 56 bool AddWindowAfter(aura::Window* window, aura::Window* after); |
| 51 | 57 |
| 52 // Removes the |window| from this workspace. | 58 // Removes the |window| from this workspace. |
| 53 void RemoveWindow(aura::Window* window); | 59 void RemoveWindow(aura::Window* window); |
| 54 | 60 |
| 55 // Return true if this workspace has the |window|. | 61 // Return true if this workspace has the |window|. |
| 56 bool Contains(aura::Window* window) const; | 62 bool Contains(aura::Window* window) const; |
| 57 | 63 |
| 64 // Returns a window to rotate to based on the |position|. | |
|
sky
2011/10/27 19:46:41
remove 'the'
oshima
2011/10/27 20:25:43
Done.
| |
| 65 aura::Window* FindRotateWindowForLocation(const gfx::Point& position); | |
| 66 | |
| 67 // Rotates the windows by removing |source| and inserting it to the | |
| 68 // position that |target| was in. It re-layouts windows except for |source|. | |
| 69 void RotateWindows(aura::Window* source, aura::Window* target); | |
| 70 | |
| 71 // Shift the windows in the workspace by inserting |window| until | |
| 72 // it reaches |until|. |insert| is inserted at the beginning if | |
| 73 // the |direction| is |SHIFT_TO_RIGHT|, or at the end if the |direction| | |
| 74 // is |SHIFT_TO_LEFT|. It returns the window that is overflowed by shifting, | |
| 75 // or NULL if shifting stopped at |until|. | |
| 76 aura::Window* ShiftWindows(aura::Window* insert, | |
| 77 aura::Window* until, | |
| 78 ShiftDirection direction); | |
| 79 | |
| 58 // Activates this workspace. | 80 // Activates this workspace. |
| 59 void Activate(); | 81 void Activate(); |
| 60 | 82 |
| 61 // Layout windows. Moving animation is applied to all windows except | 83 // Layout windows. The workspace doesn't set bounds on the |ignore| if it's |
|
sky
2011/10/27 19:46:41
'the ignore' -> 'ignore'
same with next line
oshima
2011/10/27 20:25:43
removed all "the" before ||
| |
| 62 // for the window specified by |no_animation|. | 84 // given. It still uses the |ignore| window's bounds to calculate |
| 63 void Layout(aura::Window* no_animation); | 85 // bounds for other windows. Moving animation is applied to all |
| 86 // windows except for the window specified by |no_animation| and |ignore|. | |
| 87 void Layout(aura::Window* ignore, aura::Window* no_animation); | |
| 64 | 88 |
| 65 private: | 89 private: |
| 66 FRIEND_TEST_ALL_PREFIXES(WorkspaceTest, WorkspaceBasic); | 90 FRIEND_TEST_ALL_PREFIXES(WorkspaceTest, WorkspaceBasic); |
| 91 FRIEND_TEST_ALL_PREFIXES(WorkspaceTest, RotateWindows); | |
| 92 FRIEND_TEST_ALL_PREFIXES(WorkspaceTest, ShiftWindowsSingle); | |
| 93 FRIEND_TEST_ALL_PREFIXES(WorkspaceTest, ShiftWindowsMultiple); | |
| 94 FRIEND_TEST_ALL_PREFIXES(WorkspaceManagerTest, RotateWindows); | |
| 67 | 95 |
| 68 // Returns the index in layout order of the |window| in this workspace. | 96 // Returns the index in layout order of the |window| in this workspace. |
| 69 int GetIndexOf(aura::Window* window) const; | 97 int GetIndexOf(aura::Window* window) const; |
| 70 | 98 |
| 71 // Returns true if the given |window| can be added to this workspace. | 99 // Returns true if the given |window| can be added to this workspace. |
| 72 bool CanAdd(aura::Window* window) const; | 100 bool CanAdd(aura::Window* window) const; |
| 73 | 101 |
| 74 // Moves |window| to the given point. It performs animation when | 102 // Moves |window| to the given point. It performs animation when |
| 75 // |animate| is true. | 103 // |animate| is true. |
| 76 void MoveWindowTo(aura::Window* window, | 104 void MoveWindowTo(aura::Window* window, |
| 77 const gfx::Point& origin, | 105 const gfx::Point& origin, |
| 78 bool animate); | 106 bool animate); |
| 79 | 107 |
| 108 // Returns the sum of all window's width. | |
| 109 int GetTotalWindowsWidth() const; | |
| 110 | |
| 111 // Test only: Changes how may windows workspace can haven. | |
|
sky
2011/10/27 19:46:41
haven -> have
oshima
2011/10/27 20:25:43
Done.
| |
| 112 // Returns the current value so that it can be reverted back to | |
| 113 // original value. | |
| 114 static size_t SetMaxWindowsCount(size_t max); | |
| 115 | |
| 80 WorkspaceManager* workspace_manager_; | 116 WorkspaceManager* workspace_manager_; |
| 81 | 117 |
| 82 gfx::Rect bounds_; | 118 gfx::Rect bounds_; |
| 83 | 119 |
| 84 // Windows in the workspace in layout order. | 120 // Windows in the workspace in layout order. |
| 85 std::vector<aura::Window*> windows_; | 121 std::vector<aura::Window*> windows_; |
| 86 | 122 |
| 87 DISALLOW_COPY_AND_ASSIGN(Workspace); | 123 DISALLOW_COPY_AND_ASSIGN(Workspace); |
| 88 }; | 124 }; |
| 89 | 125 |
| 90 typedef std::vector<Workspace*> Workspaces; | 126 typedef std::vector<Workspace*> Workspaces; |
| 91 | 127 |
| 92 } // namespace aura_shell | 128 } // namespace aura_shell |
| 93 | 129 |
| 94 #endif // UI_AURA_SHELL_WORKSPACE_WORKSPACE_H_ | 130 #endif // UI_AURA_SHELL_WORKSPACE_WORKSPACE_H_ |
| OLD | NEW |