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

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

Issue 1835403002: Support additional mash shelf alignments. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Cleanup; address comments. Created 4 years, 8 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
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.h"
6 6
7 #include "components/mus/public/cpp/property_type_converters.h" 7 #include "components/mus/public/cpp/property_type_converters.h"
8 #include "components/mus/public/cpp/window.h" 8 #include "components/mus/public/cpp/window.h"
9 #include "components/mus/public/cpp/window_property.h" 9 #include "components/mus/public/cpp/window_property.h"
10 #include "mash/wm/property_util.h" 10 #include "mash/wm/property_util.h"
11 #include "mash/wm/public/interfaces/ash_window_type.mojom.h" 11 #include "mash/wm/public/interfaces/ash_window_type.mojom.h"
12 #include "ui/gfx/geometry/rect.h" 12 #include "ui/gfx/geometry/rect.h"
13 13
14 namespace mash { 14 namespace mash {
15 namespace wm { 15 namespace wm {
16 16
17 namespace { 17 namespace {
18 18
19 mojom::AshWindowType GetAshWindowType(const mus::Window* window) { 19 mojom::AshWindowType GetAshWindowType(const mus::Window* window) {
20 if (!window->HasSharedProperty(mojom::kAshWindowType_Property)) 20 if (!window->HasSharedProperty(mojom::kAshWindowType_Property))
21 return mojom::AshWindowType::COUNT; 21 return mojom::AshWindowType::COUNT;
22 22
23 return static_cast<mojom::AshWindowType>( 23 return static_cast<mojom::AshWindowType>(
24 window->GetSharedProperty<int32_t>(mojom::kAshWindowType_Property)); 24 window->GetSharedProperty<int32_t>(mojom::kAshWindowType_Property));
25 } 25 }
26 26
27 } // namespace 27 } // namespace
28 28
29 ShelfLayout::ShelfLayout(mus::Window* owner) : LayoutManager(owner) { 29 ShelfLayout::ShelfLayout(mus::Window* owner)
30 : LayoutManager(owner),
31 alignment_(mojom::ShelfAlignment::BOTTOM),
32 auto_hide_behavior_(mojom::ShelfAutoHideBehavior::NEVER) {
30 AddLayoutProperty(mus::mojom::WindowManager::kPreferredSize_Property); 33 AddLayoutProperty(mus::mojom::WindowManager::kPreferredSize_Property);
31 } 34 }
32 35
33 ShelfLayout::~ShelfLayout() {} 36 ShelfLayout::~ShelfLayout() {}
34 37
35 // We explicitly don't make assertions about the number of children in this 38 // We explicitly don't make assertions about the number of children in this
36 // layout as the number of children can vary when the application providing the 39 // layout as the number of children can vary when the application providing the
37 // shelf restarts. 40 // shelf restarts.
38 41
39 void ShelfLayout::LayoutWindow(mus::Window* window) { 42 void ShelfLayout::LayoutWindow(mus::Window* window) {
40 // TODO(msw): Support additional shelf alignments and RTL UI. 43 const mojom::AshWindowType ash_window_type = GetAshWindowType(window);
41 gfx::Size size = GetWindowPreferredSize(window); 44 gfx::Size size = GetWindowPreferredSize(window);
42 const int y = owner()->bounds().height() - size.height(); 45
43 const mojom::AshWindowType ash_window_type = GetAshWindowType(window); 46 if (alignment_ == mojom::ShelfAlignment::BOTTOM) {
44 if (ash_window_type == mojom::AshWindowType::SHELF) { 47 const int y = owner()->bounds().height() - size.height();
45 size.set_width(owner()->bounds().width()); 48 if (ash_window_type == mojom::AshWindowType::SHELF) {
46 window->SetBounds(gfx::Rect(0, y, size.width(), size.height())); 49 size.set_width(owner()->bounds().width());
47 } else if (ash_window_type == mojom::AshWindowType::STATUS_AREA) { 50 window->SetBounds(gfx::Rect(0, y, size.width(), size.height()));
48 window->SetBounds(gfx::Rect(owner()->bounds().width() - size.width(), y, 51 } else if (ash_window_type == mojom::AshWindowType::STATUS_AREA) {
49 size.width(), size.height())); 52 // TODO(msw): Place the status area on the right for RTL UIs.
James Cook 2016/04/11 23:36:48 on the right? or on the left?
msw 2016/04/12 00:13:59 Done.
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 }
50 } else { 58 } else {
51 NOTREACHED() << "Unknown window in USER_SHELF container."; 59 const int x = (alignment_ == mojom::ShelfAlignment::LEFT)
60 ? 0
61 : (owner()->bounds().width() - size.width());
62 if (ash_window_type == mojom::AshWindowType::SHELF) {
63 size.set_height(owner()->bounds().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 }
52 } 71 }
53 } 72 }
54 73
74 void ShelfLayout::SetAlignment(mojom::ShelfAlignment alignment) {
75 if (alignment_ == alignment)
76 return;
77
78 alignment_ = alignment;
79 for (auto window : owner()->children())
James Cook 2016/04/11 23:36:48 I think for range-based for loops we prefer const
msw 2016/04/12 00:13:59 Done.
80 LayoutWindow(window);
81 }
82
83 void ShelfLayout::SetAutoHideBehavior(mojom::ShelfAutoHideBehavior auto_hide) {
84 if (auto_hide_behavior_ == auto_hide)
85 return;
86
87 auto_hide_behavior_ = auto_hide;
88 NOTIMPLEMENTED();
89 }
90
55 } // namespace wm 91 } // namespace wm
56 } // namespace mash 92 } // namespace mash
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698