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

Side by Side Diff: mash/screenlock/screenlock.cc

Issue 1725353003: Eliminate mojo::Shell client lib class (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@15connector
Patch Set: . Created 4 years, 10 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 2016 The Chromium Authors. All rights reserved. 1 // Copyright 2016 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/screenlock/screenlock.h" 5 #include "mash/screenlock/screenlock.h"
6 6
7 #include "base/macros.h" 7 #include "base/macros.h"
8 #include "base/strings/utf_string_conversions.h" 8 #include "base/strings/utf_string_conversions.h"
9 #include "components/mus/public/cpp/property_type_converters.h" 9 #include "components/mus/public/cpp/property_type_converters.h"
10 #include "mash/shell/public/interfaces/shell.mojom.h" 10 #include "mash/shell/public/interfaces/shell.mojom.h"
11 #include "mash/wm/public/interfaces/container.mojom.h" 11 #include "mash/wm/public/interfaces/container.mojom.h"
12 #include "mojo/public/cpp/bindings/binding.h" 12 #include "mojo/public/cpp/bindings/binding.h"
13 #include "mojo/shell/public/cpp/shell.h" 13 #include "mojo/shell/public/cpp/connector.h"
14 #include "ui/views/background.h" 14 #include "ui/views/background.h"
15 #include "ui/views/controls/button/label_button.h" 15 #include "ui/views/controls/button/label_button.h"
16 #include "ui/views/mus/aura_init.h" 16 #include "ui/views/mus/aura_init.h"
17 #include "ui/views/mus/native_widget_mus.h" 17 #include "ui/views/mus/native_widget_mus.h"
18 #include "ui/views/mus/window_manager_connection.h" 18 #include "ui/views/mus/window_manager_connection.h"
19 #include "ui/views/widget/widget_delegate.h" 19 #include "ui/views/widget/widget_delegate.h"
20 20
21 namespace mash { 21 namespace mash {
22 namespace screenlock { 22 namespace screenlock {
23 namespace { 23 namespace {
24 24
25 class ScreenlockView : public views::WidgetDelegateView, 25 class ScreenlockView : public views::WidgetDelegateView,
26 public views::ButtonListener { 26 public views::ButtonListener {
27 public: 27 public:
28 explicit ScreenlockView(mojo::Shell* shell) 28 explicit ScreenlockView(mojo::Connector* connector)
29 : shell_(shell), 29 : connector_(connector),
30 unlock_button_( 30 unlock_button_(
31 new views::LabelButton(this, base::ASCIIToUTF16("Unlock"))) { 31 new views::LabelButton(this, base::ASCIIToUTF16("Unlock"))) {
32 set_background(views::Background::CreateSolidBackground(SK_ColorYELLOW)); 32 set_background(views::Background::CreateSolidBackground(SK_ColorYELLOW));
33 unlock_button_->SetStyle(views::Button::STYLE_BUTTON); 33 unlock_button_->SetStyle(views::Button::STYLE_BUTTON);
34 AddChildView(unlock_button_); 34 AddChildView(unlock_button_);
35 } 35 }
36 ~ScreenlockView() override {} 36 ~ScreenlockView() override {}
37 37
38 private: 38 private:
39 // Overridden from views::WidgetDelegate: 39 // Overridden from views::WidgetDelegate:
(...skipping 13 matching lines...) Expand all
53 53
54 unlock_button_->SetBounds(bounds.width() - ps.width(), 54 unlock_button_->SetBounds(bounds.width() - ps.width(),
55 bounds.bottom() + 10, 55 bounds.bottom() + 10,
56 ps.width(), ps.height()); 56 ps.width(), ps.height());
57 } 57 }
58 58
59 // Overridden from views::ButtonListener: 59 // Overridden from views::ButtonListener:
60 void ButtonPressed(views::Button* sender, const ui::Event& event) override { 60 void ButtonPressed(views::Button* sender, const ui::Event& event) override {
61 DCHECK_EQ(sender, unlock_button_); 61 DCHECK_EQ(sender, unlock_button_);
62 mash::shell::mojom::ShellPtr shell; 62 mash::shell::mojom::ShellPtr shell;
63 shell_->ConnectToInterface("mojo:mash_shell", &shell); 63 connector_->ConnectToInterface("mojo:mash_shell", &shell);
64 shell->UnlockScreen(); 64 shell->UnlockScreen();
65 } 65 }
66 66
67 mojo::Shell* shell_; 67 mojo::Connector* connector_;
68 views::LabelButton* unlock_button_; 68 views::LabelButton* unlock_button_;
69 69
70 DISALLOW_COPY_AND_ASSIGN(ScreenlockView); 70 DISALLOW_COPY_AND_ASSIGN(ScreenlockView);
71 }; 71 };
72 72
73 } // namespace 73 } // namespace
74 74
75 Screenlock::Screenlock() : shell_(nullptr) {} 75 Screenlock::Screenlock() {}
76 Screenlock::~Screenlock() {} 76 Screenlock::~Screenlock() {}
77 77
78 void Screenlock::Initialize(mojo::Shell* shell, const std::string& url, 78 void Screenlock::Initialize(mojo::Connector* connector, const std::string& url,
79 uint32_t id, uint32_t user_id) { 79 uint32_t id, uint32_t user_id) {
80 shell_ = shell; 80 tracing_.Initialize(connector, url);
81 tracing_.Initialize(shell, url);
82 81
83 mash::shell::mojom::ShellPtr mash_shell; 82 mash::shell::mojom::ShellPtr mash_shell;
84 shell_->ConnectToInterface("mojo:mash_shell", &mash_shell); 83 connector->ConnectToInterface("mojo:mash_shell", &mash_shell);
85 mash_shell->AddScreenlockStateListener( 84 mash_shell->AddScreenlockStateListener(
86 bindings_.CreateInterfacePtrAndBind(this)); 85 bindings_.CreateInterfacePtrAndBind(this));
87 86
88 aura_init_.reset(new views::AuraInit(shell, "views_mus_resources.pak")); 87 aura_init_.reset(new views::AuraInit(connector, "views_mus_resources.pak"));
89 views::WindowManagerConnection::Create(shell); 88 views::WindowManagerConnection::Create(connector);
90 89
91 views::Widget* widget = new views::Widget; 90 views::Widget* widget = new views::Widget;
92 views::Widget::InitParams params( 91 views::Widget::InitParams params(
93 views::Widget::InitParams::TYPE_WINDOW_FRAMELESS); 92 views::Widget::InitParams::TYPE_WINDOW_FRAMELESS);
94 params.delegate = new ScreenlockView(shell); 93 params.delegate = new ScreenlockView(connector);
95 94
96 std::map<std::string, std::vector<uint8_t>> properties; 95 std::map<std::string, std::vector<uint8_t>> properties;
97 properties[mash::wm::mojom::kWindowContainer_Property] = 96 properties[mash::wm::mojom::kWindowContainer_Property] =
98 mojo::TypeConverter<const std::vector<uint8_t>, int32_t>::Convert( 97 mojo::TypeConverter<const std::vector<uint8_t>, int32_t>::Convert(
99 static_cast<int32_t>(mash::wm::mojom::Container::LOGIN_WINDOWS)); 98 static_cast<int32_t>(mash::wm::mojom::Container::LOGIN_WINDOWS));
100 mus::Window* window = 99 mus::Window* window =
101 views::WindowManagerConnection::Get()->NewWindow(properties); 100 views::WindowManagerConnection::Get()->NewWindow(properties);
102 params.native_widget = new views::NativeWidgetMus( 101 params.native_widget = new views::NativeWidgetMus(
103 widget, shell, window, mus::mojom::SurfaceType::DEFAULT); 102 widget, connector, window, mus::mojom::SurfaceType::DEFAULT);
104 widget->Init(params); 103 widget->Init(params);
105 widget->Show(); 104 widget->Show();
106 } 105 }
107 106
108 void Screenlock::ScreenlockStateChanged(bool screen_locked) { 107 void Screenlock::ScreenlockStateChanged(bool screen_locked) {
109 if (!screen_locked) 108 if (!screen_locked)
110 shell_->Quit(); 109 base::MessageLoop::current()->QuitWhenIdle();
111 } 110 }
112 111
113 } // namespace screenlock 112 } // namespace screenlock
114 } // namespace main 113 } // namespace main
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698