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

Unified Diff: content/browser/screen_orientation/screen_orientation_service_impl.cc

Issue 549603003: Create Mojo service for locking/unlocking screen orientation. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Response to review, port unittest Created 6 years, 3 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
Index: content/browser/screen_orientation/screen_orientation_service_impl.cc
diff --git a/content/browser/screen_orientation/screen_orientation_service_impl.cc b/content/browser/screen_orientation/screen_orientation_service_impl.cc
new file mode 100644
index 0000000000000000000000000000000000000000..b14fd8d70c3d3f82a1891c480024c1e28510f092
--- /dev/null
+++ b/content/browser/screen_orientation/screen_orientation_service_impl.cc
@@ -0,0 +1,80 @@
+// 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 "content/browser/screen_orientation/screen_orientation_service_impl.h"
+
+#include "base/bind.h"
+#include "content/browser/web_contents/web_contents_impl.h"
+#include "content/public/browser/screen_orientation_provider.h"
+
+namespace content {
+
+// static
+void ScreenOrientationServiceImpl::Create(
+ WebContents* web_contents,
+ mojo::InterfaceRequest<ScreenOrientationService> request) {
+ BindToRequest(new ScreenOrientationServiceImpl(web_contents), &request);
+}
+
+ScreenOrientationServiceImpl::ScreenOrientationServiceImpl(
+ WebContents* web_contents)
+ : context_(static_cast<WebContentsImpl*>(web_contents)
+ ->screen_orientation_context()),
qsr 2014/09/22 13:01:48 The -> should be on the previous line.
+ provider_(ScreenOrientationProvider::Create(
qsr 2014/09/22 13:01:48 As discussed live, maybe we want the provider to b
blundell 2014/09/22 13:21:54 Yes, I agree. The provider can be per-WebContents
+ base::Bind(&ScreenOrientationServiceImpl::NotifyLockResult,
+ base::Unretained(this)),
+ web_contents)) {
+ context_->AddObserver(this);
+}
+
+ScreenOrientationServiceImpl::~ScreenOrientationServiceImpl() {
+ context_->RemoveObserver(this);
+}
+
+void ScreenOrientationServiceImpl::NotifyLockResult(
+ ScreenOrientationLockResult result) {
+ if (on_result_callback_.is_null())
+ return;
+
+ on_result_callback_.Run(result);
+
+ // Reset the callback.
+ on_result_callback_ = mojo::Callback<void(ScreenOrientationLockResult)>();
+}
+
+void ScreenOrientationServiceImpl::OnScreenOrientationChange() {
+ if (provider_)
+ provider_->OnOrientationChange();
+}
+
+void ScreenOrientationServiceImpl::OnNewLockRequest() {
+ // Cancel any pending lock request.
+ NotifyLockResult(SCREEN_ORIENTATION_LOCK_RESULT_ERROR_CANCELED);
+}
+
+void ScreenOrientationServiceImpl::LockOrientation(
+ ScreenOrientationLockType lock_type,
+ const mojo::Callback<void(ScreenOrientationLockResult)>& callback) {
+ context_->OnNewLockRequest();
+
+ DCHECK(on_result_callback_.is_null());
+ on_result_callback_ = callback;
+
+ if (!provider_) {
+ NotifyLockResult(SCREEN_ORIENTATION_LOCK_RESULT_ERROR_NOT_AVAILABLE);
+ return;
+ }
+
+ provider_->LockOrientation(lock_type);
+}
+
+void ScreenOrientationServiceImpl::UnlockOrientation() {
+ // Cancel any pending lock request.
+ NotifyLockResult(SCREEN_ORIENTATION_LOCK_RESULT_ERROR_CANCELED);
+
+ if (provider_)
+ provider_->UnlockOrientation();
+}
+
+} // namespace content

Powered by Google App Engine
This is Rietveld 408576698