Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(214)

Side by Side Diff: mash/wm/shelf_layout_manager.cc

Issue 1950293003: mash: Add status area container to mash window manager (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: review comments Created 4 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « mash/wm/shelf_layout_manager.h ('k') | mash/wm/status_layout_manager.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
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/shelf_layout.h" 5 #include "mash/wm/shelf_layout_manager.h"
6 6
7 #include "components/mus/public/cpp/property_type_converters.h"
8 #include "components/mus/public/cpp/window.h" 7 #include "components/mus/public/cpp/window.h"
9 #include "components/mus/public/cpp/window_property.h"
10 #include "mash/wm/property_util.h" 8 #include "mash/wm/property_util.h"
11 #include "mash/wm/public/interfaces/ash_window_type.mojom.h" 9 #include "mash/wm/public/interfaces/ash_window_type.mojom.h"
12 #include "ui/gfx/geometry/rect.h" 10 #include "ui/gfx/geometry/rect.h"
13 11
14 namespace mash { 12 namespace mash {
15 namespace wm { 13 namespace wm {
16 14
17 namespace { 15 ShelfLayoutManager::ShelfLayoutManager(mus::Window* owner)
18
19 mojom::AshWindowType GetAshWindowType(const mus::Window* window) {
20 if (!window->HasSharedProperty(mojom::kAshWindowType_Property))
21 return mojom::AshWindowType::COUNT;
22
23 return static_cast<mojom::AshWindowType>(
24 window->GetSharedProperty<int32_t>(mojom::kAshWindowType_Property));
25 }
26
27 } // namespace
28
29 ShelfLayout::ShelfLayout(mus::Window* owner)
30 : LayoutManager(owner), 16 : LayoutManager(owner),
31 alignment_(mash::shelf::mojom::Alignment::BOTTOM), 17 alignment_(mash::shelf::mojom::Alignment::BOTTOM),
32 auto_hide_behavior_(mash::shelf::mojom::AutoHideBehavior::NEVER) { 18 auto_hide_behavior_(mash::shelf::mojom::AutoHideBehavior::NEVER) {
33 AddLayoutProperty(mus::mojom::WindowManager::kPreferredSize_Property); 19 AddLayoutProperty(mus::mojom::WindowManager::kPreferredSize_Property);
34 } 20 }
35 21
36 ShelfLayout::~ShelfLayout() {} 22 ShelfLayoutManager::~ShelfLayoutManager() {}
37 23
38 // We explicitly don't make assertions about the number of children in this 24 // We explicitly don't make assertions about the number of children in this
39 // layout as the number of children can vary when the application providing the 25 // layout as the number of children can vary when the application providing the
40 // shelf restarts. 26 // shelf restarts.
41 27
42 void ShelfLayout::LayoutWindow(mus::Window* window) { 28 void ShelfLayoutManager::LayoutWindow(mus::Window* window) {
43 const mojom::AshWindowType ash_window_type = GetAshWindowType(window); 29 if (GetAshWindowType(window) != mojom::AshWindowType::SHELF) {
30 NOTREACHED() << "Unknown window in USER_SHELF container.";
31 return;
32 }
44 gfx::Size size = GetWindowPreferredSize(window); 33 gfx::Size size = GetWindowPreferredSize(window);
45 34
46 if (alignment_ == mash::shelf::mojom::Alignment::BOTTOM) { 35 if (alignment_ == mash::shelf::mojom::Alignment::BOTTOM) {
47 const int y = owner()->bounds().height() - size.height(); 36 const int y = owner()->bounds().height() - size.height();
48 if (ash_window_type == mojom::AshWindowType::SHELF) { 37 size.set_width(owner()->bounds().width());
49 size.set_width(owner()->bounds().width()); 38 window->SetBounds(gfx::Rect(0, y, size.width(), size.height()));
50 window->SetBounds(gfx::Rect(0, y, size.width(), size.height()));
51 } else if (ash_window_type == mojom::AshWindowType::STATUS_AREA) {
52 // TODO(msw): Place the status area on the left for RTL UIs.
53 window->SetBounds(gfx::Rect(owner()->bounds().width() - size.width(), y,
54 size.width(), size.height()));
55 } else {
56 NOTREACHED() << "Unknown window in USER_SHELF container.";
57 }
58 } else { 39 } else {
59 const int x = (alignment_ == mash::shelf::mojom::Alignment::LEFT) 40 const int x = (alignment_ == mash::shelf::mojom::Alignment::LEFT)
60 ? 0 41 ? 0
61 : (owner()->bounds().width() - size.width()); 42 : (owner()->bounds().width() - size.width());
62 if (ash_window_type == mojom::AshWindowType::SHELF) { 43 size.set_height(owner()->bounds().height());
63 size.set_height(owner()->bounds().height()); 44 window->SetBounds(gfx::Rect(x, 0, size.width(), size.height()));
64 window->SetBounds(gfx::Rect(x, 0, size.width(), size.height()));
65 } else if (ash_window_type == mojom::AshWindowType::STATUS_AREA) {
66 window->SetBounds(gfx::Rect(x, owner()->bounds().height() - size.height(),
67 size.width(), size.height()));
68 } else {
69 NOTREACHED() << "Unknown window in USER_SHELF container.";
70 }
71 } 45 }
72 } 46 }
73 47
74 void ShelfLayout::SetAlignment(mash::shelf::mojom::Alignment alignment) { 48 void ShelfLayoutManager::SetAlignment(mash::shelf::mojom::Alignment alignment) {
75 if (alignment_ == alignment) 49 if (alignment_ == alignment)
76 return; 50 return;
77 51
78 alignment_ = alignment; 52 alignment_ = alignment;
79 for (mus::Window* window : owner()->children()) 53 for (mus::Window* window : owner()->children())
80 LayoutWindow(window); 54 LayoutWindow(window);
81 } 55 }
82 56
83 void ShelfLayout::SetAutoHideBehavior( 57 void ShelfLayoutManager::SetAutoHideBehavior(
84 mash::shelf::mojom::AutoHideBehavior auto_hide) { 58 mash::shelf::mojom::AutoHideBehavior auto_hide) {
85 if (auto_hide_behavior_ == auto_hide) 59 if (auto_hide_behavior_ == auto_hide)
86 return; 60 return;
87 61
88 auto_hide_behavior_ = auto_hide; 62 auto_hide_behavior_ = auto_hide;
89 NOTIMPLEMENTED(); 63 NOTIMPLEMENTED();
90 } 64 }
91 65
92 } // namespace wm 66 } // namespace wm
93 } // namespace mash 67 } // namespace mash
OLDNEW
« no previous file with comments | « mash/wm/shelf_layout_manager.h ('k') | mash/wm/status_layout_manager.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698