Chromium Code Reviews| Index: chrome/browser/ui/views/frame/browser_frame_ash.cc |
| diff --git a/chrome/browser/ui/views/frame/browser_frame_ash.cc b/chrome/browser/ui/views/frame/browser_frame_ash.cc |
| index 3792d293cc46636a05112a376781e81b1e00bbce..965addaf7cc85dc7aff2a56d80817779d6e215f9 100644 |
| --- a/chrome/browser/ui/views/frame/browser_frame_ash.cc |
| +++ b/chrome/browser/ui/views/frame/browser_frame_ash.cc |
| @@ -7,73 +7,11 @@ |
| #include "ash/wm/window_state.h" |
| #include "ash/wm/window_util.h" |
| #include "chrome/browser/ui/views/frame/browser_view.h" |
| -#include "ui/aura/client/aura_constants.h" |
| +#include "chrome/browser/ui/views/frame/non_client_frame_view_switcher_ash.h" |
| #include "ui/aura/window.h" |
| -#include "ui/aura/window_observer.h" |
| #include "ui/gfx/font.h" |
| #include "ui/views/view.h" |
| -using aura::Window; |
| - |
| -//////////////////////////////////////////////////////////////////////////////// |
| -// BrowserFrameAsh::WindowPropertyWatcher |
| - |
| -class BrowserFrameAsh::WindowPropertyWatcher : public aura::WindowObserver { |
| - public: |
| - explicit WindowPropertyWatcher(BrowserFrameAsh* browser_frame_ash, |
| - BrowserFrame* browser_frame) |
| - : browser_frame_ash_(browser_frame_ash), |
| - browser_frame_(browser_frame) {} |
| - |
| - virtual void OnWindowPropertyChanged(aura::Window* window, |
| - const void* key, |
| - intptr_t old) OVERRIDE { |
| - if (key != aura::client::kShowStateKey) |
| - return; |
| - |
| - ui::WindowShowState old_state = static_cast<ui::WindowShowState>(old); |
| - ui::WindowShowState new_state = |
| - window->GetProperty(aura::client::kShowStateKey); |
| - |
| - // Allow the frame to be replaced when entering or exiting the maximized |
| - // state. |
| - if (browser_frame_->non_client_view() && |
| - browser_frame_ash_->browser_view()->browser()->is_app() && |
| - (old_state == ui::SHOW_STATE_MAXIMIZED || |
| - new_state == ui::SHOW_STATE_MAXIMIZED)) { |
| - // Defer frame layout when replacing the frame. Layout will occur when the |
| - // window's bounds are updated. The window maximize/restore animations |
| - // clone the window's layers and rely on the subsequent layout to set |
| - // the layer sizes. |
| - // If the window is minimized, the frame view needs to be updated via |
| - // an OnBoundsChanged event so that the frame will change its size |
| - // properly. |
| - browser_frame_->non_client_view()->UpdateFrame( |
| - old_state == ui::SHOW_STATE_MINIMIZED); |
| - } |
| - } |
| - |
| - virtual void OnWindowBoundsChanged(aura::Window* window, |
| - const gfx::Rect& old_bounds, |
| - const gfx::Rect& new_bounds) OVERRIDE { |
| - // Don't do anything if we don't have our non-client view yet. |
|
pkotwicz
2013/10/02 19:41:49
Removed this method because it is obsolete
|
| - if (!browser_frame_->non_client_view()) |
| - return; |
| - |
| - // If the window just moved to the top of the screen, or just moved away |
| - // from it, invoke Layout() so the header size can change. |
| - if ((old_bounds.y() == 0 && new_bounds.y() != 0) || |
| - (old_bounds.y() != 0 && new_bounds.y() == 0)) |
| - browser_frame_->non_client_view()->Layout(); |
| - } |
| - |
| - private: |
| - BrowserFrameAsh* browser_frame_ash_; |
| - BrowserFrame* browser_frame_; |
| - |
| - DISALLOW_COPY_AND_ASSIGN(WindowPropertyWatcher); |
| -}; |
| - |
| /////////////////////////////////////////////////////////////////////////////// |
| // BrowserFrameAsh, public: |
| @@ -83,10 +21,14 @@ const char BrowserFrameAsh::kWindowName[] = "BrowserFrameAsh"; |
| BrowserFrameAsh::BrowserFrameAsh(BrowserFrame* browser_frame, |
| BrowserView* browser_view) |
| : views::NativeWidgetAura(browser_frame), |
| - browser_view_(browser_view), |
| - window_property_watcher_(new WindowPropertyWatcher(this, browser_frame)) { |
| + browser_view_(browser_view) { |
| GetNativeWindow()->SetName(kWindowName); |
| - GetNativeWindow()->AddObserver(window_property_watcher_.get()); |
| + if (browser_view->browser()->is_app()) { |
| + // Apps switch to a special non client frame view when maximized. |
| + browser_frame_switcher_.reset(new NonClientFrameViewSwitcherAsh( |
| + browser_frame, GetNativeWindow())); |
| + } |
| + |
| if (browser_view->browser()->is_type_tabbed()) |
| ash::wm::SetAnimateToFullscreen(GetNativeWindow(), false); |
| @@ -98,14 +40,7 @@ BrowserFrameAsh::BrowserFrameAsh(BrowserFrame* browser_frame, |
| } |
| /////////////////////////////////////////////////////////////////////////////// |
| -// BrowserFrameAsh, views::NativeWidgetAura overrides: |
| - |
| -void BrowserFrameAsh::OnWindowDestroying() { |
| - // Window is destroyed before our destructor is called, so clean up our |
| - // observer here. |
| - GetNativeWindow()->RemoveObserver(window_property_watcher_.get()); |
| - views::NativeWidgetAura::OnWindowDestroying(); |
| -} |
| +// BrowserFrameAsh, views::NativeWidgetAura override: |
| void BrowserFrameAsh::OnWindowTargetVisibilityChanged(bool visible) { |
| if (visible) { |