summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorben@chromium.org <ben@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2011-03-14 23:53:45 +0000
committerben@chromium.org <ben@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2011-03-14 23:53:45 +0000
commit883ce2fa8fc0b8f8bf15fb4279ea2464a22cc052 (patch)
tree4eb19bb2c187ba53924b13a0e90d61c669a15c83
parente042db5288480d9ca61b155d8b8fa9ea42481554 (diff)
downloadchromium_src-883ce2fa8fc0b8f8bf15fb4279ea2464a22cc052.zip
chromium_src-883ce2fa8fc0b8f8bf15fb4279ea2464a22cc052.tar.gz
chromium_src-883ce2fa8fc0b8f8bf15fb4279ea2464a22cc052.tar.bz2
Reland 78062 with some NULL checks.
Revert 78062 - Migrate more of BrowserFrame's event handling down into WindowWin/WidgetWin and their delegate interfaces. BUG=72040 TEST=none Review URL: http://codereview.chromium.org/6683007 TBR=ben@chromium.org Review URL: http://codereview.chromium.org/6686059 Review URL: http://codereview.chromium.org/6677029 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@78129 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r--chrome/browser/chromeos/frame/browser_frame_chromeos.cc5
-rw-r--r--chrome/browser/chromeos/frame/panel_browser_view.cc4
-rw-r--r--chrome/browser/chromeos/frame/panel_browser_view.h2
-rw-r--r--chrome/browser/chromeos/login/user_controller.cc2
-rw-r--r--chrome/browser/chromeos/login/user_controller.h18
-rw-r--r--chrome/browser/ui/views/frame/browser_frame.cc36
-rw-r--r--chrome/browser/ui/views/frame/browser_frame.h23
-rw-r--r--chrome/browser/ui/views/frame/browser_frame_gtk.cc66
-rw-r--r--chrome/browser/ui/views/frame/browser_frame_gtk.h33
-rw-r--r--chrome/browser/ui/views/frame/browser_frame_win.cc71
-rw-r--r--chrome/browser/ui/views/frame/browser_frame_win.h28
-rw-r--r--chrome/browser/ui/views/frame/browser_view.cc48
-rw-r--r--chrome/browser/ui/views/frame/browser_view.h12
-rw-r--r--chrome/browser/ui/views/frame/native_browser_frame.h8
-rw-r--r--chrome/browser/ui/views/frame/native_browser_frame_delegate.h9
-rw-r--r--chrome/browser/ui/views/notifications/balloon_view.cc4
-rw-r--r--chrome/browser/ui/views/notifications/balloon_view.h4
-rw-r--r--views/widget/widget_delegate.h21
-rw-r--r--views/widget/widget_win.cc8
-rw-r--r--views/window/native_window.h6
-rw-r--r--views/window/native_window_delegate.h4
-rw-r--r--views/window/window.cc10
-rw-r--r--views/window/window.h2
-rw-r--r--views/window/window_delegate.h9
-rw-r--r--views/window/window_gtk.h4
-rw-r--r--views/window/window_win.cc48
-rw-r--r--views/window/window_win.h6
27 files changed, 249 insertions, 242 deletions
diff --git a/chrome/browser/chromeos/frame/browser_frame_chromeos.cc b/chrome/browser/chromeos/frame/browser_frame_chromeos.cc
index 2224068..f403694 100644
--- a/chrome/browser/chromeos/frame/browser_frame_chromeos.cc
+++ b/chrome/browser/chromeos/frame/browser_frame_chromeos.cc
@@ -29,11 +29,6 @@ BrowserFrameChromeos::~BrowserFrameChromeos() {
}
void BrowserFrameChromeos::InitBrowserFrame() {
- // NOTE: This logic supersedes the logic in BrowserFrameGtk::Init()
- // by always setting browser_frame_view_.
- set_browser_frame_view(
- browser::CreateBrowserNonClientFrameView(this, browser_view()));
-
BrowserFrameGtk::InitBrowserFrame();
if (!browser_view()->IsBrowserTypePopup()) {
diff --git a/chrome/browser/chromeos/frame/panel_browser_view.cc b/chrome/browser/chromeos/frame/panel_browser_view.cc
index 657039e..9a601f9 100644
--- a/chrome/browser/chromeos/frame/panel_browser_view.cc
+++ b/chrome/browser/chromeos/frame/panel_browser_view.cc
@@ -96,8 +96,8 @@ bool PanelBrowserView::GetSavedWindowBounds(gfx::Rect* bounds) const {
return res;
}
-void PanelBrowserView::OnWindowActivate(bool active) {
- ::BrowserView::OnWindowActivate(active);
+void PanelBrowserView::OnWindowActivationChanged(bool active) {
+ ::BrowserView::OnWindowActivationChanged(active);
if (panel_controller_.get()) {
if (active)
panel_controller_->OnFocusIn();
diff --git a/chrome/browser/chromeos/frame/panel_browser_view.h b/chrome/browser/chromeos/frame/panel_browser_view.h
index cb51c3e..eec101d 100644
--- a/chrome/browser/chromeos/frame/panel_browser_view.h
+++ b/chrome/browser/chromeos/frame/panel_browser_view.h
@@ -32,7 +32,7 @@ class PanelBrowserView : public ::BrowserView,
virtual void UpdateTitleBar();
virtual void SetCreatorView(PanelBrowserView* creator);
virtual bool GetSavedWindowBounds(gfx::Rect* bounds) const;
- virtual void OnWindowActivate(bool active);
+ virtual void OnWindowActivationChanged(bool active);
// PanelController::Delegate overrides
virtual string16 GetPanelTitle();
diff --git a/chrome/browser/chromeos/login/user_controller.cc b/chrome/browser/chromeos/login/user_controller.cc
index 97b68ed..a151502 100644
--- a/chrome/browser/chromeos/login/user_controller.cc
+++ b/chrome/browser/chromeos/login/user_controller.cc
@@ -268,7 +268,7 @@ void UserController::UpdateUserCount(int index, int total_user_count) {
////////////////////////////////////////////////////////////////////////////////
// UserController, WidgetDelegate implementation:
//
-void UserController::IsActiveChanged(bool active) {
+void UserController::OnWidgetActivated(bool active) {
is_user_selected_ = active;
if (active) {
delegate_->OnUserSelected(this);
diff --git a/chrome/browser/chromeos/login/user_controller.h b/chrome/browser/chromeos/login/user_controller.h
index bab0971..28250a1 100644
--- a/chrome/browser/chromeos/login/user_controller.h
+++ b/chrome/browser/chromeos/login/user_controller.h
@@ -103,22 +103,22 @@ class UserController : public views::WidgetDelegate,
void UpdateUserCount(int index, int total_user_count);
// views::WidgetDelegate implementation:
- virtual void IsActiveChanged(bool active);
+ virtual void OnWidgetActivated(bool active) OVERRIDE;
// NewUserView::Delegate implementation:
virtual void OnLogin(const std::string& username,
- const std::string& password);
- virtual void OnLoginAsGuest();
- virtual void OnCreateAccount();
- virtual void ClearErrors();
- virtual void NavigateAway();
+ const std::string& password) OVERRIDE;
+ virtual void OnLoginAsGuest() OVERRIDE;
+ virtual void OnCreateAccount() OVERRIDE;
+ virtual void ClearErrors() OVERRIDE;
+ virtual void NavigateAway() OVERRIDE;
// UserView::Delegate implementation:
- virtual void OnRemoveUser();
- virtual bool IsUserSelected() const { return is_user_selected_; }
+ virtual void OnRemoveUser() OVERRIDE;
+ virtual bool IsUserSelected() const OVERRIDE { return is_user_selected_; }
// UsernameView::Delegate implementation:
- virtual void OnLocaleChanged();
+ virtual void OnLocaleChanged() OVERRIDE;
// Padding between the user windows.
static const int kPadding;
diff --git a/chrome/browser/ui/views/frame/browser_frame.cc b/chrome/browser/ui/views/frame/browser_frame.cc
index 9bc3a02..94d0fa7 100644
--- a/chrome/browser/ui/views/frame/browser_frame.cc
+++ b/chrome/browser/ui/views/frame/browser_frame.cc
@@ -4,7 +4,12 @@
#include "chrome/browser/ui/views/frame/browser_frame.h"
+#include "chrome/browser/ui/views/frame/browser_non_client_frame_view.h"
+#include "chrome/browser/ui/views/frame/browser_root_view.h"
+#include "chrome/browser/ui/views/frame/browser_view.h"
#include "chrome/browser/ui/views/frame/native_browser_frame.h"
+#include "views/widget/native_widget.h"
+#include "views/widget/widget.h"
#include "views/window/native_window.h"
#include "views/window/window.h"
@@ -23,15 +28,15 @@ int BrowserFrame::GetMinimizeButtonOffset() const {
}
gfx::Rect BrowserFrame::GetBoundsForTabStrip(views::View* tabstrip) const {
- return native_browser_frame_->GetBoundsForTabStrip(tabstrip);
+ return browser_frame_view_->GetBoundsForTabStrip(tabstrip);
}
int BrowserFrame::GetHorizontalTabStripVerticalOffset(bool restored) const {
- return native_browser_frame_->GetHorizontalTabStripVerticalOffset(restored);
+ return browser_frame_view_->GetHorizontalTabStripVerticalOffset(restored);
}
void BrowserFrame::UpdateThrobber(bool running) {
- native_browser_frame_->UpdateThrobber(running);
+ browser_frame_view_->UpdateThrobber(running);
}
ui::ThemeProvider* BrowserFrame::GetThemeProviderForFrame() const {
@@ -43,7 +48,7 @@ bool BrowserFrame::AlwaysUseNativeFrame() const {
}
views::View* BrowserFrame::GetFrameView() const {
- return native_browser_frame_->GetFrameView();
+ return browser_frame_view_;
}
void BrowserFrame::TabStripDisplayModeChanged() {
@@ -51,7 +56,28 @@ void BrowserFrame::TabStripDisplayModeChanged() {
}
////////////////////////////////////////////////////////////////////////////////
+// BrowserFrame, NativeBrowserFrameDelegate implementation:
+
+views::RootView* BrowserFrame::DelegateCreateRootView() {
+ root_view_ = new BrowserRootView(
+ browser_view_,
+ native_browser_frame_->AsNativeWindow()->AsNativeWidget()->GetWidget());
+ return root_view_;
+}
+
+views::NonClientFrameView* BrowserFrame::DelegateCreateFrameViewForWindow() {
+ browser_frame_view_ =
+ native_browser_frame_->CreateBrowserNonClientFrameView();
+ return browser_frame_view_;
+}
+
+
+////////////////////////////////////////////////////////////////////////////////
// BrowserFrame, protected:
-BrowserFrame::BrowserFrame() : native_browser_frame_(NULL) {
+BrowserFrame::BrowserFrame(BrowserView* browser_view)
+ : native_browser_frame_(NULL),
+ root_view_(NULL),
+ browser_frame_view_(NULL),
+ browser_view_(browser_view) {
}
diff --git a/chrome/browser/ui/views/frame/browser_frame.h b/chrome/browser/ui/views/frame/browser_frame.h
index d58a16a..2a7ae13 100644
--- a/chrome/browser/ui/views/frame/browser_frame.h
+++ b/chrome/browser/ui/views/frame/browser_frame.h
@@ -6,12 +6,17 @@
#define CHROME_BROWSER_UI_VIEWS_FRAME_BROWSER_FRAME_H_
#pragma once
+#include "base/compiler_specific.h"
#include "base/logging.h"
#include "build/build_config.h"
#include "chrome/browser/ui/views/frame/native_browser_frame_delegate.h"
+class AeroGlassNonClientView;
+class BrowserNonClientFrameView;
+class BrowserRootView;
class BrowserView;
class NativeBrowserFrame;
+class NonClientFrameView;
class Profile;
namespace gfx {
@@ -75,17 +80,33 @@ class BrowserFrame : public NativeBrowserFrameDelegate {
void TabStripDisplayModeChanged();
protected:
+ // Overridden from NativeBrowserFrameDelegate:
+ virtual views::RootView* DelegateCreateRootView() OVERRIDE;
+ virtual views::NonClientFrameView* DelegateCreateFrameViewForWindow()
+ OVERRIDE;
+
// TODO(beng): Temporarily provided as a way to associate the subclass'
// implementation of NativeBrowserFrame with this.
void set_native_browser_frame(NativeBrowserFrame* native_browser_frame) {
native_browser_frame_ = native_browser_frame;
}
- BrowserFrame();
+ explicit BrowserFrame(BrowserView* browser_view);
private:
NativeBrowserFrame* native_browser_frame_;
+ // A weak reference to the root view associated with the window. We save a
+ // copy as a BrowserRootView to avoid evil casting later, when we need to call
+ // functions that only exist on BrowserRootView (versus RootView).
+ BrowserRootView* root_view_;
+
+ // A pointer to our NonClientFrameView as a BrowserNonClientFrameView.
+ BrowserNonClientFrameView* browser_frame_view_;
+
+ // The BrowserView is our ClientView. This is a pointer to it.
+ BrowserView* browser_view_;
+
DISALLOW_COPY_AND_ASSIGN(BrowserFrame);
};
diff --git a/chrome/browser/ui/views/frame/browser_frame_gtk.cc b/chrome/browser/ui/views/frame/browser_frame_gtk.cc
index 5c4d964..c56e0fc 100644
--- a/chrome/browser/ui/views/frame/browser_frame_gtk.cc
+++ b/chrome/browser/ui/views/frame/browser_frame_gtk.cc
@@ -33,41 +33,23 @@ const gfx::Font& BrowserFrame::GetTitleFont() {
}
BrowserFrameGtk::BrowserFrameGtk(BrowserView* browser_view, Profile* profile)
- : WindowGtk(browser_view),
- browser_view_(browser_view),
- browser_frame_view_(NULL),
- root_view_(NULL),
- profile_(profile) {
+ : BrowserFrame(browser_view),
+ WindowGtk(browser_view),
+ ALLOW_THIS_IN_INITIALIZER_LIST(delegate_(this)),
+ browser_view_(browser_view) {
set_native_browser_frame(this);
browser_view_->set_frame(this);
+ non_client_view()->SetFrameView(CreateFrameViewForWindow());
}
BrowserFrameGtk::~BrowserFrameGtk() {
}
void BrowserFrameGtk::InitBrowserFrame() {
- if (browser_frame_view_ == NULL)
- browser_frame_view_ =
- browser::CreateBrowserNonClientFrameView(this, browser_view_);
-
- non_client_view()->SetFrameView(browser_frame_view_);
WindowGtk::InitWindow(NULL, gfx::Rect());
// Don't focus anything on creation, selecting a tab will set the focus.
}
-ThemeProvider* BrowserFrameGtk::GetThemeProvider() const {
- return profile_->GetThemeProvider();
-}
-
-views::RootView* BrowserFrameGtk::CreateRootView() {
- root_view_ = new BrowserRootView(browser_view_, this);
- return root_view_;
-}
-
-void BrowserFrameGtk::SetInitialFocus() {
- browser_view_->RestoreFocus();
-}
-
////////////////////////////////////////////////////////////////////////////////
// BrowserFrameGtk, NativeBrowserFrame implementation:
@@ -79,23 +61,15 @@ const views::NativeWindow* BrowserFrameGtk::AsNativeWindow() const {
return this;
}
+BrowserNonClientFrameView* BrowserFrameGtk::CreateBrowserNonClientFrameView() {
+ return browser::CreateBrowserNonClientFrameView(this, browser_view_);
+}
+
int BrowserFrameGtk::GetMinimizeButtonOffset() const {
NOTIMPLEMENTED();
return 0;
}
-gfx::Rect BrowserFrameGtk::GetBoundsForTabStrip(views::View* tabstrip) const {
- return browser_frame_view_->GetBoundsForTabStrip(tabstrip);
-}
-
-int BrowserFrameGtk::GetHorizontalTabStripVerticalOffset(bool restored) const {
- return browser_frame_view_->GetHorizontalTabStripVerticalOffset(restored);
-}
-
-void BrowserFrameGtk::UpdateThrobber(bool running) {
- browser_frame_view_->UpdateThrobber(running);
-}
-
ThemeProvider* BrowserFrameGtk::GetThemeProviderForFrame() const {
// This is implemented for a different interface than GetThemeProvider is,
// but they mean the same things.
@@ -106,10 +80,6 @@ bool BrowserFrameGtk::AlwaysUseNativeFrame() const {
return false;
}
-views::View* BrowserFrameGtk::GetFrameView() const {
- return browser_frame_view_;
-}
-
void BrowserFrameGtk::TabStripDisplayModeChanged() {
if (GetRootView()->has_children()) {
// Make sure the child of the root view gets Layout again.
@@ -119,13 +89,29 @@ void BrowserFrameGtk::TabStripDisplayModeChanged() {
}
////////////////////////////////////////////////////////////////////////////////
-// BrowserFrameGtk, private:
+// BrowserFrameGtk, WindowGtk overrides :
+
+ThemeProvider* BrowserFrameGtk::GetThemeProvider() const {
+ return browser_view_->browser()->profile()->GetThemeProvider();
+}
+
+void BrowserFrameGtk::SetInitialFocus() {
+ browser_view_->RestoreFocus();
+}
+
+views::RootView* BrowserFrameGtk::CreateRootView() {
+ return delegate_->DelegateCreateRootView();
+}
bool BrowserFrameGtk::GetAccelerator(int cmd_id,
ui::Accelerator* accelerator) {
return browser_view_->GetAccelerator(cmd_id, accelerator);
}
+views::NonClientFrameView* BrowserFrameGtk::CreateFrameViewForWindow() {
+ return delegate_->DelegateCreateFrameViewForWindow();
+}
+
gboolean BrowserFrameGtk::OnWindowStateEvent(GtkWidget* widget,
GdkEventWindowState* event) {
bool was_full_screen = IsFullscreen();
diff --git a/chrome/browser/ui/views/frame/browser_frame_gtk.h b/chrome/browser/ui/views/frame/browser_frame_gtk.h
index 78c8400..14536a1 100644
--- a/chrome/browser/ui/views/frame/browser_frame_gtk.h
+++ b/chrome/browser/ui/views/frame/browser_frame_gtk.h
@@ -29,56 +29,37 @@ class BrowserFrameGtk : public BrowserFrame,
// constructor.
virtual void InitBrowserFrame();
- // Overridden from views::Widget:
- virtual ui::ThemeProvider* GetThemeProvider() const OVERRIDE;
- virtual void SetInitialFocus() OVERRIDE;
-
protected:
// Overridden from NativeBrowserFrame:
virtual views::NativeWindow* AsNativeWindow() OVERRIDE;
virtual const views::NativeWindow* AsNativeWindow() const OVERRIDE;
+ virtual BrowserNonClientFrameView* CreateBrowserNonClientFrameView() OVERRIDE;
virtual int GetMinimizeButtonOffset() const OVERRIDE;
- virtual gfx::Rect GetBoundsForTabStrip(views::View* tabstrip) const OVERRIDE;
- virtual int GetHorizontalTabStripVerticalOffset(bool restored) const OVERRIDE;
- virtual void UpdateThrobber(bool running) OVERRIDE;
virtual ui::ThemeProvider* GetThemeProviderForFrame() const OVERRIDE;
virtual bool AlwaysUseNativeFrame() const OVERRIDE;
- virtual views::View* GetFrameView() const OVERRIDE;
virtual void TabStripDisplayModeChanged() OVERRIDE;
- void set_browser_frame_view(BrowserNonClientFrameView* browser_frame_view) {
- browser_frame_view_ = browser_frame_view;
- }
-
- // Overridden from views::WidgetGtk:
+ // Overridden from views::WindowGtk:
+ virtual ui::ThemeProvider* GetThemeProvider() const OVERRIDE;
+ virtual void SetInitialFocus() OVERRIDE;
virtual views::RootView* CreateRootView();
virtual bool GetAccelerator(int cmd_id, ui::Accelerator* accelerator);
-
- // Overriden from views::WindowGtk:
+ virtual views::NonClientFrameView* CreateFrameViewForWindow() OVERRIDE;
virtual gboolean OnWindowStateEvent(GtkWidget* widget,
GdkEventWindowState* event);
virtual gboolean OnConfigureEvent(GtkWidget* widget,
GdkEventConfigure* event);
- protected:
BrowserView* browser_view() const {
return browser_view_;
}
private:
+ NativeBrowserFrameDelegate* delegate_;
+
// The BrowserView is our ClientView. This is a pointer to it.
BrowserView* browser_view_;
- // A pointer to our NonClientFrameView as a BrowserNonClientFrameView.
- BrowserNonClientFrameView* browser_frame_view_;
-
- // An unowning reference to the root view associated with the window. We save
- // a copy as a BrowserRootView to avoid evil casting later, when we need to
- // call functions that only exist on BrowserRootView (versus RootView).
- BrowserRootView* root_view_;
-
- Profile* profile_;
-
DISALLOW_COPY_AND_ASSIGN(BrowserFrameGtk);
};
diff --git a/chrome/browser/ui/views/frame/browser_frame_win.cc b/chrome/browser/ui/views/frame/browser_frame_win.cc
index e646969..831a9c3 100644
--- a/chrome/browser/ui/views/frame/browser_frame_win.cc
+++ b/chrome/browser/ui/views/frame/browser_frame_win.cc
@@ -14,14 +14,13 @@
#include "chrome/browser/browser_list.h"
#include "chrome/browser/themes/browser_theme_provider.h"
#include "chrome/browser/ui/views/frame/browser_non_client_frame_view.h"
-#include "chrome/browser/ui/views/frame/browser_root_view.h"
#include "chrome/browser/ui/views/frame/browser_view.h"
#include "chrome/browser/ui/views/frame/glass_browser_frame_view.h"
#include "grit/theme_resources.h"
#include "ui/gfx/font.h"
#include "views/screen.h"
+#include "views/widget/root_view.h"
#include "views/widget/widget_win.h"
-#include "views/window/window_delegate.h"
#include "views/window/window_win.h"
// static
@@ -46,8 +45,8 @@ BrowserFrame* BrowserFrame::Create(BrowserView* browser_view,
BrowserFrameWin::BrowserFrameWin(BrowserView* browser_view, Profile* profile)
: WindowWin(browser_view),
+ BrowserFrame(browser_view),
browser_view_(browser_view),
- root_view_(NULL),
ALLOW_THIS_IN_INITIALIZER_LIST(delegate_(this)) {
set_native_browser_frame(this);
browser_view_->set_frame(this);
@@ -109,39 +108,11 @@ void BrowserFrameWin::OnEndSession(BOOL ending, UINT logoff) {
BrowserList::SessionEnding();
}
-void BrowserFrameWin::OnEnterSizeMove() {
- browser_view_->WindowMoveOrResizeStarted();
-}
-
-void BrowserFrameWin::OnExitSizeMove() {
- views::WidgetWin::OnExitSizeMove();
-}
-
void BrowserFrameWin::OnInitMenuPopup(HMENU menu, UINT position,
BOOL is_system_menu) {
browser_view_->PrepareToRunSystemMenu(menu);
}
-void BrowserFrameWin::OnMove(const CPoint& point) {
- browser_view_->WindowMoved();
-}
-
-void BrowserFrameWin::OnMoving(UINT param, LPRECT new_bounds) {
- browser_view_->WindowMoved();
-}
-
-LRESULT BrowserFrameWin::OnNCHitTest(const CPoint& pt) {
- // Only do DWM hit-testing when we are using the native frame.
- if (non_client_view()->UseNativeFrame()) {
- LRESULT result;
- if (DwmDefWindowProc(GetNativeView(), WM_NCHITTEST, 0,
- MAKELPARAM(pt.x, pt.y), &result)) {
- return result;
- }
- }
- return WindowWin::OnNCHitTest(pt);
-}
-
void BrowserFrameWin::OnWindowPosChanged(WINDOWPOS* window_pos) {
WindowWin::OnWindowPosChanged(window_pos);
UpdateDWMFrame();
@@ -185,15 +156,6 @@ void BrowserFrameWin::Activate() {
WindowWin::Activate();
}
-views::NonClientFrameView* BrowserFrameWin::CreateFrameViewForWindow() {
- if (AlwaysUseNativeFrame())
- browser_frame_view_ = new GlassBrowserFrameView(this, browser_view_);
- else
- browser_frame_view_ =
- browser::CreateBrowserNonClientFrameView(this, browser_view_);
- return browser_frame_view_;
-}
-
void BrowserFrameWin::UpdateFrameAfterFrameChange() {
// We need to update the glass region on or off before the base class adjusts
// the window region.
@@ -202,8 +164,11 @@ void BrowserFrameWin::UpdateFrameAfterFrameChange() {
}
views::RootView* BrowserFrameWin::CreateRootView() {
- root_view_ = new BrowserRootView(browser_view_, this);
- return root_view_;
+ return delegate_->DelegateCreateRootView();
+}
+
+views::NonClientFrameView* BrowserFrameWin::CreateFrameViewForWindow() {
+ return delegate_->DelegateCreateFrameViewForWindow();
}
////////////////////////////////////////////////////////////////////////////////
@@ -217,6 +182,12 @@ const views::NativeWindow* BrowserFrameWin::AsNativeWindow() const {
return this;
}
+BrowserNonClientFrameView* BrowserFrameWin::CreateBrowserNonClientFrameView() {
+ if (AlwaysUseNativeFrame())
+ return new GlassBrowserFrameView(this, browser_view_);
+ return browser::CreateBrowserNonClientFrameView(this, browser_view_);
+}
+
int BrowserFrameWin::GetMinimizeButtonOffset() const {
TITLEBARINFOEX titlebar_info;
titlebar_info.cbSize = sizeof(TITLEBARINFOEX);
@@ -229,18 +200,6 @@ int BrowserFrameWin::GetMinimizeButtonOffset() const {
return minimize_button_corner.x;
}
-gfx::Rect BrowserFrameWin::GetBoundsForTabStrip(views::View* tabstrip) const {
- return browser_frame_view_->GetBoundsForTabStrip(tabstrip);
-}
-
-int BrowserFrameWin::GetHorizontalTabStripVerticalOffset(bool restored) const {
- return browser_frame_view_->GetHorizontalTabStripVerticalOffset(restored);
-}
-
-void BrowserFrameWin::UpdateThrobber(bool running) {
- browser_frame_view_->UpdateThrobber(running);
-}
-
ui::ThemeProvider* BrowserFrameWin::GetThemeProviderForFrame() const {
// This is implemented for a different interface than GetThemeProvider is,
// but they mean the same things.
@@ -264,10 +223,6 @@ bool BrowserFrameWin::AlwaysUseNativeFrame() const {
return GetThemeProvider()->ShouldUseNativeFrame();
}
-views::View* BrowserFrameWin::GetFrameView() const {
- return browser_frame_view_;
-}
-
void BrowserFrameWin::TabStripDisplayModeChanged() {
if (GetRootView()->has_children()) {
// Make sure the child of the root view gets Layout again.
diff --git a/chrome/browser/ui/views/frame/browser_frame_win.h b/chrome/browser/ui/views/frame/browser_frame_win.h
index dbbd55a..4a3aa34 100644
--- a/chrome/browser/ui/views/frame/browser_frame_win.h
+++ b/chrome/browser/ui/views/frame/browser_frame_win.h
@@ -11,11 +11,7 @@
#include "chrome/browser/ui/views/frame/native_browser_frame.h"
#include "views/window/window_win.h"
-class AeroGlassNonClientView;
-class BrowserNonClientFrameView;
-class BrowserRootView;
class BrowserView;
-class NonClientFrameView;
class Profile;
///////////////////////////////////////////////////////////////////////////////
@@ -51,14 +47,9 @@ class BrowserFrameWin : public BrowserFrame,
virtual bool GetAccelerator(int cmd_id,
ui::Accelerator* accelerator) OVERRIDE;
virtual void OnEndSession(BOOL ending, UINT logoff) OVERRIDE;
- virtual void OnEnterSizeMove() OVERRIDE;
- virtual void OnExitSizeMove() OVERRIDE;
virtual void OnInitMenuPopup(HMENU menu,
UINT position,
BOOL is_system_menu) OVERRIDE;
- virtual void OnMove(const CPoint& point) OVERRIDE;
- virtual void OnMoving(UINT param, LPRECT new_bounds) OVERRIDE;
- virtual LRESULT OnNCHitTest(const CPoint& pt) OVERRIDE;
virtual void OnWindowPosChanged(WINDOWPOS* window_pos) OVERRIDE;
virtual ui::ThemeProvider* GetThemeProvider() const OVERRIDE;
virtual void OnScreenReaderDetected() OVERRIDE;
@@ -66,39 +57,28 @@ class BrowserFrameWin : public BrowserFrame,
// Overridden from views::Window:
virtual void Activate() OVERRIDE;
virtual bool IsAppWindow() const OVERRIDE { return true; }
- virtual views::NonClientFrameView* CreateFrameViewForWindow() OVERRIDE;
virtual void UpdateFrameAfterFrameChange() OVERRIDE;
virtual views::RootView* CreateRootView() OVERRIDE;
+ virtual views::NonClientFrameView* CreateFrameViewForWindow() OVERRIDE;
// Overridden from NativeBrowserFrame:
virtual views::NativeWindow* AsNativeWindow() OVERRIDE;
virtual const views::NativeWindow* AsNativeWindow() const OVERRIDE;
+ virtual BrowserNonClientFrameView* CreateBrowserNonClientFrameView() OVERRIDE;
virtual int GetMinimizeButtonOffset() const OVERRIDE;
- virtual gfx::Rect GetBoundsForTabStrip(views::View* tabstrip) const OVERRIDE;
- virtual int GetHorizontalTabStripVerticalOffset(bool restored) const OVERRIDE;
- virtual void UpdateThrobber(bool running) OVERRIDE;
virtual ui::ThemeProvider* GetThemeProviderForFrame() const OVERRIDE;
virtual bool AlwaysUseNativeFrame() const OVERRIDE;
- virtual views::View* GetFrameView() const OVERRIDE;
virtual void TabStripDisplayModeChanged() OVERRIDE;
private:
// Updates the DWM with the frame bounds.
void UpdateDWMFrame();
+ NativeBrowserFrameDelegate* delegate_;
+
// The BrowserView is our ClientView. This is a pointer to it.
BrowserView* browser_view_;
- // A pointer to our NonClientFrameView as a BrowserNonClientFrameView.
- BrowserNonClientFrameView* browser_frame_view_;
-
- // A weak reference to the root view associated with the window. We save a
- // copy as a BrowserRootView to avoid evil casting later, when we need to call
- // functions that only exist on BrowserRootView (versus RootView).
- BrowserRootView* root_view_;
-
- NativeBrowserFrameDelegate* delegate_;
-
DISALLOW_COPY_AND_ASSIGN(BrowserFrameWin);
};
diff --git a/chrome/browser/ui/views/frame/browser_view.cc b/chrome/browser/ui/views/frame/browser_view.cc
index ec2bf14..ad83930 100644
--- a/chrome/browser/ui/views/frame/browser_view.cc
+++ b/chrome/browser/ui/views/frame/browser_view.cc
@@ -500,29 +500,6 @@ BrowserView* BrowserView::GetBrowserViewForNativeWindow(
return NULL;
}
-void BrowserView::WindowMoved() {
- // Cancel any tabstrip animations, some of them may be invalidated by the
- // window being repositioned.
- // Comment out for one cycle to see if this fixes dist tests.
- // tabstrip_->DestroyDragController();
-
- status_bubble_->Reposition();
-
- BrowserBubbleHost::WindowMoved();
-
- browser::HideBookmarkBubbleView();
-
- // Close the omnibox popup, if any.
- if (toolbar_->location_bar())
- toolbar_->location_bar()->location_entry()->ClosePopup();
-}
-
-void BrowserView::WindowMoveOrResizeStarted() {
- TabContents* tab_contents = GetSelectedTabContents();
- if (tab_contents)
- tab_contents->WindowMoveOrResizeStarted();
-}
-
gfx::Rect BrowserView::GetToolbarBounds() const {
gfx::Rect toolbar_bounds(toolbar_->bounds());
if (toolbar_bounds.IsEmpty())
@@ -1650,11 +1627,34 @@ views::ClientView* BrowserView::CreateClientView(views::Window* window) {
return this;
}
-void BrowserView::OnWindowActivate(bool active) {
+void BrowserView::OnWindowActivationChanged(bool active) {
if (active)
BrowserList::SetLastActive(browser_.get());
}
+void BrowserView::OnWindowBeginUserBoundsChange() {
+ TabContents* tab_contents = GetSelectedTabContents();
+ if (tab_contents)
+ tab_contents->WindowMoveOrResizeStarted();
+}
+
+void BrowserView::OnWidgetMove() {
+ // Cancel any tabstrip animations, some of them may be invalidated by the
+ // window being repositioned.
+ // Comment out for one cycle to see if this fixes dist tests.
+ // tabstrip_->DestroyDragController();
+
+ status_bubble_->Reposition();
+
+ BrowserBubbleHost::WindowMoved();
+
+ browser::HideBookmarkBubbleView();
+
+ // Close the omnibox popup, if any.
+ if (toolbar_->location_bar())
+ toolbar_->location_bar()->location_entry()->ClosePopup();
+}
+
///////////////////////////////////////////////////////////////////////////////
// BrowserView, views::ClientView overrides:
diff --git a/chrome/browser/ui/views/frame/browser_view.h b/chrome/browser/ui/views/frame/browser_view.h
index 4ede546..b84dbc9 100644
--- a/chrome/browser/ui/views/frame/browser_view.h
+++ b/chrome/browser/ui/views/frame/browser_view.h
@@ -102,14 +102,6 @@ class BrowserView : public BrowserBubbleHost,
// Returns a Browser instance of this view.
Browser* browser() const { return browser_.get(); }
- // Called by the frame to notify the BrowserView that it was moved, and that
- // any dependent popup windows should be repositioned.
- void WindowMoved();
-
- // Called by the frame to notify the BrowserView that a move or resize was
- // initiated.
- void WindowMoveOrResizeStarted();
-
// Returns the apparent bounds of the toolbar, in BrowserView coordinates.
// These differ from |toolbar_.bounds()| in that they match where the toolbar
// background image is drawn -- slightly outside the "true" bounds
@@ -372,7 +364,9 @@ class BrowserView : public BrowserBubbleHost,
virtual bool GetSavedMaximizedState(bool* maximized) const OVERRIDE;
virtual views::View* GetContentsView() OVERRIDE;
virtual views::ClientView* CreateClientView(views::Window* window) OVERRIDE;
- virtual void OnWindowActivate(bool active) OVERRIDE;
+ virtual void OnWindowActivationChanged(bool active) OVERRIDE;
+ virtual void OnWindowBeginUserBoundsChange() OVERRIDE;
+ virtual void OnWidgetMove() OVERRIDE;
// Overridden from views::ClientView:
virtual bool CanClose() OVERRIDE;
diff --git a/chrome/browser/ui/views/frame/native_browser_frame.h b/chrome/browser/ui/views/frame/native_browser_frame.h
index 1759e55..f72ec29 100644
--- a/chrome/browser/ui/views/frame/native_browser_frame.h
+++ b/chrome/browser/ui/views/frame/native_browser_frame.h
@@ -6,6 +6,8 @@
#define CHROME_BROWSER_UI_VIEWS_FRAME_NATIVE_BROWSER_FRAME_H_
#pragma once
+class BrowserNonClientFrameView;
+
namespace gfx {
class Rect;
}
@@ -29,15 +31,13 @@ class NativeBrowserFrame {
protected:
friend class BrowserFrame;
+ virtual BrowserNonClientFrameView* CreateBrowserNonClientFrameView() = 0;
+
// BrowserFrame pass-thrus ---------------------------------------------------
// See browser_frame.h for documentation:
virtual int GetMinimizeButtonOffset() const = 0;
- virtual gfx::Rect GetBoundsForTabStrip(views::View* tabstrip) const = 0;
- virtual int GetHorizontalTabStripVerticalOffset(bool restored) const = 0;
- virtual void UpdateThrobber(bool running) = 0;
virtual ui::ThemeProvider* GetThemeProviderForFrame() const = 0;
virtual bool AlwaysUseNativeFrame() const = 0;
- virtual views::View* GetFrameView() const = 0;
virtual void TabStripDisplayModeChanged() = 0;
};
diff --git a/chrome/browser/ui/views/frame/native_browser_frame_delegate.h b/chrome/browser/ui/views/frame/native_browser_frame_delegate.h
index 10c32dd..cacd34a 100644
--- a/chrome/browser/ui/views/frame/native_browser_frame_delegate.h
+++ b/chrome/browser/ui/views/frame/native_browser_frame_delegate.h
@@ -6,10 +6,19 @@
#define CHROME_BROWSER_UI_VIEWS_FRAME_NATIVE_BROWSER_FRAME_DELEGATE_H_
#pragma once
+namespace views {
+class NonClientFrameView;
+class RootView;
+}
+
class NativeBrowserFrameDelegate {
public:
virtual ~NativeBrowserFrameDelegate() {}
+ // TODO(beng): Remove these once BrowserFrame is-a Window is-a Widget, at
+ // which point BrowserFrame can just override Widget's method.
+ virtual views::RootView* DelegateCreateRootView() = 0;
+ virtual views::NonClientFrameView* DelegateCreateFrameViewForWindow() = 0;
};
#endif // CHROME_BROWSER_UI_VIEWS_FRAME_NATIVE_BROWSER_FRAME_DELEGATE_H_
diff --git a/chrome/browser/ui/views/notifications/balloon_view.cc b/chrome/browser/ui/views/notifications/balloon_view.cc
index 3fdb610..26bee52 100644
--- a/chrome/browser/ui/views/notifications/balloon_view.cc
+++ b/chrome/browser/ui/views/notifications/balloon_view.cc
@@ -139,11 +139,11 @@ void BalloonViewImpl::RunMenu(views::View* source, const gfx::Point& pt) {
RunOptionsMenu(pt);
}
-void BalloonViewImpl::DisplayChanged() {
+void BalloonViewImpl::OnDisplayChanged() {
collection_->DisplayChanged();
}
-void BalloonViewImpl::WorkAreaChanged() {
+void BalloonViewImpl::OnWorkAreaChanged() {
collection_->DisplayChanged();
}
diff --git a/chrome/browser/ui/views/notifications/balloon_view.h b/chrome/browser/ui/views/notifications/balloon_view.h
index a956d6a..46e866e 100644
--- a/chrome/browser/ui/views/notifications/balloon_view.h
+++ b/chrome/browser/ui/views/notifications/balloon_view.h
@@ -74,8 +74,8 @@ class BalloonViewImpl : public BalloonView,
virtual void RunMenu(views::View* source, const gfx::Point& pt) OVERRIDE;
// views::WidgetDelegate interface.
- virtual void DisplayChanged() OVERRIDE;
- virtual void WorkAreaChanged() OVERRIDE;
+ virtual void OnDisplayChanged() OVERRIDE;
+ virtual void OnWorkAreaChanged() OVERRIDE;
// views::ButtonListener interface.
virtual void ButtonPressed(
diff --git a/views/widget/widget_delegate.h b/views/widget/widget_delegate.h
index 71ea6ee..b37c391 100644
--- a/views/widget/widget_delegate.h
+++ b/views/widget/widget_delegate.h
@@ -1,4 +1,4 @@
-// Copyright (c) 2006-2010 The Chromium Authors. All rights reserved.
+// Copyright (c) 2011 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.
@@ -14,15 +14,20 @@ class WidgetDelegate {
public:
virtual ~WidgetDelegate() {}
- // Called with the display changes (color depth or resolution).
- virtual void DisplayChanged() {}
+ // Called whenever the widget is activated or deactivated.
+ // TODO(beng): This should be consolidated with
+ // WindowDelegate::OnWindowActivationChanged().
+ virtual void OnWidgetActivated(bool active) {}
+
+ // Called whenever the widget's position changes.
+ virtual void OnWidgetMove() {}
- // Called when widget active state has changed.
- virtual void IsActiveChanged(bool active) {}
+ // Called with the display changes (color depth or resolution).
+ virtual void OnDisplayChanged() {}
- // Called when the work area (the desktop area minus taskbars,
- // menubars, etc.) changes in size.
- virtual void WorkAreaChanged() {}
+ // Called when the work area (the desktop area minus task bars,
+ // menu bars, etc.) changes in size.
+ virtual void OnWorkAreaChanged() {}
};
} // namespace views
diff --git a/views/widget/widget_win.cc b/views/widget/widget_win.cc
index badb66f..657ece9 100644
--- a/views/widget/widget_win.cc
+++ b/views/widget/widget_win.cc
@@ -564,7 +564,7 @@ void WidgetWin::OnDestroy() {
void WidgetWin::OnDisplayChange(UINT bits_per_pixel, CSize screen_size) {
if (widget_delegate())
- widget_delegate()->DisplayChanged();
+ widget_delegate()->OnDisplayChanged();
}
LRESULT WidgetWin::OnDwmCompositionChanged(UINT msg,
@@ -723,10 +723,14 @@ LRESULT WidgetWin::OnMouseWheel(UINT message, WPARAM w_param, LPARAM l_param) {
}
void WidgetWin::OnMove(const CPoint& point) {
+ if (widget_delegate())
+ widget_delegate()->OnWidgetMove();
SetMsgHandled(FALSE);
}
void WidgetWin::OnMoving(UINT param, const LPRECT new_bounds) {
+ if (widget_delegate())
+ widget_delegate()->OnWidgetMove();
}
LRESULT WidgetWin::OnNCActivate(BOOL active) {
@@ -851,7 +855,7 @@ LRESULT WidgetWin::OnSetText(const wchar_t* text) {
void WidgetWin::OnSettingChange(UINT flags, const wchar_t* section) {
if (flags == SPI_SETWORKAREA && widget_delegate())
- widget_delegate()->WorkAreaChanged();
+ widget_delegate()->OnWorkAreaChanged();
SetMsgHandled(FALSE);
}
diff --git a/views/window/native_window.h b/views/window/native_window.h
index 7e4bd6a..a2fb965 100644
--- a/views/window/native_window.h
+++ b/views/window/native_window.h
@@ -37,6 +37,9 @@ class NativeWindow {
virtual Window* GetWindow() = 0;
+ virtual NativeWidget* AsNativeWidget() = 0;
+ virtual const NativeWidget* AsNativeWidget() const = 0;
+
protected:
friend class Window;
@@ -75,9 +78,6 @@ class NativeWindow {
virtual void SetAccessibleRole(ui::AccessibilityTypes::Role role) = 0;
virtual void SetAccessibleState(ui::AccessibilityTypes::State state) = 0;
- virtual NativeWidget* AsNativeWidget() = 0;
- virtual const NativeWidget* AsNativeWidget() const = 0;
-
// Window pass-thrus ---------------------------------------------------------
// See documentation in window.h
diff --git a/views/window/native_window_delegate.h b/views/window/native_window_delegate.h
index 3807cfa..23705a5 100644
--- a/views/window/native_window_delegate.h
+++ b/views/window/native_window_delegate.h
@@ -51,6 +51,10 @@ class NativeWindowDelegate {
// Called when the activation state of a window has changed.
virtual void OnNativeWindowActivationChanged(bool active) = 0;
+ // Called when the user begins/ends to change the bounds of the window.
+ virtual void OnNativeWindowBeginUserBoundsChange() = 0;
+ virtual void OnNativeWindowEndUserBoundsChange() = 0;
+
// Called just before the native window is destroyed. This is the delegate's
// last chance to do anything with the native window handle.
virtual void OnNativeWindowDestroying() = 0;
diff --git a/views/window/window.cc b/views/window/window.cc
index 71f8cd8..ba7d055 100644
--- a/views/window/window.cc
+++ b/views/window/window.cc
@@ -298,7 +298,15 @@ void Window::OnNativeWindowCreated(const gfx::Rect& bounds) {
void Window::OnNativeWindowActivationChanged(bool active) {
if (!active)
SaveWindowPosition();
- window_delegate_->OnWindowActivate(active);
+ window_delegate_->OnWindowActivationChanged(active);
+}
+
+void Window::OnNativeWindowBeginUserBoundsChange() {
+ window_delegate_->OnWindowBeginUserBoundsChange();
+}
+
+void Window::OnNativeWindowEndUserBoundsChange() {
+ window_delegate_->OnWindowEndUserBoundsChange();
}
void Window::OnNativeWindowDestroying() {
diff --git a/views/window/window.h b/views/window/window.h
index fc9f3a5..f18f4bb 100644
--- a/views/window/window.h
+++ b/views/window/window.h
@@ -213,6 +213,8 @@ class Window : public internal::NativeWindowDelegate {
virtual bool ExecuteCommand(int command_id) OVERRIDE;
virtual void OnNativeWindowCreated(const gfx::Rect& bounds) OVERRIDE;
virtual void OnNativeWindowActivationChanged(bool active) OVERRIDE;
+ virtual void OnNativeWindowBeginUserBoundsChange() OVERRIDE;
+ virtual void OnNativeWindowEndUserBoundsChange() OVERRIDE;
virtual void OnNativeWindowDestroying() OVERRIDE;
virtual void OnNativeWindowDestroyed() OVERRIDE;
virtual void OnNativeWindowBoundsChanged() OVERRIDE;
diff --git a/views/window/window_delegate.h b/views/window/window_delegate.h
index 379276c..d1a350a 100644
--- a/views/window/window_delegate.h
+++ b/views/window/window_delegate.h
@@ -10,6 +10,7 @@
#include "base/scoped_ptr.h"
#include "ui/base/accessibility/accessibility_types.h"
+#include "views/widget/widget_delegate.h"
class SkBitmap;
@@ -33,7 +34,7 @@ class Window;
// it should be displayed and notify the delegate object of certain events.
//
///////////////////////////////////////////////////////////////////////////////
-class WindowDelegate {
+class WindowDelegate : public WidgetDelegate {
public:
WindowDelegate();
virtual ~WindowDelegate();
@@ -117,7 +118,11 @@ class WindowDelegate {
virtual void DeleteDelegate() {}
// Called when the window's activation state changes.
- virtual void OnWindowActivate(bool active) {}
+ virtual void OnWindowActivationChanged(bool active) {}
+
+ // Called when the user begins/ends to change the bounds of the window.
+ virtual void OnWindowBeginUserBoundsChange() {}
+ virtual void OnWindowEndUserBoundsChange() {}
// Returns the View that is contained within this Window.
virtual View* GetContentsView();
diff --git a/views/window/window_gtk.h b/views/window/window_gtk.h
index 23d0bce..a6f2c9f 100644
--- a/views/window/window_gtk.h
+++ b/views/window/window_gtk.h
@@ -46,6 +46,8 @@ class WindowGtk : public WidgetGtk, public NativeWindow, public Window {
protected:
// Overridden from NativeWindow:
+ virtual NativeWidget* AsNativeWidget() OVERRIDE;
+ virtual const NativeWidget* AsNativeWidget() const OVERRIDE;
virtual gfx::Rect GetRestoredBounds() const OVERRIDE;
virtual void ShowNativeWindow(ShowState state) OVERRIDE;
virtual void BecomeModal() OVERRIDE;
@@ -59,8 +61,6 @@ class WindowGtk : public WidgetGtk, public NativeWindow, public Window {
virtual void SetAccessibleName(const std::wstring& name) OVERRIDE;
virtual void SetAccessibleRole(ui::AccessibilityTypes::Role role) OVERRIDE;
virtual void SetAccessibleState(ui::AccessibilityTypes::State state) OVERRIDE;
- virtual NativeWidget* AsNativeWidget() OVERRIDE;
- virtual const NativeWidget* AsNativeWidget() const OVERRIDE;
virtual Window* GetWindow() OVERRIDE;
virtual void SetWindowBounds(const gfx::Rect& bounds,
gfx::NativeWindow other_window) OVERRIDE;
diff --git a/views/window/window_win.cc b/views/window/window_win.cc
index 32583e3..4708df5 100644
--- a/views/window/window_win.cc
+++ b/views/window/window_win.cc
@@ -142,6 +142,16 @@ void EnableMenuItem(HMENU menu, UINT command, bool enabled) {
EnableMenuItem(menu, command, flags);
}
+bool IsDwmRenderingWindowControls(HWND window) {
+ if (base::win::GetVersion() < base::win::VERSION_VISTA)
+ return false;
+
+ DWMNCRENDERINGPOLICY policy;
+ DwmGetWindowAttribute(window, DWMWA_NCRENDERING_POLICY, &policy,
+ sizeof(policy));
+ return policy == DWMNCRP_ENABLED;
+}
+
// If the hung renderer warning doesn't fit on screen, the amount of padding to
// be left between the edge of the window and the edge of the nearest monitor,
// after the window is nudged back on screen. Pixels.
@@ -432,6 +442,16 @@ LRESULT WindowWin::OnDwmCompositionChanged(UINT msg, WPARAM w_param,
return 0;
}
+void WindowWin::OnEnterSizeMove() {
+ WidgetWin::OnEnterSizeMove();
+ delegate_->OnNativeWindowBeginUserBoundsChange();
+}
+
+void WindowWin::OnExitSizeMove() {
+ WidgetWin::OnExitSizeMove();
+ delegate_->OnNativeWindowEndUserBoundsChange();
+}
+
void WindowWin::OnFinalMessage(HWND window) {
delegate_->OnNativeWindowDestroyed();
WidgetWin::OnFinalMessage(window);
@@ -605,9 +625,19 @@ LRESULT WindowWin::OnNCCalcSize(BOOL mode, LPARAM l_param) {
}
LRESULT WindowWin::OnNCHitTest(const CPoint& point) {
+ // If the DWM is rendering the window controls, we need to give the DWM's
+ // default window procedure first chance to handle hit testing.
+ if (IsDwmRenderingWindowControls(GetNativeView())) {
+ LRESULT result;
+ if (DwmDefWindowProc(GetNativeView(), WM_NCHITTEST, 0,
+ MAKELPARAM(point.x, point.y), &result)) {
+ return result;
+ }
+ }
+
// First, give the NonClientView a chance to test the point to see if it
// provides any of the non-client area.
- CPoint temp = point;
+ POINT temp = point;
MapWindowPoints(HWND_DESKTOP, GetNativeView(), &temp, 1);
int component = delegate_->GetNonClientComponent(gfx::Point(temp));
if (component != HTNOWHERE)
@@ -852,6 +882,14 @@ void WindowWin::OnWindowPosChanging(WINDOWPOS* window_pos) {
////////////////////////////////////////////////////////////////////////////////
// WindowWin, NativeWindow implementation:
+NativeWidget* WindowWin::AsNativeWidget() {
+ return this;
+}
+
+const NativeWidget* WindowWin::AsNativeWidget() const {
+ return this;
+}
+
gfx::Rect WindowWin::GetRestoredBounds() const {
// If we're in fullscreen mode, we've changed the normal bounds to the monitor
// rect, so return the saved bounds instead.
@@ -984,14 +1022,6 @@ void WindowWin::SetAccessibleState(ui::AccessibilityTypes::State state) {
}
}
-NativeWidget* WindowWin::AsNativeWidget() {
- return this;
-}
-
-const NativeWidget* WindowWin::AsNativeWidget() const {
- return this;
-}
-
void WindowWin::SetWindowBounds(const gfx::Rect& bounds,
gfx::NativeWindow other_window) {
SetChildBounds(GetNativeView(), GetParent(), other_window, bounds,
diff --git a/views/window/window_win.h b/views/window/window_win.h
index 222608a..114ea1e 100644
--- a/views/window/window_win.h
+++ b/views/window/window_win.h
@@ -104,6 +104,8 @@ class WindowWin : public WidgetWin,
virtual LRESULT OnDwmCompositionChanged(UINT msg,
WPARAM w_param,
LPARAM l_param) OVERRIDE;
+ virtual void OnEnterSizeMove() OVERRIDE;
+ virtual void OnExitSizeMove() OVERRIDE;
virtual void OnFinalMessage(HWND window) OVERRIDE;
virtual void OnGetMinMaxInfo(MINMAXINFO* minmax_info) OVERRIDE;
virtual void OnInitMenu(HMENU menu) OVERRIDE;
@@ -135,6 +137,8 @@ class WindowWin : public WidgetWin,
virtual const Window* GetWindow() const OVERRIDE { return this; }
// Overridden from NativeWindow:
+ virtual NativeWidget* AsNativeWidget() OVERRIDE;
+ virtual const NativeWidget* AsNativeWidget() const OVERRIDE;
virtual gfx::Rect GetRestoredBounds() const OVERRIDE;
virtual void ShowNativeWindow(ShowState state) OVERRIDE;
virtual void BecomeModal() OVERRIDE;
@@ -148,8 +152,6 @@ class WindowWin : public WidgetWin,
virtual void SetAccessibleName(const std::wstring& name) OVERRIDE;
virtual void SetAccessibleRole(ui::AccessibilityTypes::Role role) OVERRIDE;
virtual void SetAccessibleState(ui::AccessibilityTypes::State state) OVERRIDE;
- virtual NativeWidget* AsNativeWidget() OVERRIDE;
- virtual const NativeWidget* AsNativeWidget() const OVERRIDE;
virtual void SetWindowBounds(const gfx::Rect& bounds,
gfx::NativeWindow other_window) OVERRIDE;
virtual void HideWindow() OVERRIDE;