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

Unified Diff: athena/screen_lock/chrome/chrome_screen_lock_manager.cc

Issue 620663005: Lock screen for Chrome-Athena (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: one more nit Created 6 years, 2 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « athena/screen_lock/chrome/DEPS ('k') | athena/screen_lock/public/DEPS » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: athena/screen_lock/chrome/chrome_screen_lock_manager.cc
diff --git a/athena/screen_lock/chrome/chrome_screen_lock_manager.cc b/athena/screen_lock/chrome/chrome_screen_lock_manager.cc
new file mode 100644
index 0000000000000000000000000000000000000000..628b0d860c07be4b6e9b12972c638bfaa6ec5819
--- /dev/null
+++ b/athena/screen_lock/chrome/chrome_screen_lock_manager.cc
@@ -0,0 +1,94 @@
+// Copyright 2014 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "athena/input/public/accelerator_manager.h"
+#include "athena/input/public/input_manager.h"
+#include "athena/screen_lock/screen_lock_manager_base.h"
+#include "base/logging.h"
+#include "chrome/browser/chromeos/login/lock/screen_locker.h"
+
+namespace athena {
+namespace {
+
+enum Command {
+ CMD_LOCK_SCREEN
+};
+
+const AcceleratorData accelerator_data[] = {
+ { TRIGGER_ON_PRESS, ui::VKEY_L, ui::EF_SHIFT_DOWN | ui::EF_CONTROL_DOWN,
+ CMD_LOCK_SCREEN, AF_NONE }};
+
+class ChromeScreenLockManager : public ScreenLockManagerBase,
+ public AcceleratorHandler,
+ public PowerButtonObserver {
+ public:
+ ChromeScreenLockManager() {}
+
+ void Init();
+
+ protected:
+ virtual ~ChromeScreenLockManager();
+
+ private:
+ // ScreenLockManager:
+ virtual void LockScreen() override;
+
+ // AcceleratorHandler:
+ virtual bool IsCommandEnabled(int command_id) const override;
+ virtual bool OnAcceleratorFired(int command_id,
+ const ui::Accelerator& accelerator) override;
+
+ // PowerButtonObserver:
+ virtual void OnPowerButtonStateChanged(State state) override;
+
+ DISALLOW_COPY_AND_ASSIGN(ChromeScreenLockManager);
+};
+
+ChromeScreenLockManager::~ChromeScreenLockManager() {
+ InputManager::Get()->RemovePowerButtonObserver(this);
+}
+
+void ChromeScreenLockManager::Init() {
+ AcceleratorManager::Get()->RegisterAccelerators(
+ accelerator_data, arraysize(accelerator_data), this);
+ InputManager::Get()->AddPowerButtonObserver(this);
+}
+
+void ChromeScreenLockManager::LockScreen() {
+ chromeos::ScreenLocker::HandleLockScreenRequest();
+}
+
+bool ChromeScreenLockManager::IsCommandEnabled(int command_id) const {
+ return true;
+}
+
+bool ChromeScreenLockManager::OnAcceleratorFired(
+ int command_id,
+ const ui::Accelerator& accelerator) {
+ switch (command_id) {
+ case CMD_LOCK_SCREEN:
+ LockScreen();
+ return true;
+
+ default:
+ NOTREACHED();
+ }
+ return false;
+}
+
+void ChromeScreenLockManager::OnPowerButtonStateChanged(State state) {
+ if (state == PRESSED)
+ LockScreen();
+}
+
+} // namespace
+
+// static
+ScreenLockManager* ScreenLockManager::Create() {
+ ChromeScreenLockManager* instance = new ChromeScreenLockManager();
+ instance->Init();
+ return instance;
+}
+
+} // namespace athena
« no previous file with comments | « athena/screen_lock/chrome/DEPS ('k') | athena/screen_lock/public/DEPS » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698