summaryrefslogtreecommitdiffstats
path: root/ui/views/widget
diff options
context:
space:
mode:
authorsky@chromium.org <sky@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2012-01-27 17:04:07 +0000
committersky@chromium.org <sky@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2012-01-27 17:04:07 +0000
commit3c627ff7833fbc8114c84f32fcd090e5dc04cc91 (patch)
tree031b7504c331d1bddfb8a03aa3db6c885a6e49e2 /ui/views/widget
parente056f5f20b3c53941adbaa045ddadafe8e47bf4e (diff)
downloadchromium_src-3c627ff7833fbc8114c84f32fcd090e5dc04cc91.zip
chromium_src-3c627ff7833fbc8114c84f32fcd090e5dc04cc91.tar.gz
chromium_src-3c627ff7833fbc8114c84f32fcd090e5dc04cc91.tar.bz2
Tweaks to show state:
. NativeWidgetAura now sets the true show state before added to a parent. This seems ideal so that the LayoutManager doesn't end up resizing the window. . I removed NativeWidgetAura's call to OnNativeWidgetSizeChanged. This shouldn't be necessary as when the Window's bounds change OnNativeWidgetSizeChanged ends up being invoked. . Browser::GetSavedWindowShowState can now return ui::SHOW_STATE_DEFAULT. I need this to tell the difference explicitly wanting NORMAL, and this is a new window so do whatever you want. I checked all callers and as far as I can tell they all deal with DEFAULT fine. BUG=111285 TEST=none R=ben@chromium.org Review URL: https://chromiumcodereview.appspot.com/9121036 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@119460 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'ui/views/widget')
-rw-r--r--ui/views/widget/native_widget_aura.cc25
-rw-r--r--ui/views/widget/native_widget_aura_unittest.cc79
2 files changed, 95 insertions, 9 deletions
diff --git a/ui/views/widget/native_widget_aura.cc b/ui/views/widget/native_widget_aura.cc
index 57026ea..a0220ad 100644
--- a/ui/views/widget/native_widget_aura.cc
+++ b/ui/views/widget/native_widget_aura.cc
@@ -89,6 +89,16 @@ void CloseAllSecondaryWidgetsCallback(Widget* widget) {
widget->Close();
}
+const gfx::Rect* GetRestoreBounds(aura::Window* window) {
+ return reinterpret_cast<gfx::Rect*>(
+ window->GetProperty(aura::client::kRestoreBoundsKey));
+}
+
+void SetRestoreBounds(aura::Window* window, const gfx::Rect& bounds) {
+ delete GetRestoreBounds(window);
+ window->SetProperty(aura::client::kRestoreBoundsKey, new gfx::Rect(bounds));
+}
+
} // namespace
// Used when SetInactiveRenderingDisabled() is invoked to track when active
@@ -162,8 +172,7 @@ void NativeWidgetAura::InitNativeWidget(const Widget::InitParams& params) {
ownership_ = params.ownership;
window_->set_user_data(this);
window_->SetType(GetAuraWindowTypeForWidgetType(params.type));
- // TODO(jamescook): Should this use params.show_state instead?
- window_->SetIntProperty(aura::client::kShowStateKey, ui::SHOW_STATE_NORMAL);
+ window_->SetIntProperty(aura::client::kShowStateKey, params.show_state);
window_->SetTransparent(params.transparent);
window_->Init(params.create_texture_for_layer ?
ui::Layer::LAYER_HAS_TEXTURE :
@@ -172,7 +181,6 @@ void NativeWidgetAura::InitNativeWidget(const Widget::InitParams& params) {
window_->Show();
delegate_->OnNativeWidgetCreated();
- window_->SetBounds(params.bounds);
if (params.child) {
window_->SetParent(params.GetParent());
} else {
@@ -187,9 +195,14 @@ void NativeWidgetAura::InitNativeWidget(const Widget::InitParams& params) {
SetAlwaysOnTop(params.keep_on_top);
window_->SetParent(parent);
}
+ // Wait to set the bounds until we have a parent. That way we can know our
+ // true state/bounds (the LayoutManager may enforce a particular
+ // state/bounds).
+ if (IsMaximized())
+ SetRestoreBounds(window_, params.bounds);
+ else
+ window_->SetBounds(params.bounds);
window_->set_ignore_events(!params.accept_events);
- // TODO(beng): do this some other way.
- delegate_->OnNativeWidgetSizeChanged(params.bounds.size());
can_activate_ = params.can_activate;
DCHECK(GetWidget()->GetRootView());
#if !defined(OS_MACOSX)
@@ -436,7 +449,7 @@ void NativeWidgetAura::Hide() {
void NativeWidgetAura::ShowMaximizedWithBounds(
const gfx::Rect& restored_bounds) {
- window_->SetBounds(restored_bounds);
+ SetRestoreBounds(window_, restored_bounds);
ShowWithWindowState(ui::SHOW_STATE_MAXIMIZED);
}
diff --git a/ui/views/widget/native_widget_aura_unittest.cc b/ui/views/widget/native_widget_aura_unittest.cc
index 3f1427b..91e02a3 100644
--- a/ui/views/widget/native_widget_aura_unittest.cc
+++ b/ui/views/widget/native_widget_aura_unittest.cc
@@ -1,16 +1,18 @@
-
// Copyright (c) 2012 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 "ui/views/widget/native_widget_aura.h"
-#include "ui/aura/root_window.h"
-#include "ui/aura/window.h"
#include "base/basictypes.h"
#include "base/memory/scoped_ptr.h"
#include "base/message_loop.h"
#include "testing/gtest/include/gtest/gtest.h"
+#include "ui/aura/layout_manager.h"
+#include "ui/aura/root_window.h"
+#include "ui/aura/window.h"
+#include "ui/views/widget/root_view.h"
+#include "ui/views/widget/widget_delegate.h"
namespace views {
namespace {
@@ -75,6 +77,77 @@ TEST_F(NativeWidgetAuraTest, CenterWindowSmallParent) {
widget->CloseNow();
}
+// Used by ShowMaximizedDoesntBounceAround. See it for details.
+class TestLayoutManager : public aura::LayoutManager {
+ public:
+ TestLayoutManager() {}
+
+ virtual void OnWindowResized() OVERRIDE {
+ }
+ virtual void OnWindowAddedToLayout(aura::Window* child) OVERRIDE {
+ // This simulates what happens when adding a maximized window.
+ SetChildBoundsDirect(child, gfx::Rect(0, 0, 300, 300));
+ }
+ virtual void OnWillRemoveWindowFromLayout(aura::Window* child) OVERRIDE {
+ }
+ virtual void OnChildWindowVisibilityChanged(aura::Window* child,
+ bool visible) OVERRIDE {
+ }
+ virtual void SetChildBounds(aura::Window* child,
+ const gfx::Rect& requested_bounds) OVERRIDE {
+ }
+
+ private:
+ DISALLOW_COPY_AND_ASSIGN(TestLayoutManager);
+};
+
+// This simulates BrowserView, which creates a custom RootView so that
+// OnNativeWidgetSizeChanged that is invoked during Init matters.
+class TestWidget : public views::Widget {
+ public:
+ TestWidget() : did_size_change_more_than_once_(false) {
+ }
+
+ // Returns true if the size changes to a non-empty size, and then to another
+ // size.
+ bool did_size_change_more_than_once() const {
+ return did_size_change_more_than_once_;
+ }
+
+ virtual void OnNativeWidgetSizeChanged(const gfx::Size& new_size) OVERRIDE {
+ if (last_size_.IsEmpty())
+ last_size_ = new_size;
+ else if (!did_size_change_more_than_once_ && new_size != last_size_)
+ did_size_change_more_than_once_ = true;
+ Widget::OnNativeWidgetSizeChanged(new_size);
+ }
+
+ private:
+ bool did_size_change_more_than_once_;
+ gfx::Size last_size_;
+
+ DISALLOW_COPY_AND_ASSIGN(TestWidget);
+};
+
+// Verifies the size of the widget doesn't change more than once during Init if
+// the window ends up maximized. This is important as otherwise
+// RenderWidgetHostViewAura ends up getting resized during construction, which
+// leads to noticable flashes.
+TEST_F(NativeWidgetAuraTest, ShowMaximizedDoesntBounceAround) {
+ aura::RootWindow::GetInstance()->SetBounds(gfx::Rect(0, 0, 640, 480));
+ aura::RootWindow::GetInstance()->SetLayoutManager(new TestLayoutManager);
+ scoped_ptr<TestWidget> widget(new TestWidget());
+ Widget::InitParams params(Widget::InitParams::TYPE_WINDOW);
+ params.ownership = views::Widget::InitParams::WIDGET_OWNS_NATIVE_WIDGET;
+ params.parent = NULL;
+ params.show_state = ui::SHOW_STATE_MAXIMIZED;
+ params.bounds = gfx::Rect(10, 10, 100, 200);
+ widget->Init(params);
+ aura::RootWindow::DeleteInstance();
+ EXPECT_FALSE(widget->did_size_change_more_than_once());
+ widget->CloseNow();
+}
+
TEST_F(NativeWidgetAuraTest, GetClientAreaScreenBounds) {
// Create a widget.
Widget::InitParams params(Widget::InitParams::TYPE_WINDOW);