diff options
author | jcampan@chromium.org <jcampan@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-06-19 22:57:54 +0000 |
---|---|---|
committer | jcampan@chromium.org <jcampan@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-06-19 22:57:54 +0000 |
commit | a109d02492863aeb537dea09bfb445eb6f5d94c5 (patch) | |
tree | bd3d2e9a783179eb2582f0055192b97e8d248547 /chrome | |
parent | 3c30f4c1e5f2bdb4f5d198c4a9ea18cc8045ddea (diff) | |
download | chromium_src-a109d02492863aeb537dea09bfb445eb6f5d94c5.zip chromium_src-a109d02492863aeb537dea09bfb445eb6f5d94c5.tar.gz chromium_src-a109d02492863aeb537dea09bfb445eb6f5d94c5.tar.bz2 |
Removed the last Windows specific part out of the focus manager. HWNDs are not subclassed anymore.The FocusManager is now created and owned by top-level WidgetWins.BUG=NoneTEST=Run the unit tests, UI tests, interactive UI tests. Fully test the focus behavior in the browser: activate/deactivate the browser windows, make sure focus is remembered. Switch tabs, make sure focus is remembered for each tab. make sure accelerators work as expected. Test focus traversal in a web page, in the option dialog.
Review URL: http://codereview.chromium.org/125148
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@18872 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome')
25 files changed, 742 insertions, 60 deletions
diff --git a/chrome/browser/autocomplete/autocomplete_edit_view_win.cc b/chrome/browser/autocomplete/autocomplete_edit_view_win.cc index 03e7824..ed4237b 100644 --- a/chrome/browser/autocomplete/autocomplete_edit_view_win.cc +++ b/chrome/browser/autocomplete/autocomplete_edit_view_win.cc @@ -1610,8 +1610,7 @@ void AutocompleteEditViewWin::OnPaste() { } void AutocompleteEditViewWin::OnSetFocus(HWND focus_wnd) { - views::FocusManager* focus_manager = - views::FocusManager::GetFocusManager(m_hWnd); + views::FocusManager* focus_manager = parent_view_->GetFocusManager(); if (focus_manager) { // Notify the FocusManager that the focused view is now the location bar // (our parent view). diff --git a/chrome/browser/automation/automation_provider.cc b/chrome/browser/automation/automation_provider.cc index bcfd7a5..8432fee 100755 --- a/chrome/browser/automation/automation_provider.cc +++ b/chrome/browser/automation/automation_provider.cc @@ -1729,7 +1729,7 @@ void AutomationProvider::GetFocusedViewID(int handle, int* view_id) { if (window_tracker_->ContainsHandle(handle)) { HWND hwnd = window_tracker_->GetResource(handle); views::FocusManager* focus_manager = - views::FocusManager::GetFocusManager(hwnd); + views::FocusManager::GetFocusManagerForNativeView(hwnd); DCHECK(focus_manager); views::View* focused_view = focus_manager->GetFocusedView(); if (focused_view) diff --git a/chrome/browser/browser_focus_uitest.cc b/chrome/browser/browser_focus_uitest.cc index 3681c1b..8aebfcf 100644 --- a/chrome/browser/browser_focus_uitest.cc +++ b/chrome/browser/browser_focus_uitest.cc @@ -108,7 +108,7 @@ IN_PROC_BROWSER_TEST_F(BrowserFocusTest, BrowsersRememberFocus) { BrowserView* browser_view = BrowserView::GetBrowserViewForNativeWindow(hwnd); ASSERT_TRUE(browser_view); views::FocusManager* focus_manager = - views::FocusManager::GetFocusManager(hwnd); + views::FocusManager::GetFocusManagerForNativeView(hwnd); ASSERT_TRUE(focus_manager); EXPECT_EQ(browser_view->GetTabContentsContainerView(), @@ -149,7 +149,7 @@ IN_PROC_BROWSER_TEST_F(BrowserFocusTest, BrowsersRememberFocus) { BrowserView::GetBrowserViewForNativeWindow(hwnd2); ASSERT_TRUE(browser_view2); views::FocusManager* focus_manager2 = - views::FocusManager::GetFocusManager(hwnd2); + views::FocusManager::GetFocusManagerForNativeView(hwnd2); ASSERT_TRUE(focus_manager2); EXPECT_EQ(browser_view2->GetTabContentsContainerView(), focus_manager2->GetFocusedView()); @@ -183,13 +183,13 @@ IN_PROC_BROWSER_TEST_F(BrowserFocusTest, TabsRememberFocus) { ASSERT_TRUE(browser_view); views::FocusManager* focus_manager = - views::FocusManager::GetFocusManager(hwnd); + views::FocusManager::GetFocusManagerForNativeView(hwnd); ASSERT_TRUE(focus_manager); // Create several tabs. for (int i = 0; i < 4; ++i) { - browser()->AddTabWithURL(url, GURL(), PageTransition::TYPED, true, -1, false, - NULL); + browser()->AddTabWithURL(url, GURL(), PageTransition::TYPED, true, -1, + false, NULL); } // Alternate focus for the tab. @@ -283,7 +283,7 @@ IN_PROC_BROWSER_TEST_F(BrowserFocusTest, LocationBarLockFocus) { HWND hwnd = reinterpret_cast<HWND>(browser()->window()->GetNativeHandle()); BrowserView* browser_view = BrowserView::GetBrowserViewForNativeWindow(hwnd); views::FocusManager* focus_manager = - views::FocusManager::GetFocusManager(hwnd); + views::FocusManager::GetFocusManagerForNativeView(hwnd); // Click on the location bar. LocationBarView* location_bar = browser_view->GetLocationBarView(); @@ -311,7 +311,7 @@ IN_PROC_BROWSER_TEST_F(BrowserFocusTest, FocusTraversal) { HWND hwnd = reinterpret_cast<HWND>(browser()->window()->GetNativeHandle()); BrowserView* browser_view = BrowserView::GetBrowserViewForNativeWindow(hwnd); views::FocusManager* focus_manager = - views::FocusManager::GetFocusManager(hwnd); + views::FocusManager::GetFocusManagerForNativeView(hwnd); // Click on the location bar. LocationBarView* location_bar = browser_view->GetLocationBarView(); @@ -401,7 +401,7 @@ IN_PROC_BROWSER_TEST_F(BrowserFocusTest, FocusTraversalOnInterstitial) { HWND hwnd = reinterpret_cast<HWND>(browser()->window()->GetNativeHandle()); BrowserView* browser_view = BrowserView::GetBrowserViewForNativeWindow(hwnd); views::FocusManager* focus_manager = - views::FocusManager::GetFocusManager(hwnd); + views::FocusManager::GetFocusManagerForNativeView(hwnd); // Focus should be on the page. EXPECT_EQ(browser_view->GetTabContentsContainerView(), @@ -496,7 +496,7 @@ IN_PROC_BROWSER_TEST_F(BrowserFocusTest, InterstitialFocus) { HWND hwnd = reinterpret_cast<HWND>(browser()->window()->GetNativeHandle()); BrowserView* browser_view = BrowserView::GetBrowserViewForNativeWindow(hwnd); views::FocusManager* focus_manager = - views::FocusManager::GetFocusManager(hwnd); + views::FocusManager::GetFocusManagerForNativeView(hwnd); // Page should have focus. EXPECT_EQ(browser_view->GetTabContentsContainerView(), @@ -541,7 +541,7 @@ IN_PROC_BROWSER_TEST_F(BrowserFocusTest, FindFocusTest) { HWND hwnd = reinterpret_cast<HWND>(browser()->window()->GetNativeHandle()); BrowserView* browser_view = BrowserView::GetBrowserViewForNativeWindow(hwnd); views::FocusManager* focus_manager = - views::FocusManager::GetFocusManager(hwnd); + views::FocusManager::GetFocusManagerForNativeView(hwnd); LocationBarView* location_bar = browser_view->GetLocationBarView(); // Press Ctrl+F, which will make the Find box open and request focus. @@ -613,7 +613,7 @@ IN_PROC_BROWSER_TEST_F(BrowserFocusTest, TabInitialFocus) { BrowserView* browser_view = BrowserView::GetBrowserViewForNativeWindow(hwnd); ASSERT_TRUE(browser_view); views::FocusManager* focus_manager = - views::FocusManager::GetFocusManager(hwnd); + views::FocusManager::GetFocusManagerForNativeView(hwnd); ASSERT_TRUE(focus_manager); // Open the history tab, focus should be on the tab contents. diff --git a/chrome/browser/external_tab_container.cc b/chrome/browser/external_tab_container.cc index 7da0be0..d7e4836 100644 --- a/chrome/browser/external_tab_container.cc +++ b/chrome/browser/external_tab_container.cc @@ -53,11 +53,12 @@ bool ExternalTabContainer::Init(Profile* profile, } set_window_style(WS_POPUP); - views::WidgetWin::Init(NULL, bounds, true); + views::WidgetWin::Init(NULL, bounds); if (!IsWindow()) { NOTREACHED(); return false; } + // TODO(jcampan): limit focus traversal to contents. // We don't ever remove the prop because the lifetime of this object // is the same as the lifetime of the window diff --git a/chrome/browser/first_run_win.cc b/chrome/browser/first_run_win.cc index 136350c..6f1d4a5 100644 --- a/chrome/browser/first_run_win.cc +++ b/chrome/browser/first_run_win.cc @@ -684,7 +684,7 @@ class TryChromeDialog : public views::ButtonListener, popup->set_delete_on_destroy(true); popup->set_window_style(WS_POPUP | WS_CLIPCHILDREN); popup->set_window_ex_style(WS_EX_TOOLWINDOW); - popup->Init(NULL, pos, true); + popup->Init(NULL, pos); views::RootView* root_view = popup->GetRootView(); // The window color is a tiny bit off-white. diff --git a/chrome/browser/renderer_host/render_widget_host_view_win.cc b/chrome/browser/renderer_host/render_widget_host_view_win.cc index e5091d6..5a75f50 100644 --- a/chrome/browser/renderer_host/render_widget_host_view_win.cc +++ b/chrome/browser/renderer_host/render_widget_host_view_win.cc @@ -406,7 +406,7 @@ void RenderWidgetHostViewWin::Focus() { void RenderWidgetHostViewWin::Blur() { views::FocusManager* focus_manager = - views::FocusManager::GetFocusManager(GetParent()); + views::FocusManager::GetFocusManagerForNativeView(m_hWnd); // We don't have a FocusManager if we are hidden. if (focus_manager && render_widget_host_->CanBlur()) focus_manager->ClearFocus(); diff --git a/chrome/browser/views/autocomplete/autocomplete_popup_win.cc b/chrome/browser/views/autocomplete/autocomplete_popup_win.cc index 02d3118..accdbd5 100644 --- a/chrome/browser/views/autocomplete/autocomplete_popup_win.cc +++ b/chrome/browser/views/autocomplete/autocomplete_popup_win.cc @@ -28,7 +28,9 @@ void AutocompletePopupWin::Init(AutocompleteEditViewWin* edit_view, views::View* contents) { // Create the popup WidgetWin::Init(edit_view->parent_view()->GetWidget()->GetNativeView(), - contents_->GetPopupBounds(), false); + contents_->GetPopupBounds()); + // The contents is owned by the AutocompleteEditViewWin. + contents_->SetParentOwned(false); // The contents is owned by the LocationBarView. contents_->SetParentOwned(false); SetContentsView(contents_); diff --git a/chrome/browser/views/blocked_popup_container_view_win.cc b/chrome/browser/views/blocked_popup_container_view_win.cc index 8e2837e..29240de 100644 --- a/chrome/browser/views/blocked_popup_container_view_win.cc +++ b/chrome/browser/views/blocked_popup_container_view_win.cc @@ -398,7 +398,7 @@ BlockedPopupContainerViewWin::BlockedPopupContainerViewWin( set_window_style(WS_CHILD | WS_CLIPSIBLINGS | WS_CLIPCHILDREN); WidgetWin::Init(GetModel()->GetConstrainingContents(NULL)->GetNativeView(), - gfx::Rect(), false); + gfx::Rect()); SetContentsView(container_view_); SetPosition(); } diff --git a/chrome/browser/views/bookmark_bubble_view.cc b/chrome/browser/views/bookmark_bubble_view.cc index 9a2a8f6..b81d0ab 100644 --- a/chrome/browser/views/bookmark_bubble_view.cc +++ b/chrome/browser/views/bookmark_bubble_view.cc @@ -182,9 +182,7 @@ void BookmarkBubbleView::DidChangeBounds(const gfx::Rect& previous, void BookmarkBubbleView::BubbleShown() { DCHECK(GetWidget()); - views::FocusManager* focus_manager = - views::FocusManager::GetFocusManager(GetWidget()->GetNativeView()); - focus_manager->RegisterAccelerator( + GetFocusManager()->RegisterAccelerator( views::Accelerator(VK_RETURN, false, false, false), this); title_tf_->RequestFocus(); diff --git a/chrome/browser/views/browser_bubble_win.cc b/chrome/browser/views/browser_bubble_win.cc index 7b47fe9..e72545b 100644 --- a/chrome/browser/views/browser_bubble_win.cc +++ b/chrome/browser/views/browser_bubble_win.cc @@ -24,9 +24,7 @@ void BrowserBubble::InitPopup() { #endif // A focus manager is necessary if you want to be able to handle various // mouse events properly. - pop->Init(frame_native_view_, - bounds_, - true); // Give the widget a focus manager. + pop->Init(frame_native_view_, bounds_); pop->SetContentsView(view_); popup_.reset(pop); Reposition(); diff --git a/chrome/browser/views/constrained_window_impl.cc b/chrome/browser/views/constrained_window_impl.cc new file mode 100644 index 0000000..39d3bcb --- /dev/null +++ b/chrome/browser/views/constrained_window_impl.cc @@ -0,0 +1,691 @@ +// Copyright (c) 2006-2008 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 "chrome/browser/views/constrained_window_impl.h" + +#include "app/gfx/canvas.h" +#include "app/gfx/font.h" +#include "app/gfx/path.h" +#include "app/gfx/text_elider.h" +#include "app/l10n_util.h" +#include "app/resource_bundle.h" +#include "app/win_util.h" +#include "base/gfx/rect.h" +#include "chrome/app/chrome_dll_resource.h" +#include "chrome/browser/browser_process.h" +#include "chrome/browser/profile.h" +#include "chrome/browser/tab_contents/tab_contents.h" +#include "chrome/browser/tab_contents/tab_contents.h" +#include "chrome/browser/tab_contents/tab_contents_view.h" +#include "chrome/browser/toolbar_model.h" +#include "chrome/browser/views/frame/browser_view.h" +#include "chrome/browser/window_sizer.h" +#include "chrome/common/chrome_constants.h" +#include "chrome/common/notification_service.h" +#include "chrome/common/pref_names.h" +#include "chrome/common/pref_service.h" +#include "grit/app_resources.h" +#include "grit/chromium_strings.h" +#include "grit/generated_resources.h" +#include "grit/theme_resources.h" +#include "net/base/net_util.h" +#include "views/controls/button/image_button.h" +#include "views/focus/focus_manager.h" +#include "views/window/client_view.h" +#include "views/window/non_client_view.h" +#include "views/window/window_resources.h" + +using base::TimeDelta; + +namespace views { +class ClientView; +} + +// An enumeration of bitmap resources used by this window. +enum { + FRAME_PART_BITMAP_FIRST = 0, // Must be first. + + // Window Controls. + FRAME_CLOSE_BUTTON_ICON, + FRAME_CLOSE_BUTTON_ICON_H, + FRAME_CLOSE_BUTTON_ICON_P, + + // Window Frame Border. + FRAME_BOTTOM_EDGE, + FRAME_BOTTOM_LEFT_CORNER, + FRAME_BOTTOM_RIGHT_CORNER, + FRAME_LEFT_EDGE, + FRAME_RIGHT_EDGE, + FRAME_TOP_EDGE, + FRAME_TOP_LEFT_CORNER, + FRAME_TOP_RIGHT_CORNER, + + FRAME_WINDOW, + FRAME_WINDOW_INACTIVE, + FRAME_WINDOW_INCOGNITO, + FRAME_WINDOW_INCOGNITO_INACTIVE, + + FRAME_PART_BITMAP_COUNT // Must be last. +}; + +static const int kXPFramePartIDs[] = { + 0, + IDR_CLOSE_SA, IDR_CLOSE_SA_H, IDR_CLOSE_SA_P, + IDR_WINDOW_BOTTOM_CENTER, IDR_WINDOW_BOTTOM_LEFT_CORNER, + IDR_WINDOW_BOTTOM_RIGHT_CORNER, IDR_WINDOW_LEFT_SIDE, + IDR_WINDOW_RIGHT_SIDE, IDR_WINDOW_TOP_CENTER, + IDR_WINDOW_TOP_LEFT_CORNER, IDR_WINDOW_TOP_RIGHT_CORNER, + IDR_THEME_FRAME, IDR_THEME_FRAME_INACTIVE, IDR_THEME_FRAME_INCOGNITO, + IDR_THEME_FRAME_INCOGNITO_INACTIVE, + 0 }; +static const int kVistaFramePartIDs[] = { + 0, + IDR_CLOSE_SA, IDR_CLOSE_SA_H, IDR_CLOSE_SA_P, + IDR_CONSTRAINED_BOTTOM_CENTER_V, IDR_CONSTRAINED_BOTTOM_LEFT_CORNER_V, + IDR_CONSTRAINED_BOTTOM_RIGHT_CORNER_V, IDR_CONSTRAINED_LEFT_SIDE_V, + IDR_CONSTRAINED_RIGHT_SIDE_V, IDR_CONSTRAINED_TOP_CENTER_V, + IDR_CONSTRAINED_TOP_LEFT_CORNER_V, IDR_CONSTRAINED_TOP_RIGHT_CORNER_V, + IDR_THEME_FRAME, IDR_THEME_FRAME_INACTIVE, IDR_THEME_FRAME_INCOGNITO, + IDR_THEME_FRAME_INCOGNITO_INACTIVE, + 0 }; + +class XPWindowResources : public views::WindowResources { + public: + XPWindowResources() { + InitClass(); + } + virtual ~XPWindowResources() {} + + virtual SkBitmap* GetPartBitmap(views::FramePartBitmap part_id) const { + return bitmaps_[part_id]; + } + + private: + static void InitClass() { + static bool initialized = false; + if (!initialized) { + ResourceBundle& rb = ResourceBundle::GetSharedInstance(); + for (int i = 0; i < FRAME_PART_BITMAP_COUNT; ++i) { + int id = kXPFramePartIDs[i]; + if (id != 0) + bitmaps_[i] = rb.GetBitmapNamed(id); + } + initialized = true; + } + } + + static SkBitmap* bitmaps_[FRAME_PART_BITMAP_COUNT]; + + DISALLOW_EVIL_CONSTRUCTORS(XPWindowResources); +}; + +class VistaWindowResources : public views::WindowResources { + public: + VistaWindowResources() { + InitClass(); + } + virtual ~VistaWindowResources() {} + + virtual SkBitmap* GetPartBitmap(views::FramePartBitmap part_id) const { + return bitmaps_[part_id]; + } + + private: + static void InitClass() { + static bool initialized = false; + if (!initialized) { + ResourceBundle& rb = ResourceBundle::GetSharedInstance(); + for (int i = 0; i < FRAME_PART_BITMAP_COUNT; ++i) { + int id = kVistaFramePartIDs[i]; + if (id != 0) + bitmaps_[i] = rb.GetBitmapNamed(id); + } + initialized = true; + } + } + + static SkBitmap* bitmaps_[FRAME_PART_BITMAP_COUNT]; + + DISALLOW_EVIL_CONSTRUCTORS(VistaWindowResources); +}; + +SkBitmap* XPWindowResources::bitmaps_[]; +SkBitmap* VistaWindowResources::bitmaps_[]; + +//////////////////////////////////////////////////////////////////////////////// +// ConstrainedWindowFrameView + +class ConstrainedWindowFrameView + : public views::NonClientFrameView, + public views::ButtonListener { + public: + explicit ConstrainedWindowFrameView(ConstrainedWindowImpl* container); + virtual ~ConstrainedWindowFrameView(); + + void UpdateWindowTitle(); + + // Overridden from views::NonClientFrameView: + virtual gfx::Rect GetBoundsForClientView() const; + virtual bool AlwaysUseCustomFrame() const; + virtual gfx::Rect GetWindowBoundsForClientBounds( + const gfx::Rect& client_bounds) const; + virtual gfx::Point GetSystemMenuPoint() const; + virtual int NonClientHitTest(const gfx::Point& point); + virtual void GetWindowMask(const gfx::Size& size, gfx::Path* window_mask); + virtual void EnableClose(bool enable); + virtual void ResetWindowControls() { } + + // Overridden from views::View: + virtual void Paint(gfx::Canvas* canvas); + virtual void Layout(); + virtual void ThemeChanged(); + + // Overridden from views::ButtonListener: + virtual void ButtonPressed(views::Button* sender); + + private: + // Returns the thickness of the border that makes up the window frame edges. + // This does not include any client edge. + int FrameBorderThickness() const; + + // Returns the thickness of the entire nonclient left, right, and bottom + // borders, including both the window frame and any client edge. + int NonClientBorderThickness() const; + + // Returns the height of the entire nonclient top border, including the window + // frame, any title area, and any connected client edge. + int NonClientTopBorderHeight() const; + + // Calculates multiple values related to title layout. Returns the height of + // the entire titlebar including any connected client edge. + int TitleCoordinates(int* title_top_spacing, + int* title_thickness) const; + + // Paints different parts of the window to the incoming canvas. + void PaintFrameBorder(gfx::Canvas* canvas); + void PaintTitleBar(gfx::Canvas* canvas); + void PaintClientEdge(gfx::Canvas* canvas); + + // Layout various sub-components of this view. + void LayoutWindowControls(); + void LayoutTitleBar(); + void LayoutClientView(); + + // Returns the bounds of the client area for the specified view size. + gfx::Rect CalculateClientAreaBounds(int width, int height) const; + + SkColor GetTitleColor() const { + return (container_->owner()->profile()->IsOffTheRecord() || + !win_util::ShouldUseVistaFrame()) ? SK_ColorWHITE : SK_ColorBLACK; + } + + // Loads the appropriate set of WindowResources for the frame view. + void InitWindowResources(); + + ConstrainedWindowImpl* container_; + + scoped_ptr<views::WindowResources> resources_; + + gfx::Rect title_bounds_; + + views::ImageButton* close_button_; + + // The bounds of the ClientView. + gfx::Rect client_view_bounds_; + + static void InitClass(); + + // The font to be used to render the titlebar text. + static gfx::Font* title_font_; + + DISALLOW_EVIL_CONSTRUCTORS(ConstrainedWindowFrameView); +}; + +gfx::Font* ConstrainedWindowFrameView::title_font_ = NULL; + +namespace { +// The frame border is only visible in restored mode and is hardcoded to 4 px on +// each side regardless of the system window border size. +const int kFrameBorderThickness = 4; +// Various edges of the frame border have a 1 px shadow along their edges; in a +// few cases we shift elements based on this amount for visual appeal. +const int kFrameShadowThickness = 1; +// In the window corners, the resize areas don't actually expand bigger, but the +// 16 px at the end of each edge triggers diagonal resizing. +const int kResizeAreaCornerSize = 16; +// The titlebar never shrinks to less than 20 px tall, including the height of +// the frame border and client edge. +const int kTitlebarMinimumHeight = 20; +// The icon is inset 2 px from the left frame border. +const int kIconLeftSpacing = 2; +// The title text starts 2 px below the bottom of the top frame border. +const int kTitleTopSpacing = 2; +// There is a 5 px gap between the title text and the caption buttons. +const int kTitleCaptionSpacing = 5; +// The caption buttons are always drawn 1 px down from the visible top of the +// window (the true top in restored mode, or the top of the screen in maximized +// mode). +const int kCaptionTopSpacing = 1; + +const SkColor kContentsBorderShadow = SkColorSetARGB(51, 0, 0, 0); +} + +//////////////////////////////////////////////////////////////////////////////// +// ConstrainedWindowFrameView, public: + +ConstrainedWindowFrameView::ConstrainedWindowFrameView( + ConstrainedWindowImpl* container) + : NonClientFrameView(), + container_(container), + close_button_(new views::ImageButton(this)) { + InitClass(); + InitWindowResources(); + + close_button_->SetImage(views::CustomButton::BS_NORMAL, + resources_->GetPartBitmap(FRAME_CLOSE_BUTTON_ICON)); + close_button_->SetImage(views::CustomButton::BS_HOT, + resources_->GetPartBitmap(FRAME_CLOSE_BUTTON_ICON_H)); + close_button_->SetImage(views::CustomButton::BS_PUSHED, + resources_->GetPartBitmap(FRAME_CLOSE_BUTTON_ICON_P)); + close_button_->SetImageAlignment(views::ImageButton::ALIGN_CENTER, + views::ImageButton::ALIGN_MIDDLE); + AddChildView(close_button_); +} + +ConstrainedWindowFrameView::~ConstrainedWindowFrameView() { +} + +void ConstrainedWindowFrameView::UpdateWindowTitle() { + SchedulePaint(title_bounds_, false); +} + +//////////////////////////////////////////////////////////////////////////////// +// ConstrainedWindowFrameView, views::NonClientFrameView implementation: + +gfx::Rect ConstrainedWindowFrameView::GetBoundsForClientView() const { + return client_view_bounds_; +} + +bool ConstrainedWindowFrameView::AlwaysUseCustomFrame() const { + // Constrained windows always use the custom frame - they just have a + // different set of bitmaps. + return true; +} + +gfx::Rect ConstrainedWindowFrameView::GetWindowBoundsForClientBounds( + const gfx::Rect& client_bounds) const { + int top_height = NonClientTopBorderHeight(); + int border_thickness = NonClientBorderThickness(); + return gfx::Rect(std::max(0, client_bounds.x() - border_thickness), + std::max(0, client_bounds.y() - top_height), + client_bounds.width() + (2 * border_thickness), + client_bounds.height() + top_height + border_thickness); +} + +gfx::Point ConstrainedWindowFrameView::GetSystemMenuPoint() const { + // Doesn't really matter, since we never show system menus on constrained + // windows... + gfx::Point system_menu_point(FrameBorderThickness(), + NonClientTopBorderHeight()); + ConvertPointToScreen(this, &system_menu_point); + return system_menu_point; +} + +int ConstrainedWindowFrameView::NonClientHitTest(const gfx::Point& point) { + if (!bounds().Contains(point)) + return HTNOWHERE; + + int frame_component = container_->GetClientView()->NonClientHitTest(point); + if (frame_component != HTNOWHERE) + return frame_component; + + // Then see if the point is within any of the window controls. + if (close_button_->GetBounds(APPLY_MIRRORING_TRANSFORMATION).Contains(point)) + return HTCLOSE; + + int window_component = GetHTComponentForFrame(point, FrameBorderThickness(), + NonClientBorderThickness(), kResizeAreaCornerSize, kResizeAreaCornerSize, + container_->GetDelegate()->CanResize()); + // Fall back to the caption if no other component matches. + return (window_component == HTNOWHERE) ? HTCAPTION : window_component; +} + +void ConstrainedWindowFrameView::GetWindowMask(const gfx::Size& size, + gfx::Path* window_mask) { + DCHECK(window_mask); + + // Redefine the window visible region for the new size. + window_mask->moveTo(0, 3); + window_mask->lineTo(1, 2); + window_mask->lineTo(1, 1); + window_mask->lineTo(2, 1); + window_mask->lineTo(3, 0); + + window_mask->lineTo(SkIntToScalar(size.width() - 3), 0); + window_mask->lineTo(SkIntToScalar(size.width() - 2), 1); + window_mask->lineTo(SkIntToScalar(size.width() - 1), 1); + window_mask->lineTo(SkIntToScalar(size.width() - 1), 2); + window_mask->lineTo(SkIntToScalar(size.width()), 3); + + window_mask->lineTo(SkIntToScalar(size.width()), + SkIntToScalar(size.height())); + window_mask->lineTo(0, SkIntToScalar(size.height())); + window_mask->close(); +} + +void ConstrainedWindowFrameView::EnableClose(bool enable) { + close_button_->SetEnabled(enable); +} + +//////////////////////////////////////////////////////////////////////////////// +// ConstrainedWindowFrameView, views::View implementation: + +void ConstrainedWindowFrameView::Paint(gfx::Canvas* canvas) { + PaintFrameBorder(canvas); + PaintTitleBar(canvas); + PaintClientEdge(canvas); +} + +void ConstrainedWindowFrameView::Layout() { + LayoutWindowControls(); + LayoutTitleBar(); + LayoutClientView(); +} + +void ConstrainedWindowFrameView::ThemeChanged() { + InitWindowResources(); +} + +//////////////////////////////////////////////////////////////////////////////// +// ConstrainedWindowFrameView, views::ButtonListener implementation: + +void ConstrainedWindowFrameView::ButtonPressed(views::Button* sender) { + if (sender == close_button_) + container_->ExecuteSystemMenuCommand(SC_CLOSE); +} + +//////////////////////////////////////////////////////////////////////////////// +// ConstrainedWindowFrameView, private: + +int ConstrainedWindowFrameView::FrameBorderThickness() const { + return kFrameBorderThickness; +} + +int ConstrainedWindowFrameView::NonClientBorderThickness() const { + return FrameBorderThickness() + kClientEdgeThickness; +} + +int ConstrainedWindowFrameView::NonClientTopBorderHeight() const { + int title_top_spacing, title_thickness; + return TitleCoordinates(&title_top_spacing, &title_thickness); +} + +int ConstrainedWindowFrameView::TitleCoordinates( + int* title_top_spacing, + int* title_thickness) const { + int frame_thickness = FrameBorderThickness(); + int min_titlebar_height = kTitlebarMinimumHeight + frame_thickness; + *title_top_spacing = frame_thickness + kTitleTopSpacing; + // The bottom spacing should be the same apparent height as the top spacing, + // plus have the client edge tacked on. + int title_bottom_spacing = *title_top_spacing + kClientEdgeThickness; + *title_thickness = std::max(title_font_->height(), + min_titlebar_height - *title_top_spacing - title_bottom_spacing); + return *title_top_spacing + *title_thickness + title_bottom_spacing; +} + +void ConstrainedWindowFrameView::PaintFrameBorder(gfx::Canvas* canvas) { + SkBitmap* top_left_corner = resources_->GetPartBitmap(FRAME_TOP_LEFT_CORNER); + SkBitmap* top_right_corner = + resources_->GetPartBitmap(FRAME_TOP_RIGHT_CORNER); + SkBitmap* top_edge = resources_->GetPartBitmap(FRAME_TOP_EDGE); + SkBitmap* right_edge = resources_->GetPartBitmap(FRAME_RIGHT_EDGE); + SkBitmap* left_edge = resources_->GetPartBitmap(FRAME_LEFT_EDGE); + SkBitmap* bottom_left_corner = + resources_->GetPartBitmap(FRAME_BOTTOM_LEFT_CORNER); + SkBitmap* bottom_right_corner = + resources_->GetPartBitmap(FRAME_BOTTOM_RIGHT_CORNER); + SkBitmap* bottom_edge = resources_->GetPartBitmap(FRAME_BOTTOM_EDGE); + + ResourceBundle& rb = ResourceBundle::GetSharedInstance(); + SkBitmap* theme_frame = rb.GetBitmapNamed(IDR_THEME_FRAME); + SkColor frame_color = ResourceBundle::frame_color; + + // Fill with the frame color first so we have a constant background for + // areas not covered by the theme image. + canvas->FillRectInt(frame_color, 0, 0, width(), theme_frame->height()); + // Now fill down the sides + canvas->FillRectInt(frame_color, + 0, theme_frame->height(), + left_edge->width(), height() - theme_frame->height()); + canvas->FillRectInt(frame_color, + width() - right_edge->width(), theme_frame->height(), + right_edge->width(), height() - theme_frame->height()); + // Now fill the bottom area. + canvas->FillRectInt(frame_color, + left_edge->width(), height() - bottom_edge->height(), + width() - left_edge->width() - right_edge->width(), + bottom_edge->height()); + + // Draw the theme frame. + canvas->TileImageInt(*theme_frame, 0, 0, width(), theme_frame->height()); + + // Top. + canvas->DrawBitmapInt(*top_left_corner, 0, 0); + canvas->TileImageInt(*top_edge, top_left_corner->width(), 0, + width() - top_right_corner->width(), top_edge->height()); + canvas->DrawBitmapInt(*top_right_corner, + width() - top_right_corner->width(), 0); + + // Right. + canvas->TileImageInt(*right_edge, width() - right_edge->width(), + top_right_corner->height(), right_edge->width(), + height() - top_right_corner->height() - + bottom_right_corner->height()); + + // Bottom. + canvas->DrawBitmapInt(*bottom_right_corner, + width() - bottom_right_corner->width(), + height() - bottom_right_corner->height()); + canvas->TileImageInt(*bottom_edge, bottom_left_corner->width(), + height() - bottom_edge->height(), + width() - bottom_left_corner->width() - + bottom_right_corner->width(), + bottom_edge->height()); + canvas->DrawBitmapInt(*bottom_left_corner, 0, + height() - bottom_left_corner->height()); + + // Left. + canvas->TileImageInt(*left_edge, 0, top_left_corner->height(), + left_edge->width(), + height() - top_left_corner->height() - bottom_left_corner->height()); +} + +void ConstrainedWindowFrameView::PaintTitleBar(gfx::Canvas* canvas) { + canvas->DrawStringInt(container_->GetWindowTitle(), *title_font_, + GetTitleColor(), MirroredLeftPointForRect(title_bounds_), + title_bounds_.y(), title_bounds_.width(), title_bounds_.height()); +} + +void ConstrainedWindowFrameView::PaintClientEdge(gfx::Canvas* canvas) { + gfx::Rect client_edge_bounds(CalculateClientAreaBounds(width(), height())); + client_edge_bounds.Inset(-kClientEdgeThickness, -kClientEdgeThickness); + gfx::Rect frame_shadow_bounds(client_edge_bounds); + frame_shadow_bounds.Inset(-kFrameShadowThickness, -kFrameShadowThickness); + + canvas->FillRectInt(kContentsBorderShadow, frame_shadow_bounds.x(), + frame_shadow_bounds.y(), frame_shadow_bounds.width(), + frame_shadow_bounds.height()); + + canvas->FillRectInt(ResourceBundle::toolbar_color, client_edge_bounds.x(), + client_edge_bounds.y(), client_edge_bounds.width(), + client_edge_bounds.height()); +} + +void ConstrainedWindowFrameView::LayoutWindowControls() { + gfx::Size close_button_size = close_button_->GetPreferredSize(); + close_button_->SetBounds( + width() - close_button_size.width() - FrameBorderThickness(), + kCaptionTopSpacing, close_button_size.width(), + close_button_size.height()); +} + +void ConstrainedWindowFrameView::LayoutTitleBar() { + // Size the title. + int title_x = FrameBorderThickness() + kIconLeftSpacing; + int title_top_spacing, title_thickness; + TitleCoordinates(&title_top_spacing, &title_thickness); + title_bounds_.SetRect(title_x, + title_top_spacing + ((title_thickness - title_font_->height()) / 2), + std::max(0, close_button_->x() - kTitleCaptionSpacing - title_x), + title_font_->height()); +} + +void ConstrainedWindowFrameView::LayoutClientView() { + client_view_bounds_ = CalculateClientAreaBounds(width(), height()); +} + +gfx::Rect ConstrainedWindowFrameView::CalculateClientAreaBounds( + int width, + int height) const { + int top_height = NonClientTopBorderHeight(); + int border_thickness = NonClientBorderThickness(); + return gfx::Rect(border_thickness, top_height, + std::max(0, width - (2 * border_thickness)), + std::max(0, height - top_height - border_thickness)); +} + +void ConstrainedWindowFrameView::InitWindowResources() { + if (win_util::ShouldUseVistaFrame()) { + resources_.reset(new VistaWindowResources); + } else { + resources_.reset(new XPWindowResources); + } +} + +// static +void ConstrainedWindowFrameView::InitClass() { + static bool initialized = false; + if (!initialized) { + title_font_ = new gfx::Font(win_util::GetWindowTitleFont()); + + initialized = true; + } +} + +//////////////////////////////////////////////////////////////////////////////// +// ConstrainedWindowImpl, public: + +// The space (in pixels) between minimized pop-ups stacked horizontally and +// vertically. +static const int kPopupRepositionOffset = 5; +static const int kConstrainedWindowEdgePadding = 10; + +ConstrainedWindowImpl::~ConstrainedWindowImpl() { +} + +//////////////////////////////////////////////////////////////////////////////// +// ConstrainedWindowImpl, ConstrainedWindow implementation: + +views::NonClientFrameView* ConstrainedWindowImpl::CreateFrameViewForWindow() { + return new ConstrainedWindowFrameView(this); +} + +void ConstrainedWindowImpl::CloseConstrainedWindow() { + // Broadcast to all observers of NOTIFY_CWINDOW_CLOSED. + // One example of such an observer is AutomationCWindowTracker in the + // automation component. + NotificationService::current()->Notify(NotificationType::CWINDOW_CLOSED, + Source<ConstrainedWindow>(this), + NotificationService::NoDetails()); + + Close(); +} + +std::wstring ConstrainedWindowImpl::GetWindowTitle() const { + std::wstring display_title; + if (GetDelegate()) + display_title = GetDelegate()->GetWindowTitle(); + else + display_title = L"Untitled"; + + return display_title; +} + +const gfx::Rect& ConstrainedWindowImpl::GetCurrentBounds() const { + return current_bounds_; +} + +//////////////////////////////////////////////////////////////////////////////// +// ConstrainedWindowImpl, private: + +ConstrainedWindowImpl::ConstrainedWindowImpl( + TabContents* owner, + views::WindowDelegate* window_delegate) + : WindowWin(window_delegate), + owner_(owner) { + GetNonClientView()->SetFrameView(CreateFrameViewForWindow()); + + focus_restoration_disabled_ = false; + set_window_style(WS_CHILD | WS_CLIPSIBLINGS | WS_CLIPCHILDREN | WS_CAPTION | + WS_THICKFRAME | WS_SYSMENU); + set_focus_on_creation(false); + + WindowWin::Init(owner_->GetNativeView(), gfx::Rect()); + ActivateConstrainedWindow(); +} + +void ConstrainedWindowImpl::ActivateConstrainedWindow() { + // Other pop-ups are simply moved to the front of the z-order. + SetWindowPos(HWND_TOP, 0, 0, 0, 0, SWP_NOMOVE | SWP_NOSIZE | SWP_SHOWWINDOW); +} + +//////////////////////////////////////////////////////////////////////////////// +// ConstrainedWindowImpl, views::WidgetWin overrides: + +void ConstrainedWindowImpl::OnDestroy() { + // TODO(jcampan): figure out focus restoration + + // Make sure we call super so that it can do its cleanup. + WindowWin::OnDestroy(); +} + +void ConstrainedWindowImpl::OnFinalMessage(HWND window) { + // Tell our constraining TabContents that we've gone so it can update its + // list. + owner_->WillClose(this); + + WindowWin::OnFinalMessage(window); +} + +LRESULT ConstrainedWindowImpl::OnMouseActivate(HWND window, + UINT hittest_code, + UINT message) { + // We only detach the window if the user clicked on the title bar. That + // way, users can click inside the contents of legitimate popups obtained + // with a mouse gesture. + if (hittest_code != HTCLIENT && hittest_code != HTNOWHERE && + hittest_code != HTCLOSE) { + ActivateConstrainedWindow(); + } + + return MA_ACTIVATE; +} + +void ConstrainedWindowImpl::OnWindowPosChanged(WINDOWPOS* window_pos) { + // If the window was moved or sized, tell the owner. + if (!(window_pos->flags & SWP_NOMOVE) || !(window_pos->flags & SWP_NOSIZE)) + owner_->DidMoveOrResize(this); + SetMsgHandled(FALSE); +} + + +// static +ConstrainedWindow* ConstrainedWindow::CreateConstrainedDialog( + TabContents* parent, + views::WindowDelegate* window_delegate) { + ConstrainedWindowImpl* window = new ConstrainedWindowImpl(parent, + window_delegate); + return window; +} diff --git a/chrome/browser/views/download_started_animation_win.cc b/chrome/browser/views/download_started_animation_win.cc index 4de387e..ec71683 100644 --- a/chrome/browser/views/download_started_animation_win.cc +++ b/chrome/browser/views/download_started_animation_win.cc @@ -106,7 +106,7 @@ DownloadStartedAnimationWin::DownloadStartedAnimationWin( popup_->set_window_ex_style(WS_EX_LAYERED | WS_EX_TOOLWINDOW | WS_EX_TRANSPARENT); popup_->SetOpacity(0x00); - popup_->Init(tab_contents_->GetNativeView(), rc, false); + popup_->Init(tab_contents_->GetNativeView(), rc); popup_->SetContentsView(this); Reposition(); popup_->Show(); diff --git a/chrome/browser/views/find_bar_win.cc b/chrome/browser/views/find_bar_win.cc index 51e1b20..4272ef7 100644 --- a/chrome/browser/views/find_bar_win.cc +++ b/chrome/browser/views/find_bar_win.cc @@ -95,12 +95,13 @@ FindBarWin::FindBarWin(BrowserView* browser_view) // Initialize the host. host_.reset(new Host(this)); - host_->Init(browser_view->GetWidget()->GetNativeView(), gfx::Rect(), false); + host_->Init(browser_view->GetWidget()->GetNativeView(), gfx::Rect()); host_->SetContentsView(view_); // Start listening to focus changes, so we can register and unregister our // own handler for Escape. - focus_manager_ = views::FocusManager::GetFocusManager(host_->GetNativeView()); + focus_manager_ = + views::FocusManager::GetFocusManagerForNativeView(host_->GetNativeView()); focus_manager_->AddFocusChangeListener(this); // Stores the currently focused view, and tracks focus changes so that we can diff --git a/chrome/browser/views/find_bar_win_browsertest.cc b/chrome/browser/views/find_bar_win_browsertest.cc index 67b05ad..cf55acf 100644 --- a/chrome/browser/views/find_bar_win_browsertest.cc +++ b/chrome/browser/views/find_bar_win_browsertest.cc @@ -557,8 +557,9 @@ IN_PROC_BROWSER_TEST_F(FindInPageControllerTest, AcceleratorRestoring) { GURL url = server->TestServerPageW(kSimplePage); ui_test_utils::NavigateToURL(browser(), url); - views::FocusManager* focus_manager = views::FocusManager::GetFocusManager( - browser()->window()->GetNativeHandle()); + gfx::NativeView browser_view = browser()->window()->GetNativeHandle(); + views::FocusManager* focus_manager = + views::FocusManager::GetFocusManagerForNativeView(browser_view); // See where Escape is registered. views::Accelerator escape(VK_ESCAPE, false, false, false); diff --git a/chrome/browser/views/first_run_bubble.cc b/chrome/browser/views/first_run_bubble.cc index ba8edb2..b79c665 100644 --- a/chrome/browser/views/first_run_bubble.cc +++ b/chrome/browser/views/first_run_bubble.cc @@ -343,9 +343,7 @@ void FirstRunBubble::InfoBubbleClosing(InfoBubble* info_bubble, if (!IsWindowEnabled(GetParent())) ::EnableWindow(GetParent(), true); enable_window_method_factory_.RevokeAll(); - views::FocusManager* focus_manager = - views::FocusManager::GetFocusManager(GetNativeView()); - focus_manager->RemoveFocusChangeListener(view_); + GetFocusManager()->RemoveFocusChangeListener(view_); } // static @@ -362,9 +360,7 @@ FirstRunBubble* FirstRunBubble::Show(Profile* profile, views::Window* parent, window->set_view(view); window->Init(parent, position_relative_to, view); window->ShowWindow(SW_SHOW); - views::FocusManager* focus_manager = - views::FocusManager::GetFocusManager(window->GetNativeView()); - focus_manager->AddFocusChangeListener(view); + window->GetFocusManager()->AddFocusChangeListener(view); view->BubbleShown(); return window; } diff --git a/chrome/browser/views/fullscreen_exit_bubble.cc b/chrome/browser/views/fullscreen_exit_bubble.cc index 854c3dd..907a791 100644 --- a/chrome/browser/views/fullscreen_exit_bubble.cc +++ b/chrome/browser/views/fullscreen_exit_bubble.cc @@ -144,7 +144,7 @@ FullscreenExitBubble::FullscreenExitBubble( popup_->set_window_ex_style(WS_EX_LAYERED | WS_EX_TOOLWINDOW | l10n_util::GetExtendedTooltipStyles()); popup_->SetOpacity(static_cast<unsigned char>(0xff * kOpacity)); - popup_->Init(frame->GetNativeView(), GetPopupRect(false), false); + popup_->Init(frame->GetNativeView(), GetPopupRect(false)); popup_->SetContentsView(view_); popup_->Show(); // This does not activate the popup. diff --git a/chrome/browser/views/info_bubble.cc b/chrome/browser/views/info_bubble.cc index 908aa54..031caaf 100644 --- a/chrome/browser/views/info_bubble.cc +++ b/chrome/browser/views/info_bubble.cc @@ -133,7 +133,7 @@ void InfoBubble::Init(views::Window* parent, content_view_->CalculateWindowBoundsAndAjust(position_relative_to); #if defined(OS_WIN) - WidgetWin::Init(parent->GetNativeWindow(), bounds, true); + WidgetWin::Init(parent->GetNativeWindow(), bounds); #else WidgetGtk::Init(GTK_WIDGET(parent->GetNativeWindow()), bounds, true); #endif @@ -155,11 +155,9 @@ void InfoBubble::Init(views::Window* parent, #if defined(OS_WIN) // Register the Escape accelerator for closing. - views::FocusManager* focus_manager = - views::FocusManager::GetFocusManager(GetNativeView()); - focus_manager->RegisterAccelerator(views::Accelerator(VK_ESCAPE, false, - false, false), - this); + GetFocusManager()->RegisterAccelerator(views::Accelerator(VK_ESCAPE, false, + false, false), + this); // Set initial alpha value of the layered window. SetLayeredWindowAttributes(GetNativeView(), RGB(0xFF, 0xFF, 0xFF), diff --git a/chrome/browser/views/infobars/infobars.cc b/chrome/browser/views/infobars/infobars.cc index 12fe42e..3e19bf7 100644 --- a/chrome/browser/views/infobars/infobars.cc +++ b/chrome/browser/views/infobars/infobars.cc @@ -207,9 +207,8 @@ void InfoBar::InfoBarAdded() { // focus so that we can restore focus when we're removed. views::Widget* widget = GetWidget(); if (widget) { - focus_tracker_.reset( - new views::ExternalFocusTracker(this, - views::FocusManager::GetFocusManager(widget->GetNativeView()))); + focus_tracker_.reset(new views::ExternalFocusTracker(this, + GetFocusManager())); } #endif } diff --git a/chrome/browser/views/shelf_item_dialog.cc b/chrome/browser/views/shelf_item_dialog.cc index ade3be7..12868f6 100644 --- a/chrome/browser/views/shelf_item_dialog.cc +++ b/chrome/browser/views/shelf_item_dialog.cc @@ -476,8 +476,7 @@ bool ShelfItemDialog::AcceleratorPressed( if (accelerator.GetKeyCode() == VK_ESCAPE) { window()->Close(); } else if (accelerator.GetKeyCode() == VK_RETURN) { - views::FocusManager* fm = views::FocusManager::GetFocusManager( - GetWidget()->GetNativeView()); + views::FocusManager* fm = GetFocusManager(); if (fm->GetFocusedView() == url_table_) { // Return on table behaves like a double click. OnDoubleClick(); diff --git a/chrome/browser/views/status_bubble_views.cc b/chrome/browser/views/status_bubble_views.cc index 49462bf..76c3ab9 100644 --- a/chrome/browser/views/status_bubble_views.cc +++ b/chrome/browser/views/status_bubble_views.cc @@ -481,7 +481,7 @@ void StatusBubbleViews::Init() { WS_EX_TRANSPARENT | l10n_util::GetExtendedTooltipStyles()); popup->SetOpacity(0x00); - popup->Init(frame_->GetNativeView(), gfx::Rect(), false); + popup->Init(frame_->GetNativeView(), gfx::Rect()); popup->SetContentsView(view_); Reposition(); popup->Show(); diff --git a/chrome/browser/views/tab_contents/tab_contents_view_win.cc b/chrome/browser/views/tab_contents/tab_contents_view_win.cc index 1b7fa80..2080cff 100755 --- a/chrome/browser/views/tab_contents/tab_contents_view_win.cc +++ b/chrome/browser/views/tab_contents/tab_contents_view_win.cc @@ -73,7 +73,7 @@ void TabContentsViewWin::CreateView() { // Since we create these windows parented to the desktop window initially, we // don't want to create them initially visible. set_window_style(WS_CHILD | WS_CLIPCHILDREN | WS_CLIPSIBLINGS); - WidgetWin::Init(GetDesktopWindow(), gfx::Rect(), false); + WidgetWin::Init(GetDesktopWindow(), gfx::Rect()); // Remove the root view drop target so we can register our own. RevokeDragDrop(GetNativeView()); @@ -233,7 +233,7 @@ void TabContentsViewWin::SizeContents(const gfx::Size& size) { void TabContentsViewWin::Focus() { views::FocusManager* focus_manager = - views::FocusManager::GetFocusManager(GetNativeView()); + views::FocusManager::GetFocusManagerForNativeView(GetNativeView()); if (tab_contents()->interstitial_page()) { tab_contents()->interstitial_page()->Focus(); @@ -269,7 +269,7 @@ void TabContentsViewWin::StoreFocus() { view_storage->RemoveView(last_focused_view_storage_id_); views::FocusManager* focus_manager = - views::FocusManager::GetFocusManager(GetNativeView()); + views::FocusManager::GetFocusManagerForNativeView(GetNativeView()); if (focus_manager) { // |focus_manager| can be NULL if the tab has been detached but still // exists. @@ -301,7 +301,7 @@ void TabContentsViewWin::RestoreFocus() { SetInitialFocus(); } else { views::FocusManager* focus_manager = - views::FocusManager::GetFocusManager(GetNativeView()); + views::FocusManager::GetFocusManagerForNativeView(GetNativeView()); // If you hit this DCHECK, please report it to Jay (jcampan). DCHECK(focus_manager != NULL) << "No focus manager when restoring focus."; @@ -333,7 +333,7 @@ void TabContentsViewWin::GotFocus() { void TabContentsViewWin::TakeFocus(bool reverse) { if (!tab_contents()->delegate()->TakeFocus(reverse)) { views::FocusManager* focus_manager = - views::FocusManager::GetFocusManager(GetNativeView()); + views::FocusManager::GetFocusManagerForNativeView(GetNativeView()); // We may not have a focus manager if the tab has been switched before this // message arrived. @@ -357,7 +357,7 @@ void TabContentsViewWin::HandleKeyboardEvent( // a keyboard shortcut that we have to process. if (event.type == WebInputEvent::RawKeyDown) { views::FocusManager* focus_manager = - views::FocusManager::GetFocusManager(GetNativeView()); + views::FocusManager::GetFocusManagerForNativeView(GetNativeView()); // We may not have a focus_manager at this point (if the tab has been // switched by the time this message returned). if (focus_manager) { diff --git a/chrome/browser/views/tabs/dragged_tab_controller.cc b/chrome/browser/views/tabs/dragged_tab_controller.cc index b4fea1d..adf7903 100644 --- a/chrome/browser/views/tabs/dragged_tab_controller.cc +++ b/chrome/browser/views/tabs/dragged_tab_controller.cc @@ -198,7 +198,7 @@ class DraggedTabController::DockDisplayer : public AnimationDelegate { popup->set_window_ex_style(WS_EX_LAYERED | WS_EX_TOOLWINDOW | WS_EX_TOPMOST); popup->SetOpacity(0x00); - popup->Init(NULL, info.GetPopupRect(), false); + popup->Init(NULL, info.GetPopupRect()); popup->SetContentsView(new DockView(info.type())); if (info.in_enable_area()) animation_.Reset(1); diff --git a/chrome/browser/views/tabs/dragged_tab_view.cc b/chrome/browser/views/tabs/dragged_tab_view.cc index f3101d9..b77ace5 100644 --- a/chrome/browser/views/tabs/dragged_tab_view.cc +++ b/chrome/browser/views/tabs/dragged_tab_view.cc @@ -48,7 +48,7 @@ DraggedTabView::DraggedTabView(TabContents* datasource, container_->set_window_ex_style( WS_EX_LAYERED | WS_EX_TOPMOST | WS_EX_TOOLWINDOW); container_->set_can_update_layered_window(false); - container_->Init(NULL, gfx::Rect(0, 0, 0, 0), false); + container_->Init(NULL, gfx::Rect(0, 0, 0, 0)); container_->SetContentsView(this); BOOL drag; diff --git a/chrome/browser/views/tabs/native_view_photobooth_win.cc b/chrome/browser/views/tabs/native_view_photobooth_win.cc index 430e009..6f78ea9 100644 --- a/chrome/browser/views/tabs/native_view_photobooth_win.cc +++ b/chrome/browser/views/tabs/native_view_photobooth_win.cc @@ -155,7 +155,7 @@ void NativeViewPhotoboothWin::CreateCaptureWindow(HWND initial_hwnd) { // WS_EX_TOOLWINDOW ensures the capture window doesn't produce a Taskbar // button. capture_window_->set_window_ex_style(WS_EX_LAYERED | WS_EX_TOOLWINDOW); - capture_window_->Init(NULL, capture_bounds, false); + capture_window_->Init(NULL, capture_bounds); // If the capture window isn't visible, blitting from the TabContents' // HWND's DC to the capture bitmap produces blankness. capture_window_->Show(); diff --git a/chrome/browser/views/tabs/tab_strip.cc b/chrome/browser/views/tabs/tab_strip.cc index d669be3..b5f0aae 100644 --- a/chrome/browser/views/tabs/tab_strip.cc +++ b/chrome/browser/views/tabs/tab_strip.cc @@ -1382,8 +1382,7 @@ TabStrip::DropInfo::DropInfo(int drop_index, bool drop_before, bool point_down) arrow_window->Init( NULL, - gfx::Rect(0, 0, drop_indicator_width, drop_indicator_height), - true); + gfx::Rect(0, 0, drop_indicator_width, drop_indicator_height)); arrow_window->SetContentsView(arrow_view); #else NOTIMPLEMENTED(); |