OLD | NEW |
1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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 "mash/wm/property_util.h" | 5 #include "ash/mus/property_util.h" |
6 | 6 |
7 #include <stdint.h> | 7 #include <stdint.h> |
8 | 8 |
| 9 #include "ash/mus/shadow.h" |
9 #include "components/mus/public/cpp/property_type_converters.h" | 10 #include "components/mus/public/cpp/property_type_converters.h" |
10 #include "components/mus/public/cpp/window_property.h" | 11 #include "components/mus/public/cpp/window_property.h" |
11 #include "mash/wm/shadow.h" | |
12 #include "ui/gfx/geometry/rect.h" | 12 #include "ui/gfx/geometry/rect.h" |
13 #include "ui/gfx/geometry/size.h" | 13 #include "ui/gfx/geometry/size.h" |
14 | 14 |
15 namespace mash { | 15 namespace ash { |
16 namespace wm { | 16 namespace mus { |
17 namespace { | 17 namespace { |
18 | 18 |
19 MUS_DEFINE_LOCAL_WINDOW_PROPERTY_KEY(Shadow*, kLocalShadowProperty, nullptr); | 19 MUS_DEFINE_LOCAL_WINDOW_PROPERTY_KEY(Shadow*, kLocalShadowProperty, nullptr); |
20 MUS_DEFINE_LOCAL_WINDOW_PROPERTY_KEY(bool, kWindowIsJankyProperty, false); | 20 MUS_DEFINE_LOCAL_WINDOW_PROPERTY_KEY(bool, kWindowIsJankyProperty, false); |
21 | 21 |
22 } // namespace | 22 } // namespace |
23 | 23 |
24 void SetWindowShowState(mus::Window* window, mus::mojom::ShowState show_state) { | 24 void SetWindowShowState(::mus::Window* window, |
| 25 ::mus::mojom::ShowState show_state) { |
25 window->SetSharedProperty<int32_t>( | 26 window->SetSharedProperty<int32_t>( |
26 mus::mojom::WindowManager::kShowState_Property, | 27 ::mus::mojom::WindowManager::kShowState_Property, |
27 static_cast<uint32_t>(show_state)); | 28 static_cast<uint32_t>(show_state)); |
28 } | 29 } |
29 | 30 |
30 mus::mojom::ShowState GetWindowShowState(const mus::Window* window) { | 31 ::mus::mojom::ShowState GetWindowShowState(const ::mus::Window* window) { |
31 if (window->HasSharedProperty( | 32 if (window->HasSharedProperty( |
32 mus::mojom::WindowManager::kShowState_Property)) { | 33 ::mus::mojom::WindowManager::kShowState_Property)) { |
33 return static_cast<mus::mojom::ShowState>( | 34 return static_cast<::mus::mojom::ShowState>( |
34 window->GetSharedProperty<int32_t>( | 35 window->GetSharedProperty<int32_t>( |
35 mus::mojom::WindowManager::kShowState_Property)); | 36 ::mus::mojom::WindowManager::kShowState_Property)); |
36 } | 37 } |
37 return mus::mojom::ShowState::DEFAULT; | 38 return ::mus::mojom::ShowState::DEFAULT; |
38 } | 39 } |
39 | 40 |
40 void SetWindowUserSetBounds(mus::Window* window, const gfx::Rect& bounds) { | 41 void SetWindowUserSetBounds(::mus::Window* window, const gfx::Rect& bounds) { |
41 if (bounds.IsEmpty()) { | 42 if (bounds.IsEmpty()) { |
42 window->ClearSharedProperty( | 43 window->ClearSharedProperty( |
43 mus::mojom::WindowManager::kUserSetBounds_Property); | 44 ::mus::mojom::WindowManager::kUserSetBounds_Property); |
44 } else { | 45 } else { |
45 window->SetSharedProperty<gfx::Rect>( | 46 window->SetSharedProperty<gfx::Rect>( |
46 mus::mojom::WindowManager::kUserSetBounds_Property, bounds); | 47 ::mus::mojom::WindowManager::kUserSetBounds_Property, bounds); |
47 } | 48 } |
48 } | 49 } |
49 | 50 |
50 gfx::Rect GetWindowUserSetBounds(const mus::Window* window) { | 51 gfx::Rect GetWindowUserSetBounds(const ::mus::Window* window) { |
51 if (window->HasSharedProperty( | 52 if (window->HasSharedProperty( |
52 mus::mojom::WindowManager::kUserSetBounds_Property)) { | 53 ::mus::mojom::WindowManager::kUserSetBounds_Property)) { |
53 return window->GetSharedProperty<gfx::Rect>( | 54 return window->GetSharedProperty<gfx::Rect>( |
54 mus::mojom::WindowManager::kUserSetBounds_Property); | 55 ::mus::mojom::WindowManager::kUserSetBounds_Property); |
55 } | 56 } |
56 return gfx::Rect(); | 57 return gfx::Rect(); |
57 } | 58 } |
58 | 59 |
59 void SetWindowPreferredSize(mus::Window* window, const gfx::Size& size) { | 60 void SetWindowPreferredSize(::mus::Window* window, const gfx::Size& size) { |
60 window->SetSharedProperty<gfx::Size>( | 61 window->SetSharedProperty<gfx::Size>( |
61 mus::mojom::WindowManager::kPreferredSize_Property, size); | 62 ::mus::mojom::WindowManager::kPreferredSize_Property, size); |
62 } | 63 } |
63 | 64 |
64 gfx::Size GetWindowPreferredSize(const mus::Window* window) { | 65 gfx::Size GetWindowPreferredSize(const ::mus::Window* window) { |
65 if (window->HasSharedProperty( | 66 if (window->HasSharedProperty( |
66 mus::mojom::WindowManager::kPreferredSize_Property)) { | 67 ::mus::mojom::WindowManager::kPreferredSize_Property)) { |
67 return window->GetSharedProperty<gfx::Size>( | 68 return window->GetSharedProperty<gfx::Size>( |
68 mus::mojom::WindowManager::kPreferredSize_Property); | 69 ::mus::mojom::WindowManager::kPreferredSize_Property); |
69 } | 70 } |
70 return gfx::Size(); | 71 return gfx::Size(); |
71 } | 72 } |
72 | 73 |
73 ash::mojom::Container GetRequestedContainer(const mus::Window* window) { | 74 mojom::Container GetRequestedContainer(const ::mus::Window* window) { |
74 if (window->HasSharedProperty(ash::mojom::kWindowContainer_Property)) { | 75 if (window->HasSharedProperty(mojom::kWindowContainer_Property)) { |
75 return static_cast<ash::mojom::Container>( | 76 return static_cast<mojom::Container>( |
76 window->GetSharedProperty<int32_t>( | 77 window->GetSharedProperty<int32_t>(mojom::kWindowContainer_Property)); |
77 ash::mojom::kWindowContainer_Property)); | |
78 } | 78 } |
79 return ash::mojom::Container::USER_PRIVATE_WINDOWS; | 79 return mojom::Container::USER_PRIVATE_WINDOWS; |
80 } | 80 } |
81 | 81 |
82 int32_t GetResizeBehavior(const mus::Window* window) { | 82 int32_t GetResizeBehavior(const ::mus::Window* window) { |
83 if (window->HasSharedProperty( | 83 if (window->HasSharedProperty( |
84 mus::mojom::WindowManager::kResizeBehavior_Property)) { | 84 ::mus::mojom::WindowManager::kResizeBehavior_Property)) { |
85 return window->GetSharedProperty<int32_t>( | 85 return window->GetSharedProperty<int32_t>( |
86 mus::mojom::WindowManager::kResizeBehavior_Property); | 86 ::mus::mojom::WindowManager::kResizeBehavior_Property); |
87 } | 87 } |
88 return mus::mojom::kResizeBehaviorNone; | 88 return ::mus::mojom::kResizeBehaviorNone; |
89 } | 89 } |
90 | 90 |
91 void SetRestoreBounds(mus::Window* window, const gfx::Rect& bounds) { | 91 void SetRestoreBounds(::mus::Window* window, const gfx::Rect& bounds) { |
92 window->SetSharedProperty<gfx::Rect>( | 92 window->SetSharedProperty<gfx::Rect>( |
93 mus::mojom::WindowManager::kRestoreBounds_Property, bounds); | 93 ::mus::mojom::WindowManager::kRestoreBounds_Property, bounds); |
94 } | 94 } |
95 | 95 |
96 gfx::Rect GetRestoreBounds(const mus::Window* window) { | 96 gfx::Rect GetRestoreBounds(const ::mus::Window* window) { |
97 if (window->HasSharedProperty( | 97 if (window->HasSharedProperty( |
98 mus::mojom::WindowManager::kRestoreBounds_Property)) { | 98 ::mus::mojom::WindowManager::kRestoreBounds_Property)) { |
99 return window->GetSharedProperty<gfx::Rect>( | 99 return window->GetSharedProperty<gfx::Rect>( |
100 mus::mojom::WindowManager::kRestoreBounds_Property); | 100 ::mus::mojom::WindowManager::kRestoreBounds_Property); |
101 } | 101 } |
102 return gfx::Rect(); | 102 return gfx::Rect(); |
103 } | 103 } |
104 | 104 |
105 void SetShadow(mus::Window* window, Shadow* shadow) { | 105 void SetShadow(::mus::Window* window, Shadow* shadow) { |
106 window->SetLocalProperty(kLocalShadowProperty, shadow); | 106 window->SetLocalProperty(kLocalShadowProperty, shadow); |
107 } | 107 } |
108 | 108 |
109 Shadow* GetShadow(const mus::Window* window) { | 109 Shadow* GetShadow(const ::mus::Window* window) { |
110 return window->GetLocalProperty(kLocalShadowProperty); | 110 return window->GetLocalProperty(kLocalShadowProperty); |
111 } | 111 } |
112 | 112 |
113 mus::mojom::WindowType GetWindowType(const mus::Window* window) { | 113 ::mus::mojom::WindowType GetWindowType(const ::mus::Window* window) { |
114 if (window->HasSharedProperty( | 114 if (window->HasSharedProperty( |
115 mus::mojom::WindowManager::kWindowType_Property)) { | 115 ::mus::mojom::WindowManager::kWindowType_Property)) { |
116 return static_cast<mus::mojom::WindowType>( | 116 return static_cast<::mus::mojom::WindowType>( |
117 window->GetSharedProperty<int32_t>( | 117 window->GetSharedProperty<int32_t>( |
118 mus::mojom::WindowManager::kWindowType_Property)); | 118 ::mus::mojom::WindowManager::kWindowType_Property)); |
119 } | 119 } |
120 return mus::mojom::WindowType::POPUP; | 120 return ::mus::mojom::WindowType::POPUP; |
121 } | 121 } |
122 | 122 |
123 mus::mojom::WindowType GetWindowType( | 123 ::mus::mojom::WindowType GetWindowType( |
124 const mus::Window::SharedProperties& properties) { | 124 const ::mus::Window::SharedProperties& properties) { |
125 const auto iter = | 125 const auto iter = |
126 properties.find(mus::mojom::WindowManager::kWindowType_Property); | 126 properties.find(::mus::mojom::WindowManager::kWindowType_Property); |
127 if (iter != properties.end()) { | 127 if (iter != properties.end()) { |
128 return static_cast<mus::mojom::WindowType>( | 128 return static_cast<::mus::mojom::WindowType>( |
129 mojo::ConvertTo<int32_t>(iter->second)); | 129 mojo::ConvertTo<int32_t>(iter->second)); |
130 } | 130 } |
131 return mus::mojom::WindowType::POPUP; | 131 return ::mus::mojom::WindowType::POPUP; |
132 } | 132 } |
133 | 133 |
134 ui::wm::WindowType GetWmWindowType(const mus::Window* window) { | 134 ui::wm::WindowType GetWmWindowType(const ::mus::Window* window) { |
135 switch (GetWindowType(window)) { | 135 switch (GetWindowType(window)) { |
136 case mus::mojom::WindowType::WINDOW: | 136 case ::mus::mojom::WindowType::WINDOW: |
137 return ui::wm::WINDOW_TYPE_NORMAL; | 137 return ui::wm::WINDOW_TYPE_NORMAL; |
138 | 138 |
139 case mus::mojom::WindowType::PANEL: | 139 case ::mus::mojom::WindowType::PANEL: |
140 return ui::wm::WINDOW_TYPE_PANEL; | 140 return ui::wm::WINDOW_TYPE_PANEL; |
141 | 141 |
142 case mus::mojom::WindowType::CONTROL: | 142 case ::mus::mojom::WindowType::CONTROL: |
143 return ui::wm::WINDOW_TYPE_CONTROL; | 143 return ui::wm::WINDOW_TYPE_CONTROL; |
144 | 144 |
145 case mus::mojom::WindowType::WINDOW_FRAMELESS: | 145 case ::mus::mojom::WindowType::WINDOW_FRAMELESS: |
146 case mus::mojom::WindowType::POPUP: | 146 case ::mus::mojom::WindowType::POPUP: |
147 case mus::mojom::WindowType::BUBBLE: | 147 case ::mus::mojom::WindowType::BUBBLE: |
148 case mus::mojom::WindowType::DRAG: | 148 case ::mus::mojom::WindowType::DRAG: |
149 return ui::wm::WINDOW_TYPE_POPUP; | 149 return ui::wm::WINDOW_TYPE_POPUP; |
150 | 150 |
151 case mus::mojom::WindowType::MENU: | 151 case ::mus::mojom::WindowType::MENU: |
152 return ui::wm::WINDOW_TYPE_MENU; | 152 return ui::wm::WINDOW_TYPE_MENU; |
153 | 153 |
154 case mus::mojom::WindowType::TOOLTIP: | 154 case ::mus::mojom::WindowType::TOOLTIP: |
155 return ui::wm::WINDOW_TYPE_TOOLTIP; | 155 return ui::wm::WINDOW_TYPE_TOOLTIP; |
156 } | 156 } |
157 | 157 |
158 return ui::wm::WINDOW_TYPE_UNKNOWN; | 158 return ui::wm::WINDOW_TYPE_UNKNOWN; |
159 } | 159 } |
160 | 160 |
161 ash::mojom::AshWindowType GetAshWindowType(const mus::Window* window) { | 161 mojom::AshWindowType GetAshWindowType(const ::mus::Window* window) { |
162 if (!window->HasSharedProperty(ash::mojom::kAshWindowType_Property)) | 162 if (!window->HasSharedProperty(mojom::kAshWindowType_Property)) |
163 return ash::mojom::AshWindowType::COUNT; | 163 return mojom::AshWindowType::COUNT; |
164 | 164 |
165 return static_cast<ash::mojom::AshWindowType>( | 165 return static_cast<mojom::AshWindowType>( |
166 window->GetSharedProperty<int32_t>(ash::mojom::kAshWindowType_Property)); | 166 window->GetSharedProperty<int32_t>(mojom::kAshWindowType_Property)); |
167 } | 167 } |
168 | 168 |
169 base::string16 GetWindowTitle(const mus::Window* window) { | 169 base::string16 GetWindowTitle(const ::mus::Window* window) { |
170 if (!window->HasSharedProperty( | 170 if (!window->HasSharedProperty( |
171 mus::mojom::WindowManager::kWindowTitle_Property)) { | 171 ::mus::mojom::WindowManager::kWindowTitle_Property)) { |
172 return base::string16(); | 172 return base::string16(); |
173 } | 173 } |
174 | 174 |
175 return window->GetSharedProperty<base::string16>( | 175 return window->GetSharedProperty<base::string16>( |
176 mus::mojom::WindowManager::kWindowTitle_Property); | 176 ::mus::mojom::WindowManager::kWindowTitle_Property); |
177 } | 177 } |
178 | 178 |
179 mojo::Array<uint8_t> GetWindowAppIcon(const mus::Window* window) { | 179 mojo::Array<uint8_t> GetWindowAppIcon(const ::mus::Window* window) { |
180 if (window->HasSharedProperty( | 180 if (window->HasSharedProperty( |
181 mus::mojom::WindowManager::kWindowAppIcon_Property)) { | 181 ::mus::mojom::WindowManager::kWindowAppIcon_Property)) { |
182 return mojo::Array<uint8_t>::From( | 182 return mojo::Array<uint8_t>::From( |
183 window->GetSharedProperty<std::vector<uint8_t>>( | 183 window->GetSharedProperty<std::vector<uint8_t>>( |
184 mus::mojom::WindowManager::kWindowAppIcon_Property)); | 184 ::mus::mojom::WindowManager::kWindowAppIcon_Property)); |
185 } | 185 } |
186 return mojo::Array<uint8_t>(); | 186 return mojo::Array<uint8_t>(); |
187 } | 187 } |
188 | 188 |
189 void SetAppID(mus::Window* window, const base::string16& app_id) { | 189 void SetAppID(::mus::Window* window, const base::string16& app_id) { |
190 window->SetSharedProperty<base::string16>( | 190 window->SetSharedProperty<base::string16>( |
191 mus::mojom::WindowManager::kAppID_Property, app_id); | 191 ::mus::mojom::WindowManager::kAppID_Property, app_id); |
192 } | 192 } |
193 | 193 |
194 base::string16 GetAppID(const mus::Window* window) { | 194 base::string16 GetAppID(const ::mus::Window* window) { |
195 if (!window->HasSharedProperty(mus::mojom::WindowManager::kAppID_Property)) | 195 if (!window->HasSharedProperty(::mus::mojom::WindowManager::kAppID_Property)) |
196 return base::string16(); | 196 return base::string16(); |
197 | 197 |
198 return window->GetSharedProperty<base::string16>( | 198 return window->GetSharedProperty<base::string16>( |
199 mus::mojom::WindowManager::kAppID_Property); | 199 ::mus::mojom::WindowManager::kAppID_Property); |
200 } | 200 } |
201 | 201 |
202 bool GetWindowIgnoredByShelf(mus::Window* window) { | 202 bool GetWindowIgnoredByShelf(::mus::Window* window) { |
203 return window->HasSharedProperty( | 203 return window->HasSharedProperty( |
204 mus::mojom::WindowManager::kWindowIgnoredByShelf_Property) && | 204 ::mus::mojom::WindowManager::kWindowIgnoredByShelf_Property) && |
205 window->GetSharedProperty<bool>( | 205 window->GetSharedProperty<bool>( |
206 mus::mojom::WindowManager::kWindowIgnoredByShelf_Property); | 206 ::mus::mojom::WindowManager::kWindowIgnoredByShelf_Property); |
207 } | 207 } |
208 | 208 |
209 void SetWindowIsJanky(mus::Window* window, bool janky) { | 209 void SetWindowIsJanky(::mus::Window* window, bool janky) { |
210 window->SetLocalProperty(kWindowIsJankyProperty, janky); | 210 window->SetLocalProperty(kWindowIsJankyProperty, janky); |
211 } | 211 } |
212 | 212 |
213 bool IsWindowJanky(mus::Window* window) { | 213 bool IsWindowJanky(::mus::Window* window) { |
214 return window->GetLocalProperty(kWindowIsJankyProperty); | 214 return window->GetLocalProperty(kWindowIsJankyProperty); |
215 } | 215 } |
216 | 216 |
217 bool IsWindowJankyProperty(const void* key) { | 217 bool IsWindowJankyProperty(const void* key) { |
218 return key == kWindowIsJankyProperty; | 218 return key == kWindowIsJankyProperty; |
219 } | 219 } |
220 | 220 |
221 void SetAlwaysOnTop(mus::Window* window, bool value) { | 221 void SetAlwaysOnTop(::mus::Window* window, bool value) { |
222 window->SetSharedProperty<bool>( | 222 window->SetSharedProperty<bool>( |
223 mus::mojom::WindowManager::kAlwaysOnTop_Property, value); | 223 ::mus::mojom::WindowManager::kAlwaysOnTop_Property, value); |
224 } | 224 } |
225 | 225 |
226 bool IsAlwaysOnTop(mus::Window* window) { | 226 bool IsAlwaysOnTop(::mus::Window* window) { |
227 return window->HasSharedProperty( | 227 return window->HasSharedProperty( |
228 mus::mojom::WindowManager::kAlwaysOnTop_Property) && | 228 ::mus::mojom::WindowManager::kAlwaysOnTop_Property) && |
229 window->GetSharedProperty<bool>( | 229 window->GetSharedProperty<bool>( |
230 mus::mojom::WindowManager::kAlwaysOnTop_Property); | 230 ::mus::mojom::WindowManager::kAlwaysOnTop_Property); |
231 } | 231 } |
232 | 232 |
233 } // namespace wm | 233 } // namespace mus |
234 } // namespace mash | 234 } // namespace ash |
OLD | NEW |