| Index: content/browser/screen_orientation/screen_orientation.cc
|
| diff --git a/content/browser/screen_orientation/screen_orientation.cc b/content/browser/screen_orientation/screen_orientation.cc
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..b80366ac47c23ff17b12a0e394274ad770a17c94
|
| --- /dev/null
|
| +++ b/content/browser/screen_orientation/screen_orientation.cc
|
| @@ -0,0 +1,66 @@
|
| +// Copyright 2016 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.h"
|
| +
|
| +#include "base/bind.h"
|
| +#include "base/callback_helpers.h"
|
| +#include "content/public/browser/navigation_details.h"
|
| +#include "content/public/browser/screen_orientation_provider.h"
|
| +#include "content/public/browser/web_contents.h"
|
| +
|
| +namespace content {
|
| +
|
| +using LockResult = blink::mojom::ScreenOrientationLockResult;
|
| +
|
| +ScreenOrientation::ScreenOrientation(WebContents* web_contents)
|
| + : WebContentsObserver(web_contents),
|
| + bindings_(web_contents, this),
|
| + weak_factory_(this) {
|
| + provider_.reset(new ScreenOrientationProvider(web_contents));
|
| +}
|
| +
|
| +ScreenOrientation::~ScreenOrientation() = default;
|
| +
|
| +void ScreenOrientation::LockOrientation(
|
| + blink::WebScreenOrientationLockType orientation,
|
| + const LockOrientationCallback& callback) {
|
| + if (!on_result_callback_.is_null()) {
|
| + NotifyLockResult(LockResult::SCREEN_ORIENTATION_LOCK_RESULT_ERROR_CANCELED);
|
| + }
|
| +
|
| + on_result_callback_ = callback;
|
| +
|
| + provider_->LockOrientation(
|
| + orientation,
|
| + base::Bind(&ScreenOrientation::NotifyLockResult, base::Unretained(this)));
|
| +}
|
| +
|
| +void ScreenOrientation::UnlockOrientation() {
|
| + // Cancel any pending lock request.
|
| + NotifyLockResult(LockResult::SCREEN_ORIENTATION_LOCK_RESULT_ERROR_CANCELED);
|
| +
|
| + provider_->UnlockOrientation();
|
| +}
|
| +
|
| +void ScreenOrientation::DidNavigateMainFrame(
|
| + const LoadCommittedDetails& details,
|
| + const FrameNavigateParams& params) {
|
| + if (details.is_in_page)
|
| + return;
|
| + provider_->UnlockOrientation();
|
| +}
|
| +
|
| +void ScreenOrientation::NotifyLockResult(LockResult result) {
|
| + if (on_result_callback_.is_null())
|
| + return;
|
| +
|
| + base::ResetAndReturn(&on_result_callback_).Run(result);
|
| +}
|
| +
|
| +ScreenOrientationProvider* ScreenOrientation::GetScreenOrientationProvider() {
|
| + return provider_.get();
|
| +}
|
| +
|
| +} // namespace content
|
|
|