Chromium Code Reviews| Index: chrome/browser/ui/views/frame/browser_frame_android.cc |
| diff --git a/chrome/browser/ui/views/frame/browser_frame_android.cc b/chrome/browser/ui/views/frame/browser_frame_android.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..337eab5981a0619f12e11bc3dec3edaae35812cc |
| --- /dev/null |
| +++ b/chrome/browser/ui/views/frame/browser_frame_android.cc |
| @@ -0,0 +1,76 @@ |
| +// Copyright 2013 The Chromium Authors. All rights reserved. |
|
no sievers
2015/10/28 20:04:51
nit: 2015
Hadi
2015/10/29 15:27:01
Done.
|
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +#include "chrome/browser/ui/views/frame/browser_frame_android.h" |
| + |
| +#include "chrome/browser/ui/browser_commands.h" |
| +#include "chrome/browser/ui/browser_finder.h" |
|
no sievers
2015/10/28 20:04:51
nit: some headers look unused
Hadi
2015/10/29 15:27:01
Done. Need to double-check when we are able compil
|
| +#include "chrome/browser/ui/views/frame/browser_shutdown.h" |
| +#include "chrome/browser/ui/views/frame/browser_view.h" |
| +#include "ui/aura/client/aura_constants.h" |
| +#include "ui/aura/window.h" |
| +#include "ui/aura/window_observer.h" |
| +#include "ui/aura/window_tree_host_android.h" |
| +#include "ui/views/view.h" |
| + |
| +// A stripped version of BrowserFrameAsh. May need to add things back later. |
| + |
| +/////////////////////////////////////////////////////////////////////////////// |
| +// BrowserFrameAndroid, public: |
| + |
| +// static |
| +const char BrowserFrameAndroid::kWindowName[] = "BrowserFrameAndroid"; |
| + |
| +BrowserFrameAndroid::BrowserFrameAndroid(BrowserFrame* browser_frame, |
| + BrowserView* browser_view) |
| + : views::NativeWidgetAura(browser_frame), browser_view_(browser_view) { |
| + GetNativeWindow()->SetName(kWindowName); |
| +} |
| + |
| +/////////////////////////////////////////////////////////////////////////////// |
| +// BrowserFrameAndroid, views::NativeWidgetAura overrides: |
| + |
| +void BrowserFrameAndroid::OnWindowDestroying(aura::Window* window) { |
| + // Destroy any remaining WebContents early on. Doing so may result in |
| + // calling back to one of the Views/LayoutManagers or supporting classes of |
| + // BrowserView. By destroying here we ensure all said classes are valid. |
| + DestroyBrowserWebContents(browser_view_->browser()); |
| + NativeWidgetAura::OnWindowDestroying(window); |
| +} |
| + |
| +void BrowserFrameAndroid::OnWindowTargetVisibilityChanged(bool visible) { |
| + views::NativeWidgetAura::OnWindowTargetVisibilityChanged(visible); |
| +} |
| + |
| +bool BrowserFrameAndroid::ShouldSaveWindowPlacement() const { |
| + return false; |
| +} |
| + |
| +void BrowserFrameAndroid::GetWindowPlacement( |
| + gfx::Rect* bounds, |
| + ui::WindowShowState* show_state) const {} |
| + |
| +//////////////////////////////////////////////////////////////////////////////// |
| +// BrowserFrameAndroid, NativeBrowserFrame implementation: |
| + |
| +views::Widget::InitParams BrowserFrameAndroid::GetWidgetParams() { |
| + views::Widget::InitParams params; |
| + params.native_widget = this; |
| + params.context = aura::WindowTreeHostPlatform::GetHost()->window(); |
| + return params; |
| +} |
| + |
| +bool BrowserFrameAndroid::UseCustomFrame() const { |
| + return true; |
| +} |
| + |
| +bool BrowserFrameAndroid::UsesNativeSystemMenu() const { |
| + return false; |
| +} |
| + |
| +int BrowserFrameAndroid::GetMinimizeButtonOffset() const { |
| + return 0; |
| +} |
| + |
| +BrowserFrameAndroid::~BrowserFrameAndroid() {} |