 Chromium Code Reviews
 Chromium Code Reviews Issue 549603003:
  Create Mojo service for locking/unlocking screen orientation.  (Closed) 
  Base URL: https://chromium.googlesource.com/chromium/src.git@master
    
  
    Issue 549603003:
  Create Mojo service for locking/unlocking screen orientation.  (Closed) 
  Base URL: https://chromium.googlesource.com/chromium/src.git@master| 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 |