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