diff options
Diffstat (limited to 'chrome/views')
40 files changed, 477 insertions, 506 deletions
diff --git a/chrome/views/accessibility/view_accessibility.cc b/chrome/views/accessibility/view_accessibility.cc index af2d933..ac7ed71 100644 --- a/chrome/views/accessibility/view_accessibility.cc +++ b/chrome/views/accessibility/view_accessibility.cc @@ -109,9 +109,9 @@ STDMETHODIMP ViewAccessibility::get_accParent(IDispatch** disp_parent) { views::View* parent = view_->GetParent(); if (!parent) { - // This function can get called during teardown of ContainerWin so we + // This function can get called during teardown of WidetWin so we // should bail out if we fail to get the HWND. - if (!view_->GetContainer() || !view_->GetContainer()->GetHWND()) { + if (!view_->GetWidget() || !view_->GetWidget()->GetHWND()) { *disp_parent = NULL; return S_FALSE; } @@ -120,7 +120,7 @@ STDMETHODIMP ViewAccessibility::get_accParent(IDispatch** disp_parent) { // the default implementation, to interface with Windows' hierarchy and to // support calls from e.g. WindowFromAccessibleObject. HRESULT hr = - ::AccessibleObjectFromWindow(view_->GetContainer()->GetHWND(), + ::AccessibleObjectFromWindow(view_->GetWidget()->GetHWND(), OBJID_WINDOW, IID_IAccessible, reinterpret_cast<void**>(disp_parent)); diff --git a/chrome/views/aero_tooltip_manager.cc b/chrome/views/aero_tooltip_manager.cc index 5977644..29f3d66 100644 --- a/chrome/views/aero_tooltip_manager.cc +++ b/chrome/views/aero_tooltip_manager.cc @@ -18,8 +18,8 @@ namespace views { /////////////////////////////////////////////////////////////////////////////// // AeroTooltipManager, public: -AeroTooltipManager::AeroTooltipManager(Container* container, HWND parent) - : TooltipManager(container, parent), +AeroTooltipManager::AeroTooltipManager(Widget* widget, HWND parent) + : TooltipManager(widget, parent), initial_delay_(0) { } diff --git a/chrome/views/aero_tooltip_manager.h b/chrome/views/aero_tooltip_manager.h index 3b7b99a..7635904 100644 --- a/chrome/views/aero_tooltip_manager.h +++ b/chrome/views/aero_tooltip_manager.h @@ -28,7 +28,7 @@ namespace views { // TODO(glen): Resolve this with Microsoft. class AeroTooltipManager : public TooltipManager { public: - AeroTooltipManager(Container* container, HWND parent); + AeroTooltipManager(Widget* widget, HWND parent); virtual ~AeroTooltipManager(); virtual void OnMouse(UINT u_msg, WPARAM w_param, LPARAM l_param); diff --git a/chrome/views/bitmap_scroll_bar.cc b/chrome/views/bitmap_scroll_bar.cc index 5297f59..283f987 100644 --- a/chrome/views/bitmap_scroll_bar.cc +++ b/chrome/views/bitmap_scroll_bar.cc @@ -7,9 +7,9 @@ #include "base/message_loop.h" #include "chrome/common/gfx/chrome_canvas.h" #include "chrome/common/l10n_util.h" -#include "chrome/views/container.h" #include "chrome/views/menu.h" #include "chrome/views/scroll_view.h" +#include "chrome/views/widget.h" #include "skia/include/SkBitmap.h" #include "generated_resources.h" @@ -529,14 +529,14 @@ enum ScrollBarContextMenuCommands { void BitmapScrollBar::ShowContextMenu(View* source, int x, int y, bool is_mouse_gesture) { - Container* vc = GetContainer(); - CRect vc_bounds; - vc->GetBounds(&vc_bounds, true); - gfx::Point temp_pt(x - vc_bounds.left, y - vc_bounds.top); - View::ConvertPointFromContainer(this, &temp_pt); + Widget* widget = GetWidget(); + CRect widget_bounds; + widget->GetBounds(&widget_bounds, true); + gfx::Point temp_pt(x - widget_bounds.left, y - widget_bounds.top); + View::ConvertPointFromWidget(this, &temp_pt); context_menu_mouse_position_ = IsHorizontal() ? temp_pt.x() : temp_pt.y(); - Menu menu(this, Menu::TOPLEFT, GetContainer()->GetHWND()); + Menu menu(this, Menu::TOPLEFT, GetWidget()->GetHWND()); menu.AppendDelegateMenuItem(ScrollBarContextMenuCommand_ScrollHere); menu.AppendSeparator(); menu.AppendDelegateMenuItem(ScrollBarContextMenuCommand_ScrollStart); diff --git a/chrome/views/button.cc b/chrome/views/button.cc index 1a55aaf..93e2e3c 100644 --- a/chrome/views/button.cc +++ b/chrome/views/button.cc @@ -8,12 +8,11 @@ #include <atlapp.h> #include "base/gfx/image_operations.h" +#include "chrome/app/chrome_dll_resource.h" #include "chrome/common/gfx/chrome_canvas.h" #include "chrome/common/l10n_util.h" #include "chrome/common/throb_animation.h" -#include "chrome/views/container.h" #include "chrome/views/event.h" -#include "chrome/app/chrome_dll_resource.h" #include "generated_resources.h" diff --git a/chrome/views/button_dropdown.cc b/chrome/views/button_dropdown.cc index 2b07def..cb2b4b2 100644 --- a/chrome/views/button_dropdown.cc +++ b/chrome/views/button_dropdown.cc @@ -7,8 +7,8 @@ #include "base/message_loop.h" #include "chrome/browser/back_forward_menu_model.h" #include "chrome/common/l10n_util.h" -#include "chrome/views/container.h" #include "chrome/views/view_menu_delegate.h" +#include "chrome/views/widget.h" #include "generated_resources.h" @@ -49,7 +49,7 @@ bool ButtonDropDown::OnMousePressed(const MouseEvent& e) { // Schedule a task that will show the menu. MessageLoop::current()->PostDelayedTask(FROM_HERE, show_menu_factory_.NewRunnableMethod(&ButtonDropDown::ShowDropDownMenu, - GetContainer()->GetHWND()), + GetWidget()->GetHWND()), kMenuTimerDelay); } @@ -73,7 +73,7 @@ void ButtonDropDown::OnMouseReleased(const MouseEvent& e, bool canceled) { // update the appearance synchronously. SetState(BS_PUSHED); PaintNow(); - ShowDropDownMenu(GetContainer()->GetHWND()); + ShowDropDownMenu(GetWidget()->GetHWND()); } } @@ -91,7 +91,7 @@ bool ButtonDropDown::OnMouseDragged(const MouseEvent& e) { // it immediately. if (e.y() > y_position_on_lbuttondown_ + dragging_threshold) { show_menu_factory_.RevokeAll(); - ShowDropDownMenu(GetContainer()->GetHWND()); + ShowDropDownMenu(GetWidget()->GetHWND()); } } @@ -112,7 +112,7 @@ void ButtonDropDown::ShowContextMenu(int x, int y, bool is_mouse_gesture) { // update the appearance synchronously. SetState(BS_PUSHED); PaintNow(); - ShowDropDownMenu(GetContainer()->GetHWND()); + ShowDropDownMenu(GetWidget()->GetHWND()); SetState(BS_HOT); } diff --git a/chrome/views/chrome_menu.cc b/chrome/views/chrome_menu.cc index ffa4891..549bedf 100644 --- a/chrome/views/chrome_menu.cc +++ b/chrome/views/chrome_menu.cc @@ -21,9 +21,9 @@ #include "chrome/common/l10n_util.h" #include "chrome/common/os_exchange_data.h" #include "chrome/views/border.h" -#include "chrome/views/container_win.h" #include "chrome/views/root_view.h" #include "chrome/views/view_constants.h" +#include "chrome/views/widget_win.h" #include "generated_resources.h" #undef min @@ -542,9 +542,9 @@ class MenuSeparator : public View { class MenuHostRootView : public RootView { public: - explicit MenuHostRootView(Container* container, + explicit MenuHostRootView(Widget* widget, SubmenuView* submenu) - : RootView(container), + : RootView(widget), submenu_(submenu), forward_drag_to_menu_controller_(true), suspend_events_(false) { @@ -648,7 +648,7 @@ class MenuHostRootView : public RootView { // DelayedClosed, which avoids timing issues with deleting the window while // capture or events are directed at it. -class MenuHost : public ContainerWin { +class MenuHost : public WidgetWin { public: MenuHost(SubmenuView* submenu) : closed_(false), @@ -672,7 +672,7 @@ class MenuHost : public ContainerWin { const gfx::Rect& bounds, View* contents_view, bool do_capture) { - ContainerWin::Init(parent, bounds, true); + WidgetWin::Init(parent, bounds, true); SetContentsView(contents_view); // We don't want to take focus away from the hosting window. ShowWindow(SW_SHOWNA); @@ -699,17 +699,17 @@ class MenuHost : public ContainerWin { GetRootView()->RemoveAllChildViews(false); closed_ = true; ReleaseCapture(); - ContainerWin::Hide(); + WidgetWin::Hide(); } virtual void HideWindow() { // Make sure we release capture before hiding. ReleaseCapture(); - ContainerWin::Hide(); + WidgetWin::Hide(); } virtual void OnCaptureChanged(HWND hwnd) { - ContainerWin::OnCaptureChanged(hwnd); + WidgetWin::OnCaptureChanged(hwnd); owns_capture_ = false; #ifdef DEBUG_MENU DLOG(INFO) << "Capture changed"; @@ -2638,7 +2638,7 @@ bool MenuController::IsMenuWindow(MenuItemView* item, HWND window) { if (!item) return false; return ((item->HasSubmenu() && item->GetSubmenu()->IsShowing() && - item->GetSubmenu()->GetContainer()->GetHWND() == window) || + item->GetSubmenu()->GetWidget()->GetHWND() == window) || IsMenuWindow(item->GetParentMenuItem(), window)); } diff --git a/chrome/views/chrome_menu.h b/chrome/views/chrome_menu.h index dd17a84..98ce67b 100644 --- a/chrome/views/chrome_menu.h +++ b/chrome/views/chrome_menu.h @@ -19,7 +19,7 @@ namespace views { -class ContainerWin; +class WidgetWin; class MenuController; class MenuItemView; class SubmenuView; @@ -484,7 +484,7 @@ class MenuItemView : public View { // . Forwards the appropriate events to the MenuController. This allows the // MenuController to update the selection as the user moves the mouse around. // . Renders the drop indicator during a drop operation. -// . Shows and hides the window (a ContainerWin) when the menu is shown on +// . Shows and hides the window (a WidgetWin) when the menu is shown on // screen. // // SubmenuView is itself contained in a MenuScrollViewContainer. @@ -590,7 +590,7 @@ class SubmenuView : public View { // Parent menu item. MenuItemView* parent_menu_item_; - // ContainerWin subclass used to show the children. + // WidgetWin subclass used to show the children. MenuHost* host_; // If non-null, indicates a drop is in progress and drop_item is the item diff --git a/chrome/views/client_view.cc b/chrome/views/client_view.cc index ba3f6e4..4f4bae3 100644 --- a/chrome/views/client_view.cc +++ b/chrome/views/client_view.cc @@ -38,7 +38,7 @@ gfx::Size ClientView::GetPreferredSize() { void ClientView::ViewHierarchyChanged(bool is_add, View* parent, View* child) { if (is_add && child == this) { - DCHECK(GetContainer()); + DCHECK(GetWidget()); DCHECK(contents_view_); // |contents_view_| must be valid now! AddChildView(contents_view_); } diff --git a/chrome/views/container.h b/chrome/views/container.h deleted file mode 100644 index 08f776c..0000000 --- a/chrome/views/container.h +++ /dev/null @@ -1,89 +0,0 @@ -// 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. - -#ifndef CHROME_VIEWS_CONTAINER_H_ -#define CHROME_VIEWS_CONTAINER_H_ - -// TODO(maruel): Remove once HWND is abstracted. -#include <windows.h> - -namespace gfx { -class Rect; -} - -// TODO(maruel): Remove once gfx::Rect is used instead. -namespace WTL { -class CRect; -} -using WTL::CRect; - -namespace views { - -class RootView; -class TooltipManager; -class Accelerator; - -///////////////////////////////////////////////////////////////////////////// -// -// Container interface -// -// Container is an abstract class that defines the API that should be -// implemented by a CWindow / HWND implementation in order to host a view -// hierarchy. -// -// Container wraps a hierarchy of View objects (see view.h) that implement -// painting and flexible layout within the bounds of the Container's window. -// -// The Container is responsible for handling various system events and -// forwarding them to the appropriate view. -// -///////////////////////////////////////////////////////////////////////////// - -class Container { - public: - virtual ~Container() { } - - // Returns the bounds of this container in the screen coordinate system. - // If the receiving view container is a frame which is larger than its - // client area, this method returns the client area if including_frame is - // false and the frame bounds otherwise. If the receiving view container - // is not a frame, including_frame is ignored. - virtual void GetBounds(CRect *out, bool including_frame) const = 0; - - // Moves this view container to the front of the Z-Order - // If should_activate is TRUE, the window should also become the active - // window - virtual void MoveToFront(bool should_activate) = 0; - - // Returns the Window HWND associated with this container - virtual HWND GetHWND() const = 0; - - // Forces a paint of a specified rectangle immediately. - virtual void PaintNow(const gfx::Rect& update_rect) = 0; - - // Returns the RootView contained by this container - virtual RootView* GetRootView() = 0; - - // Returns whether the view container is visible to the user - virtual bool IsVisible() = 0; - - // Returns whether the view container is the currently active window. - virtual bool IsActive() = 0; - - // Returns the TooltipManager for this Container. If this Container does not - // support tooltips, NULL is returned. - virtual TooltipManager* GetTooltipManager() { - return NULL; - } - - // Returns the accelerator given a command id. Returns false if there is - // no accelerator associated with a given id, which is a common condition. - virtual bool GetAccelerator(int cmd_id, - Accelerator* accelerator) = 0; -}; - -} // namespace views - -#endif // CHROME_VIEWS_VIEW_CONTAINER_H_ - diff --git a/chrome/views/custom_frame_window.cc b/chrome/views/custom_frame_window.cc index 33df287..3ff64a6 100644 --- a/chrome/views/custom_frame_window.cc +++ b/chrome/views/custom_frame_window.cc @@ -532,9 +532,9 @@ gfx::Size DefaultNonClientView::GetPreferredSize() { void DefaultNonClientView::ViewHierarchyChanged(bool is_add, View* parent, View* child) { - // Add our Client View as we are added to the Container so that if we are + // Add our Client View as we are added to the Widget so that if we are // subsequently resized all the parent-child relationships are established. - if (is_add && GetContainer() && child == this) + if (is_add && GetWidget() && child == this) AddChildView(container_->client_view()); } @@ -927,7 +927,7 @@ void CustomFrameWindow::SetClientView(ClientView* cv) { DCHECK(cv && !client_view() && GetHWND()); set_client_view(cv); // For a CustomFrameWindow, the non-client view is the root. - ContainerWin::SetContentsView(non_client_view_); + WidgetWin::SetContentsView(non_client_view_); // When the non client view is added to the view hierarchy, it will cause the // client view to be added as well. } @@ -977,7 +977,7 @@ void CustomFrameWindow::SizeWindowToDefault() { } /////////////////////////////////////////////////////////////////////////////// -// CustomFrameWindow, ContainerWin overrides: +// CustomFrameWindow, WidgetWin overrides: void CustomFrameWindow::OnGetMinMaxInfo(MINMAXINFO* minmax_info) { // We handle this message so that we can make sure we interact nicely with @@ -1207,7 +1207,7 @@ void CustomFrameWindow::OnNCLButtonDown(UINT ht_component, /* if (!IsMsgHandled()) { // Window::OnNCLButtonDown set the message as unhandled. This normally - // means ContainerWin::ProcessWindowMessage will pass it to + // means WidgetWin::ProcessWindowMessage will pass it to // DefWindowProc. Sadly, DefWindowProc for WM_NCLBUTTONDOWN does weird // non-client painting, so we need to call it directly here inside a // scoped update lock. @@ -1232,23 +1232,21 @@ void CustomFrameWindow::OnNCMButtonDown(UINT ht_component, SetMsgHandled(FALSE); return; } - ContainerWin::OnNCMButtonDown(ht_component, point); + WidgetWin::OnNCMButtonDown(ht_component, point); } LRESULT CustomFrameWindow::OnNCUAHDrawCaption(UINT msg, WPARAM w_param, LPARAM l_param) { - // See comment in hwnd_view_container.h at the definition of - // WM_NCUAHDRAWCAPTION for an explanation about why we need to handle this - // message. + // See comment in widget_win.h at the definition of WM_NCUAHDRAWCAPTION for + // an explanation about why we need to handle this message. SetMsgHandled(TRUE); return 0; } LRESULT CustomFrameWindow::OnNCUAHDrawFrame(UINT msg, WPARAM w_param, LPARAM l_param) { - // See comment in hwnd_view_container.h at the definition of - // WM_NCUAHDRAWCAPTION for an explanation about why we need to handle this - // message. + // See comment in widget_win.h at the definition of WM_NCUAHDRAWCAPTION for + // an explanation about why we need to handle this message. SetMsgHandled(TRUE); return 0; } diff --git a/chrome/views/custom_frame_window.h b/chrome/views/custom_frame_window.h index 85c6b2d..2878f91 100644 --- a/chrome/views/custom_frame_window.h +++ b/chrome/views/custom_frame_window.h @@ -47,7 +47,7 @@ class CustomFrameWindow : public Window { virtual void EnableClose(bool enable); virtual void DisableInactiveRendering(bool disable); - // Overridden from ContainerWin: + // Overridden from WidgetWin: virtual void OnGetMinMaxInfo(MINMAXINFO* minmax_info); virtual void OnInitMenu(HMENU menu); virtual void OnMouseLeave(); diff --git a/chrome/views/focus_manager.cc b/chrome/views/focus_manager.cc index 4164cb8..da23bda 100644 --- a/chrome/views/focus_manager.cc +++ b/chrome/views/focus_manager.cc @@ -9,11 +9,11 @@ #include "chrome/browser/render_widget_host_view_win.h" #include "chrome/common/notification_types.h" #include "chrome/views/accelerator.h" -#include "chrome/views/container.h" #include "chrome/views/focus_manager.h" #include "chrome/views/root_view.h" #include "chrome/views/view.h" #include "chrome/views/view_storage.h" +#include "chrome/views/widget.h" // The following keys are used in SetProp/GetProp to associate additional // information needed for focus tracking with a window. @@ -304,11 +304,11 @@ bool FocusManager::OnKeyDown(HWND window, UINT message, WPARAM wparam, DCHECK((message == WM_KEYDOWN) || (message == WM_SYSKEYDOWN)); if (!IsWindowVisible(root_)) { - // We got a message for a hidden window. Because ContainerWin::Close - // hides the window, then destroys it, it it possible to get a message after - // we've hidden the window. If we allow the message to be dispatched - // chances are we'll crash in some weird place. By returning false we make - // sure the message isn't dispatched. + // We got a message for a hidden window. Because WidgetWin::Close hides the + // window, then destroys it, it it possible to get a message after we've + // hidden the window. If we allow the message to be dispatched chances are + // we'll crash in some weird place. By returning false we make sure the + // message isn't dispatched. return false; } @@ -425,11 +425,11 @@ bool FocusManager::ContainsView(View* view) { if (!root_view) return false; - Container* view_container = root_view->GetContainer(); - if (!view_container) + Widget* widget = root_view->GetWidget(); + if (!widget) return false; - HWND window = view_container->GetHWND(); + HWND window = widget->GetHWND(); while (window) { if (window == root_) return true; @@ -457,7 +457,7 @@ View* FocusManager::GetNextFocusableView(View* original_starting_view, View* starting_view = NULL; if (original_starting_view) { // If the starting view has a focus traversable, use it. - // This is the case with ContainerWins for example. + // This is the case with WidgetWins for example. focus_traversable = original_starting_view->GetFocusTraversable(); // Otherwise default to the root view. diff --git a/chrome/views/focus_manager.h b/chrome/views/focus_manager.h index 835b745..4fcd1ce 100644 --- a/chrome/views/focus_manager.h +++ b/chrome/views/focus_manager.h @@ -29,10 +29,10 @@ // This is already done for you if you subclass the NativeControl class or if // you use the HWNDView class. // -// When creating a top window, if it derives from ContainerWin, the +// When creating a top window, if it derives from WidgetWin, the // |has_own_focus_manager| of the Init method lets you specify whether that // window should have its own focus manager (so focus traversal stays confined -// in that window). If you are not deriving from ContainerWin or one of its +// in that window). If you are not deriving from WidgetWin or one of its // derived classes (Window, FramelessWindow, ConstrainedWindow), you must // create a FocusManager when the window is created (it is automatically deleted // when the window is destroyed). @@ -49,7 +49,7 @@ // method SetNextFocusableView(). // // If you are embedding a native view containing a nested RootView (for example -// by adding a NativeControl that contains a ContainerWin as its native +// by adding a NativeControl that contains a WidgetWin as its native // component), then you need to: // - override the View::GetFocusTraversable() method in your outter component. // It should return the RootView of the inner component. This is used when diff --git a/chrome/views/focus_manager_unittest.cc b/chrome/views/focus_manager_unittest.cc index 861979e..30f7e85 100644 --- a/chrome/views/focus_manager_unittest.cc +++ b/chrome/views/focus_manager_unittest.cc @@ -14,7 +14,6 @@ #include "chrome/views/background.h" #include "chrome/views/border.h" #include "chrome/views/checkbox.h" -#include "chrome/views/container_win.h" #include "chrome/views/label.h" #include "chrome/views/link.h" #include "chrome/views/native_button.h" @@ -23,6 +22,7 @@ #include "chrome/views/scroll_view.h" #include "chrome/views/tabbed_pane.h" #include "chrome/views/text_field.h" +#include "chrome/views/widget_win.h" #include "chrome/views/window.h" #include "chrome/views/window_delegate.h" #include "SkColor.h" @@ -114,10 +114,10 @@ class BorderView : public views::NativeControl { 0, 0, width(), height(), parent_container, NULL, NULL, NULL); // Create the view container which is a child of the TabControl. - view_container_ = new views::ContainerWin(); - view_container_->Init(tab_control, gfx::Rect(), false); - view_container_->SetContentsView(child_); - view_container_->SetFocusTraversableParentView(this); + widget_ = new views::WidgetWin(); + widget_->Init(tab_control, gfx::Rect(), false); + widget_->SetContentsView(child_); + widget_->SetFocusTraversableParentView(this); ResizeContents(tab_control); return tab_control; } @@ -132,11 +132,11 @@ class BorderView : public views::NativeControl { } virtual views::RootView* GetContentsRootView() { - return view_container_->GetRootView(); + return widget_->GetRootView(); } virtual views::FocusTraversable* GetFocusTraversable() { - return view_container_; + return widget_; } virtual void ViewHierarchyChanged(bool is_add, View *parent, View *child) { @@ -145,7 +145,7 @@ class BorderView : public views::NativeControl { if (child == this && is_add) { // We have been added to a view hierarchy, update the FocusTraversable // parent. - view_container_->SetFocusTraversableParent(GetRootView()); + widget_->SetFocusTraversableParent(GetRootView()); } } @@ -156,18 +156,18 @@ private: if (!GetClientRect(tab_control, &content_bounds)) return; TabCtrl_AdjustRect(tab_control, FALSE, &content_bounds); - view_container_->MoveWindow(content_bounds.left, content_bounds.top, + widget_->MoveWindow(content_bounds.left, content_bounds.top, content_bounds.Width(), content_bounds.Height(), TRUE); } View* child_; - views::ContainerWin* view_container_; + views::WidgetWin* widget_; DISALLOW_EVIL_CONSTRUCTORS(BorderView); }; -class TestViewWindow : public views::ContainerWin { +class TestViewWindow : public views::WidgetWin { public: explicit TestViewWindow(FocusManagerTest* test); ~TestViewWindow() { } @@ -239,7 +239,7 @@ void TestViewWindow::Init() { contents_->set_background( views::Background::CreateSolidBackground(255, 255, 255)); - ContainerWin::Init(NULL, bounds, true); + WidgetWin::Init(NULL, bounds, true); SetContentsView(contents_); views::CheckBox* cb = diff --git a/chrome/views/hwnd_view.cc b/chrome/views/hwnd_view.cc index 9a4ab30..22990fb 100644 --- a/chrome/views/hwnd_view.cc +++ b/chrome/views/hwnd_view.cc @@ -6,9 +6,9 @@ #include "chrome/common/gfx/chrome_canvas.h" #include "chrome/common/win_util.h" -#include "chrome/views/container.h" #include "chrome/views/focus_manager.h" #include "chrome/views/scroll_view.h" +#include "chrome/views/widget.h" #include "base/logging.h" namespace views { @@ -38,7 +38,7 @@ void HWNDView::Attach(HWND hwnd) { ShowWindow(hwnd_, SW_HIDE); // Need to set the HWND's parent before changing its size to avoid flashing. - ::SetParent(hwnd_, GetContainer()->GetHWND()); + ::SetParent(hwnd_, GetWidget()->GetHWND()); UpdateHWNDBounds(); // Register with the focus manager so the associated view is focused when the @@ -67,11 +67,11 @@ void HWNDView::UpdateHWNDBounds() { return; // Since HWNDs know nothing about the View hierarchy (they are direct - // children of the Container that hosts our View hierarchy) they need to be - // positioned in the coordinate system of the Container, not the current + // children of the Widget that hosts our View hierarchy) they need to be + // positioned in the coordinate system of the Widget, not the current // view. gfx::Point top_left; - ConvertPointToContainer(this, &top_left); + ConvertPointToWidget(this, &top_left); gfx::Rect vis_bounds = GetVisibleBounds(); bool visible = !vis_bounds.IsEmpty(); @@ -150,12 +150,12 @@ gfx::Size HWNDView::GetPreferredSize() { void HWNDView::ViewHierarchyChanged(bool is_add, View *parent, View *child) { if (hwnd_) { - Container* vc = GetContainer(); - if (is_add && vc) { + Widget* widget = GetWidget(); + if (is_add && widget) { HWND parent = ::GetParent(hwnd_); - HWND vc_hwnd = vc->GetHWND(); - if (parent != vc_hwnd) { - ::SetParent(hwnd_, vc_hwnd); + HWND widget_hwnd = widget->GetHWND(); + if (parent != widget_hwnd) { + ::SetParent(hwnd_, widget_hwnd); } if (IsVisibleInRootView()) ::ShowWindow(hwnd_, SW_SHOW); diff --git a/chrome/views/label.cc b/chrome/views/label.cc index d63e2f0..fc1e9d3 100644 --- a/chrome/views/label.cc +++ b/chrome/views/label.cc @@ -15,7 +15,6 @@ #include "chrome/common/l10n_util.h" #include "chrome/common/resource_bundle.h" #include "chrome/views/background.h" -#include "chrome/views/container.h" namespace views { diff --git a/chrome/views/menu_button.cc b/chrome/views/menu_button.cc index 59b0aa2..011a8b3 100644 --- a/chrome/views/menu_button.cc +++ b/chrome/views/menu_button.cc @@ -14,10 +14,10 @@ #include "chrome/common/resource_bundle.h" #include "chrome/common/win_util.h" #include "chrome/views/button.h" -#include "chrome/views/container.h" #include "chrome/views/event.h" #include "chrome/views/root_view.h" #include "chrome/views/view_menu_delegate.h" +#include "chrome/views/widget.h" #include "generated_resources.h" @@ -105,14 +105,14 @@ void MenuButton::Paint(ChromeCanvas* canvas, bool for_drag) { //////////////////////////////////////////////////////////////////////////////// int MenuButton::GetMaximumScreenXCoordinate() { - Container* vc = GetContainer(); + Widget* widget = GetWidget(); - if (!vc) { + if (!widget) { NOTREACHED(); return 0; } - HWND hwnd = vc->GetHWND(); + HWND hwnd = widget->GetHWND(); CRect t; ::GetWindowRect(hwnd, &t); @@ -158,7 +158,7 @@ bool MenuButton::Activate() { menu_visible_ = true; menu_delegate_->RunMenu(this, menu_position.ToPOINT(), - GetContainer()->GetHWND()); + GetWidget()->GetHWND()); menu_visible_ = false; menu_closed_time_ = Time::Now(); diff --git a/chrome/views/native_control.cc b/chrome/views/native_control.cc index fd81b4f..4236e27 100644 --- a/chrome/views/native_control.cc +++ b/chrome/views/native_control.cc @@ -11,11 +11,11 @@ #include "base/win_util.h" #include "chrome/common/l10n_util.h" +#include "chrome/views/background.h" #include "chrome/views/border.h" -#include "chrome/views/container.h" #include "chrome/views/focus_manager.h" #include "chrome/views/hwnd_view.h" -#include "chrome/views/background.h" +#include "chrome/views/widget.h" #include "base/gfx/native_theme.h" namespace views { @@ -36,7 +36,7 @@ class NativeControlContainer : public CWindowImpl<NativeControlContainer, explicit NativeControlContainer(NativeControl* parent) : parent_(parent), control_(NULL) { - Create(parent->GetContainer()->GetHWND()); + Create(parent->GetWidget()->GetHWND()); ::ShowWindow(m_hWnd, SW_SHOW); } @@ -199,14 +199,14 @@ void NativeControl::ValidateNativeControl() { void NativeControl::ViewHierarchyChanged(bool is_add, View *parent, View *child) { - if (is_add && GetContainer()) { + if (is_add && GetWidget()) { ValidateNativeControl(); Layout(); } } void NativeControl::Layout() { - if (!container_ && GetContainer()) + if (!container_ && GetWidget()) ValidateNativeControl(); if (hwnd_view_) { diff --git a/chrome/views/native_scroll_bar.cc b/chrome/views/native_scroll_bar.cc index fb10520..38f4b8d 100644 --- a/chrome/views/native_scroll_bar.cc +++ b/chrome/views/native_scroll_bar.cc @@ -11,8 +11,8 @@ #include <atlframe.h> #include "base/message_loop.h" -#include "chrome/views/container.h" #include "chrome/views/hwnd_view.h" +#include "chrome/views/widget.h" namespace views { @@ -30,7 +30,7 @@ class ScrollBarContainer : public CWindowImpl<ScrollBarContainer, public: ScrollBarContainer(ScrollBar* parent) : parent_(parent), scrollbar_(NULL) { - Create(parent->GetContainer()->GetHWND()); + Create(parent->GetWidget()->GetHWND()); ::ShowWindow(m_hWnd, SW_SHOW); } @@ -126,8 +126,8 @@ class ScrollBarContainer : public CWindowImpl<ScrollBarContainer, // If we receive an event from the scrollbar, make the view // component focused so we actually get mousewheel events. if (source != NULL) { - Container* vc = parent_->GetContainer(); - if (vc && vc->GetHWND() != GetFocus()) { + Widget* widget = parent_->GetWidget(); + if (widget && widget->GetHWND() != GetFocus()) { parent_->RequestFocus(); } } @@ -227,8 +227,8 @@ NativeScrollBar::~NativeScrollBar() { void NativeScrollBar::ViewHierarchyChanged(bool is_add, View *parent, View *child) { - Container* vc; - if (is_add && (vc = GetContainer()) && !sb_view_) { + Widget* widget; + if (is_add && (widget = GetWidget()) && !sb_view_) { sb_view_ = new HWNDView(); AddChildView(sb_view_); sb_container_ = new ScrollBarContainer(this); diff --git a/chrome/views/root_view.cc b/chrome/views/root_view.cc index 4b4027d..ac59d3f 100644 --- a/chrome/views/root_view.cc +++ b/chrome/views/root_view.cc @@ -12,7 +12,7 @@ #include "chrome/common/drag_drop_types.h" #include "chrome/common/gfx/chrome_canvas.h" #include "chrome/views/root_view_drop_target.h" -#include "chrome/views/container.h" +#include "chrome/views/widget.h" namespace views { @@ -51,8 +51,8 @@ const char RootView::kViewClassName[] = "chrome/views/RootView"; // ///////////////////////////////////////////////////////////////////////////// -RootView::RootView(Container* container) - : container_(container), +RootView::RootView(Widget* widget) + : widget_(widget), mouse_pressed_handler_(NULL), mouse_move_handler_(NULL), explicit_mouse_handler_(FALSE), @@ -178,9 +178,9 @@ void RootView::PaintNow() { } if (!paint_task_needed_) return; - Container* vc = GetContainer(); - if (vc) - vc->PaintNow(invalid_rect_); + Widget* widget = GetWidget(); + if (widget) + widget->PaintNow(invalid_rect_); } bool RootView::NeedsPainting(bool urgent) { @@ -212,8 +212,8 @@ RECT RootView::GetScheduledPaintRectConstrainedToSize() { // ///////////////////////////////////////////////////////////////////////////// -Container* RootView::GetContainer() const { - return container_; +Widget* RootView::GetWidget() const { + return widget_; } ///////////////////////////////////////////////////////////////////////////// @@ -311,7 +311,7 @@ bool RootView::OnMousePressed(const MouseEvent& e) { mouse_pressed_handler_ = NULL; if (focus_on_mouse_pressed_) { - HWND hwnd = container_->GetHWND(); + HWND hwnd = GetWidget()->GetHWND(); if (::GetFocus() != hwnd) { ::SetFocus(hwnd); } @@ -327,7 +327,7 @@ bool RootView::ConvertPointToMouseHandler(const gfx::Point& l, // window. (a non explicit mouse handler is automatically // cleared when the control is removed from the hierarchy) if (explicit_mouse_handler_) { - if (mouse_pressed_handler_->GetContainer()) { + if (mouse_pressed_handler_->GetWidget()) { *p = l; ConvertPointToScreen(this, p); ConvertPointToView(NULL, mouse_pressed_handler_, p); @@ -459,17 +459,17 @@ void RootView::SetMouseHandler(View *new_mh) { mouse_pressed_handler_ = new_mh; } -void RootView::OnContainerCreated() { +void RootView::OnWidgetCreated() { DCHECK(!drop_target_.get()); drop_target_ = new RootViewDropTarget(this); } -void RootView::OnContainerDestroyed() { +void RootView::OnWidgetDestroyed() { if (drop_target_.get()) { - RevokeDragDrop(GetContainer()->GetHWND()); + RevokeDragDrop(GetWidget()->GetHWND()); drop_target_ = NULL; } - container_ = NULL; + widget_ = NULL; } void RootView::ProcessMouseDragCanceled() { @@ -489,7 +489,7 @@ void RootView::FocusView(View* view) { if (view != GetFocusedView()) { FocusManager* focus_manager = GetFocusManager(); DCHECK(focus_manager) << "No Focus Manager for Window " << - (GetContainer() ? GetContainer()->GetHWND() : 0); + (GetWidget() ? GetWidget()->GetHWND() : 0); if (!focus_manager) return; diff --git a/chrome/views/root_view.h b/chrome/views/root_view.h index d15d354..6c62ba8 100644 --- a/chrome/views/root_view.h +++ b/chrome/views/root_view.h @@ -11,9 +11,9 @@ namespace views { -class Container; class PaintTask; class RootViewDropTarget; +class Widget; //////////////////////////////////////////////////////////////////////////////// // @@ -30,13 +30,12 @@ class FocusListener { // // RootView class // -// The RootView is the root of a View hierarchy. Its parent is not -// necessarily a Container, but the Container's View child is always a -// RootView. +// The RootView is the root of a View hierarchy. A RootView is always the +// first and only child of a Widget. // -// The RootView manages the View hierarchy's interface with the -// Container, and also maintains the current invalid rect - the region -// that needs repainting. +// The RootView manages the View hierarchy's interface with the Widget +// and also maintains the current invalid rect - the region that needs +// repainting. // ///////////////////////////////////////////////////////////////////////////// class RootView : public View, @@ -44,7 +43,7 @@ class RootView : public View, public: static const char kViewClassName[]; - explicit RootView(Container* container); + explicit RootView(Widget* widget); virtual ~RootView(); @@ -71,8 +70,7 @@ class RootView : public View, // returns whether this root view needs to paint as soon as possible. virtual bool NeedsPainting(bool urgent); - // Invoked by the Container to discover what rectangle should be - // painted + // Invoked by the Widget to discover what rectangle should be painted. const gfx::Rect& GetScheduledPaintRect(); // Returns the region scheduled to paint clipped to the RootViews bounds. @@ -80,8 +78,8 @@ class RootView : public View, // Tree functions - // Get the Container that hosts this View. - virtual Container* GetContainer() const; + // Get the Widget that hosts this View. + virtual Widget* GetWidget() const; // The following event methods are overridden to propagate event to the // control tree @@ -91,24 +89,23 @@ class RootView : public View, virtual void OnMouseMoved(const MouseEvent& e); virtual void SetMouseHandler(View* new_mouse_handler); - // Invoked when the Containers has been fully initialized. - // At the time the constructor is invoked the Container may not be - // completely initialized, when this method is invoked, it is. - void OnContainerCreated(); + // Invoked when the Widget has been fully initialized. + // At the time the constructor is invoked the Widget may not be completely + // initialized, when this method is invoked, it is. + void OnWidgetCreated(); - // Invoked prior to the Container being destroyed. - void OnContainerDestroyed(); + // Invoked prior to the Widget being destroyed. + void OnWidgetDestroyed(); - // Invoked By the Container if the mouse drag is interrupted by + // Invoked By the Widget if the mouse drag is interrupted by // the system. Invokes OnMouseReleased with a value of true for canceled. void ProcessMouseDragCanceled(); - // Invoked by the Container instance when the mouse moves outside of - // the container bounds + // Invoked by the Widget instance when the mouse moves outside of the Widget + // bounds. virtual void ProcessOnMouseExited(); - // Make the provided view focused. Also make sure that our container - // is focused. + // Make the provided view focused. Also make sure that our Widget is focused. void FocusView(View* view); // Check whether the provided view is in the focus path. The focus path is the @@ -167,10 +164,10 @@ class RootView : public View, virtual std::string GetClassName() const; // Clears the region that is schedule to be painted. You nearly never need - // to invoke this. This is primarily intended for Containers. + // to invoke this. This is primarily intended for Widgets. void ClearPaintRect(); - // Invoked from the Container to service a WM_PAINT call. + // Invoked from the Widget to service a WM_PAINT call. void OnPaint(HWND hwnd); // Returns the MSAA role of the current view. The role is what assistive @@ -202,7 +199,7 @@ class RootView : public View, DISALLOW_EVIL_CONSTRUCTORS(RootView); // Convert a point to our current mouse handler. Returns false if the - // mouse handler is not connected to a Container. In that case, the + // mouse handler is not connected to a Widget. In that case, the // conversion cannot take place and *p is unchanged bool ConvertPointToMouseHandler(const gfx::Point& l, gfx::Point *p); @@ -267,8 +264,8 @@ class RootView : public View, // The view currently handling enter / exit View* mouse_move_handler_; - // The host Container - Container* container_; + // The host Widget + Widget* widget_; // The rectangle that should be painted gfx::Rect invalid_rect_; diff --git a/chrome/views/root_view_drop_target.cc b/chrome/views/root_view_drop_target.cc index c5beedc..8920234 100644 --- a/chrome/views/root_view_drop_target.cc +++ b/chrome/views/root_view_drop_target.cc @@ -7,13 +7,13 @@ #include "base/gfx/point.h" #include "base/logging.h" #include "chrome/common/drag_drop_types.h" -#include "chrome/views/container.h" #include "chrome/views/root_view.h" +#include "chrome/views/widget.h" namespace views { RootViewDropTarget::RootViewDropTarget(RootView* root_view) - : BaseDropTarget(root_view->GetContainer()->GetHWND()), + : BaseDropTarget(root_view->GetWidget()->GetHWND()), root_view_(root_view), target_view_(NULL), deepest_view_(NULL) { diff --git a/chrome/views/tabbed_pane.cc b/chrome/views/tabbed_pane.cc index 9fe72a7..2638972 100644 --- a/chrome/views/tabbed_pane.cc +++ b/chrome/views/tabbed_pane.cc @@ -16,8 +16,8 @@ #include "chrome/common/stl_util-inl.h" #include "chrome/common/throb_animation.h" #include "chrome/views/background.h" -#include "chrome/views/container_win.h" #include "chrome/views/root_view.h" +#include "chrome/views/widget_win.h" #include "skia/include/SkColor.h" namespace views { @@ -167,7 +167,7 @@ HWND TabbedPane::CreateNativeControl(HWND parent_container) { SendMessage(tab_control_, WM_SETFONT, reinterpret_cast<WPARAM>(font), FALSE); // Create the view container which is a child of the TabControl. - content_window_ = new ContainerWin(); + content_window_ = new WidgetWin(); content_window_->Init(tab_control_, gfx::Rect(), false); // Explicitly setting the WS_EX_LAYOUTRTL property for the HWND (see above diff --git a/chrome/views/tabbed_pane.h b/chrome/views/tabbed_pane.h index fc30765..5e0dd5e 100644 --- a/chrome/views/tabbed_pane.h +++ b/chrome/views/tabbed_pane.h @@ -12,7 +12,7 @@ namespace views { // The TabbedPane class is a view that shows tabs. When the user clicks on a // tab, the associated view is displayed. // TODO (jcampan): implement GetPreferredSize(). -class ContainerWin; +class WidgetWin; class TabbedPane : public NativeControl { public: @@ -75,7 +75,7 @@ class TabbedPane : public NativeControl { std::vector<View*> tab_views_; // The window displayed in the tab. - ContainerWin* content_window_; + WidgetWin* content_window_; // The listener we notify about tab selection changes. Listener* listener_; diff --git a/chrome/views/table_view.cc b/chrome/views/table_view.cc index b67ca49..61d70388 100644 --- a/chrome/views/table_view.cc +++ b/chrome/views/table_view.cc @@ -15,7 +15,6 @@ #include "chrome/common/gfx/icon_util.h" #include "chrome/common/resource_bundle.h" #include "chrome/common/win_util.h" -#include "chrome/views/container.h" #include "chrome/views/hwnd_view.h" #include "SkBitmap.h" #include "SkColorFilter.h" @@ -438,7 +437,7 @@ void TableView::SetColumnVisibility(int id, bool is_visible) { int index = static_cast<int>(i - visible_columns_.begin()); // This could be called before the native list view has been created // (in CreateNativeControl, called when the view is added to a - // container). In that case since the column is not in + // Widget). In that case since the column is not in // visible_columns_ it will not be added later on when it is created. if (list_view_) SendMessage(list_view_, LVM_DELETECOLUMN, index, 0); diff --git a/chrome/views/text_button.cc b/chrome/views/text_button.cc index a64c2fd..30019c4 100644 --- a/chrome/views/text_button.cc +++ b/chrome/views/text_button.cc @@ -10,7 +10,6 @@ #include "chrome/common/throb_animation.h" #include "chrome/common/win_util.h" #include "chrome/views/button.h" -#include "chrome/views/container.h" #include "chrome/views/event.h" #include "chrome/views/view_menu_delegate.h" diff --git a/chrome/views/text_field.cc b/chrome/views/text_field.cc index 3c64c3d..072ff76 100644 --- a/chrome/views/text_field.cc +++ b/chrome/views/text_field.cc @@ -22,9 +22,9 @@ #include "chrome/common/l10n_util.h" #include "chrome/common/logging_chrome.h" #include "chrome/common/win_util.h" -#include "chrome/views/container.h" #include "chrome/views/hwnd_view.h" #include "chrome/views/menu.h" +#include "chrome/views/widget.h" #include "generated_resources.h" @@ -267,7 +267,7 @@ TextField::Edit::Edit(TextField* parent, bool draw_border) DWORD ex_style = l10n_util::GetExtendedStyles(); RECT r = {0, 0, parent_->width(), parent_->height()}; - Create(parent_->GetContainer()->GetHWND(), r, NULL, style, ex_style); + Create(parent_->GetWidget()->GetHWND(), r, NULL, style, ex_style); // Set up the text_object_model_. CComPtr<IRichEditOle> ole_interface; @@ -884,9 +884,9 @@ TextField::~TextField() { } void TextField::ViewHierarchyChanged(bool is_add, View* parent, View* child) { - Container* vc; + Widget* widget; - if (is_add && (vc = GetContainer())) { + if (is_add && (widget = GetWidget())) { // This notification is called from the AddChildView call below. Ignore it. if (native_view_ && !edit_) return; diff --git a/chrome/views/tooltip_manager.cc b/chrome/views/tooltip_manager.cc index ae842bf..2e5c00b 100644 --- a/chrome/views/tooltip_manager.cc +++ b/chrome/views/tooltip_manager.cc @@ -13,7 +13,7 @@ #include "chrome/views/root_view.h" #include "chrome/views/tooltip_manager.h" #include "chrome/views/view.h" -#include "chrome/views/container.h" +#include "chrome/views/widget.h" namespace views { @@ -76,8 +76,8 @@ const std::wstring& TooltipManager::GetLineSeparator() { return *separator; } -TooltipManager::TooltipManager(Container* container, HWND parent) - : container_(container), +TooltipManager::TooltipManager(Widget* widget, HWND parent) + : widget_(widget), parent_(parent), last_mouse_x_(-1), last_mouse_y_(-1), @@ -88,7 +88,7 @@ TooltipManager::TooltipManager(Container* container, HWND parent) keyboard_tooltip_hwnd_(NULL), #pragma warning(suppress: 4355) keyboard_tooltip_factory_(this) { - DCHECK(container && parent); + DCHECK(widget && parent); Init(); } @@ -147,7 +147,7 @@ LRESULT TooltipManager::OnNotify(int w_param, NMHDR* l_param, bool* handled) { case TTN_GETDISPINFO: { if (last_view_out_of_sync_) { // View under the mouse is out of sync, determine it now. - RootView* root_view = container_->GetRootView(); + RootView* root_view = widget_->GetRootView(); last_tooltip_view_ = root_view->GetViewForPoint( gfx::Point(last_mouse_x_, last_mouse_y_)); last_view_out_of_sync_ = false; @@ -165,7 +165,7 @@ LRESULT TooltipManager::OnNotify(int w_param, NMHDR* l_param, bool* handled) { tooltip_text_.clear(); // Mouse is over a View, ask the View for it's tooltip. gfx::Point view_loc(last_mouse_x_, last_mouse_y_); - View::ConvertPointToView(container_->GetRootView(), + View::ConvertPointToView(widget_->GetRootView(), last_tooltip_view_, &view_loc); if (last_tooltip_view_->GetTooltipText(view_loc.x(), view_loc.y(), &tooltip_text_) && @@ -194,7 +194,7 @@ LRESULT TooltipManager::OnNotify(int w_param, NMHDR* l_param, bool* handled) { if (tooltip_height_ == 0) tooltip_height_ = CalcTooltipHeight(); gfx::Point view_loc(last_mouse_x_, last_mouse_y_); - View::ConvertPointToView(container_->GetRootView(), + View::ConvertPointToView(widget_->GetRootView(), last_tooltip_view_, &view_loc); if (last_tooltip_view_->GetTooltipTextOrigin( view_loc.x(), view_loc.y(), &text_origin) && @@ -284,7 +284,7 @@ void TooltipManager::TrimTooltipToFit(std::wstring* text, // Determine the available width for the tooltip. gfx::Point screen_loc(position_x, position_y); - View::ConvertPointToScreen(container_->GetRootView(), &screen_loc); + View::ConvertPointToScreen(widget_->GetRootView(), &screen_loc); gfx::Rect monitor_bounds = win_util::GetMonitorBoundsForRect(gfx::Rect(screen_loc.x(), screen_loc.y(), 0, 0)); @@ -319,7 +319,7 @@ void TooltipManager::TrimTooltipToFit(std::wstring* text, } void TooltipManager::UpdateTooltip(int x, int y) { - RootView* root_view = container_->GetRootView(); + RootView* root_view = widget_->GetRootView(); View* view = root_view->GetViewForPoint(gfx::Point(x, y)); if (view != last_tooltip_view_) { // NOTE: This *must* be sent regardless of the visibility of the tooltip. @@ -352,7 +352,7 @@ void TooltipManager::OnMouse(UINT u_msg, WPARAM w_param, LPARAM l_param) { if (u_msg >= WM_NCMOUSEMOVE && u_msg <= WM_NCXBUTTONDBLCLK) { // NC message coordinates are in screen coordinates. CRect frame_bounds; - container_->GetBounds(&frame_bounds, true); + widget_->GetBounds(&frame_bounds, true); x -= frame_bounds.left; y -= frame_bounds.top; } @@ -385,8 +385,7 @@ void TooltipManager::ShowKeyboardTooltip(View* focused_view) { gfx::Point screen_point; focused_view->ConvertPointToScreen(focused_view, &screen_point); gfx::Point relative_point_coordinates; - focused_view->ConvertPointToContainer(focused_view, - &relative_point_coordinates); + focused_view->ConvertPointToWidget(focused_view, &relative_point_coordinates); keyboard_tooltip_hwnd_ = CreateWindowEx( WS_EX_TRANSPARENT | l10n_util::GetExtendedTooltipStyles(), TOOLTIPS_CLASS, NULL, 0, 0, 0, 0, 0, NULL, NULL, NULL, NULL); diff --git a/chrome/views/tooltip_manager.h b/chrome/views/tooltip_manager.h index f1aab66a..2800fb0 100644 --- a/chrome/views/tooltip_manager.h +++ b/chrome/views/tooltip_manager.h @@ -13,11 +13,11 @@ class ChromeFont; namespace views { -class Container; class View; +class Widget; // TooltipManager takes care of the wiring to support tooltips for Views. -// This class is intended to be used by Containers. To use this, you must +// This class is intended to be used by Widgets. To use this, you must // do the following: // Add the following to your MSG_MAP: // @@ -57,8 +57,8 @@ class TooltipManager { // Returns the separator for lines of text in a tooltip. static const std::wstring& GetLineSeparator(); - // Creates a TooltipManager for the specified Container and parent window. - TooltipManager(Container* container, HWND parent); + // Creates a TooltipManager for the specified Widget and parent window. + TooltipManager(Widget* widget, HWND parent); virtual ~TooltipManager(); // Notification that the view hierarchy has changed in some way. @@ -123,8 +123,8 @@ class TooltipManager { // Invoked when the timer elapses and tooltip has to be destroyed. void DestroyKeyboardTooltipWindow(HWND window_to_destroy); - // Hosting view container. - Container* container_; + // Hosting Widget. + Widget* widget_; // The View the mouse is under. This is null if the mouse isn't under a // View. diff --git a/chrome/views/tree_view.cc b/chrome/views/tree_view.cc index 0410ecc..ffb3e4c 100644 --- a/chrome/views/tree_view.cc +++ b/chrome/views/tree_view.cc @@ -13,8 +13,8 @@ #include "chrome/common/l10n_util.h" #include "chrome/common/resource_bundle.h" #include "chrome/common/stl_util-inl.h" -#include "chrome/views/container.h" #include "chrome/views/focus_manager.h" +#include "chrome/views/widget.h" namespace views { @@ -436,9 +436,9 @@ bool TreeView::OnKeyDown(int virtual_key_code) { } return true; } else if (virtual_key_code == VK_RETURN && !process_enter_) { - Container* vc = GetContainer(); - DCHECK(vc); - FocusManager* fm = FocusManager::GetFocusManager(vc->GetHWND()); + Widget* widget = GetWidget(); + DCHECK(widget); + FocusManager* fm = FocusManager::GetFocusManager(widget->GetHWND()); DCHECK(fm); Accelerator accelerator(Accelerator(static_cast<int>(virtual_key_code), win_util::IsShiftPressed(), diff --git a/chrome/views/view.cc b/chrome/views/view.cc index 4525724..823cb3e 100644 --- a/chrome/views/view.cc +++ b/chrome/views/view.cc @@ -22,10 +22,10 @@ #include "chrome/views/accessibility/accessible_wrapper.h" #include "chrome/views/background.h" #include "chrome/views/border.h" -#include "chrome/views/container.h" #include "chrome/views/layout_manager.h" #include "chrome/views/root_view.h" #include "chrome/views/tooltip_manager.h" +#include "chrome/views/widget.h" #include "SkShader.h" namespace views { @@ -282,11 +282,11 @@ void View::SetFocusable(bool focusable) { } FocusManager* View::GetFocusManager() { - Container* container = GetContainer(); - if (!container) + Widget* widget = GetWidget(); + if (!widget) return NULL; - HWND hwnd = container->GetHWND(); + HWND hwnd = widget->GetHWND(); if (!hwnd) return NULL; @@ -748,19 +748,15 @@ View* View::GetViewForPoint(const gfx::Point& point, return this; } -Container* View::GetContainer() const { - // The root view holds a reference to this view hierarchy's container. - return parent_ ? parent_->GetContainer() : NULL; +Widget* View::GetWidget() const { + // The root view holds a reference to this view hierarchy's Widget. + return parent_ ? parent_->GetWidget() : NULL; } // Get the containing RootView RootView* View::GetRootView() { - Container* vc = GetContainer(); - if (vc) { - return vc->GetRootView(); - } else { - return NULL; - } + Widget* widget = GetWidget(); + return widget ? widget->GetRootView() : NULL; } View* View::GetViewByID(int id) const { @@ -1291,10 +1287,10 @@ void View::ConvertPointToView(View* src, View* dst, gfx::Point* point, // If src is NULL, sp is in the screen coordinate system if (src == NULL) { - Container* vc = dst->GetContainer(); - if (vc) { + Widget* widget = dst->GetWidget(); + if (widget) { CRect b; - vc->GetBounds(&b, false); + widget->GetBounds(&b, false); point->SetPoint(point->x() - b.left, point->y() - b.top); } } @@ -1302,7 +1298,7 @@ void View::ConvertPointToView(View* src, View* dst, gfx::Point* point, } // static -void View::ConvertPointToContainer(View* src, gfx::Point* p) { +void View::ConvertPointToWidget(View* src, gfx::Point* p) { DCHECK(src); DCHECK(p); @@ -1316,9 +1312,9 @@ void View::ConvertPointToContainer(View* src, gfx::Point* p) { } // static -void View::ConvertPointFromContainer(View *source, gfx::Point* p) { +void View::ConvertPointFromWidget(View *source, gfx::Point* p) { gfx::Point t; - ConvertPointToContainer(source, &t); + ConvertPointToWidget(source, &t); p->SetPoint(p->x() - t.x(), p->y() - t.y()); } @@ -1328,11 +1324,11 @@ void View::ConvertPointToScreen(View* src, gfx::Point* p) { DCHECK(p); // If the view is not connected to a tree, there's nothing we can do. - Container* vc = src->GetContainer(); - if (vc) { - ConvertPointToContainer(src, p); + Widget* widget = src->GetWidget(); + if (widget) { + ConvertPointToWidget(src, p); CRect r; - vc->GetBounds(&r, false); + widget->GetBounds(&r, false); p->SetPoint(p->x() + r.left, p->y() + r.top); } } @@ -1503,7 +1499,7 @@ void View::Focus() { // messages. FocusManager* focus_manager = GetFocusManager(); if (focus_manager) - focus_manager->FocusHWND(GetRootView()->GetContainer()->GetHWND()); + focus_manager->FocusHWND(GetRootView()->GetWidget()->GetHWND()); } bool View::CanProcessTabKeyEvents() { @@ -1520,15 +1516,15 @@ bool View::GetTooltipTextOrigin(int x, int y, gfx::Point* loc) { } void View::TooltipTextChanged() { - Container* view_container = GetContainer(); - if (view_container != NULL && view_container->GetTooltipManager()) - view_container->GetTooltipManager()->TooltipTextChanged(this); + Widget* widget = GetWidget(); + if (widget && widget->GetTooltipManager()) + widget->GetTooltipManager()->TooltipTextChanged(this); } void View::UpdateTooltip() { - Container* view_container = GetContainer(); - if (view_container != NULL && view_container->GetTooltipManager()) - view_container->GetTooltipManager()->UpdateTooltip(); + Widget* widget = GetWidget(); + if (widget && widget->GetTooltipManager()) + widget->GetTooltipManager()->UpdateTooltip(); } void View::SetParentOwned(bool f) { @@ -1549,7 +1545,6 @@ gfx::Rect View::GetVisibleBounds() { View* view = this; int root_x = 0; int root_y = 0; - bool has_view_container = false; while (view != NULL && !vis_bounds.IsEmpty()) { root_x += view->GetX(APPLY_MIRRORING_TRANSFORMATION); root_y += view->y(); @@ -1559,9 +1554,8 @@ gfx::Rect View::GetVisibleBounds() { ancestor_bounds.SetRect(0, 0, ancestor->width(), ancestor->height()); vis_bounds = vis_bounds.Intersect(ancestor_bounds); - } else if (!view->GetContainer()) { - // If the view has no Container, we're not visible. Return an empty - // rect. + } else if (!view->GetWidget()) { + // If the view has no Widget, we're not visible. Return an empty rect. return gfx::Rect(); } view = ancestor; diff --git a/chrome/views/view.h b/chrome/views/view.h index d6b16ce..383473f 100644 --- a/chrome/views/view.h +++ b/chrome/views/view.h @@ -32,13 +32,13 @@ namespace views { class Background; class Border; -class Container; class FocusManager; class FocusTraversable; class LayoutManager; class RestoreFocusTask; class RootView; class ScrollView; +class Widget; // ContextMenuController is responsible for showing the context menu for a // View. To use a ContextMenuController invoke SetContextMenuController on a @@ -424,8 +424,8 @@ class View : public AcceleratorTarget { // Get the child View at the specified point. virtual View* GetViewForPoint(const gfx::Point& point); - // Get the Container that hosts this View, if any. - virtual Container* GetContainer() const; + // Get the Widget that hosts this View, if any. + virtual Widget* GetWidget() const; // Get the containing RootView virtual RootView* GetRootView(); @@ -496,8 +496,8 @@ class View : public AcceleratorTarget { virtual void SetFocusable(bool focusable); // Convenience method to retrieve the FocusManager associated with the - // container window that contains this view. This can return NULL if this - // view is not part of a view hierarchy with a Container. + // Widget that contains this view. This can return NULL if this view is not + // part of a view hierarchy with a Widget. virtual FocusManager* GetFocusManager(); // Sets a keyboard accelerator for that view. When the user presses the @@ -672,13 +672,13 @@ class View : public AcceleratorTarget { gfx::Point* point); // Convert a point from the coordinate system of a View to that of the - // Container. This is useful for example when sizing HWND children of the - // Container that don't know about the View hierarchy and need to be placed - // relative to the Container that is their parent. - static void ConvertPointToContainer(View* src, gfx::Point* point); + // Widget. This is useful for example when sizing HWND children of the + // Widget that don't know about the View hierarchy and need to be placed + // relative to the Widget that is their parent. + static void ConvertPointToWidget(View* src, gfx::Point* point); - // Convert a point from a view Container to a View dest - static void ConvertPointFromContainer(View *dest, gfx::Point* p); + // Convert a point from a view Widget to a View dest + static void ConvertPointFromWidget(View *dest, gfx::Point* p); // Convert a point from the coordinate system of a View to that of the // screen. This is useful for example when placing popup windows. @@ -1050,8 +1050,8 @@ class View : public AcceleratorTarget { // set and gives an opportunity to subclasses to perform any extra focus steps // (for example native component set the native focus on their native // component). The default behavior is to set the native focus on the root - // view container, which is what is appropriate for views that have no native - // window associated with them (so the root view gets the keyboard messages). + // Widget, which is what is appropriate for views that have no native window + // associated with them (so the root view gets the keyboard messages). virtual void Focus(); // Invoked when a key is pressed before the key event is processed by the @@ -1171,7 +1171,7 @@ class View : public AcceleratorTarget { gfx::Point* point, bool try_other_direction); - // Propagates UpdateTooltip() to the TooltipManager for the Container. + // Propagates UpdateTooltip() to the TooltipManager for the Widget. // This must be invoked any time the View hierarchy changes in such a way // the view under the mouse differs. For example, if the bounds of a View is // changed, this is invoked. Similarly, as Views are added/removed, this diff --git a/chrome/views/view_unittest.cc b/chrome/views/view_unittest.cc index e7196a0..48499a3 100644 --- a/chrome/views/view_unittest.cc +++ b/chrome/views/view_unittest.cc @@ -285,7 +285,7 @@ TEST_F(ViewTest, MouseEvent) { TestView* v2 = new TestView(); v2->SetBounds (100, 100, 100, 100); - views::ContainerWin window; + views::WidgetWin window; window.set_delete_on_destroy(false); window.set_window_style(WS_OVERLAPPEDWINDOW); window.Init(NULL, gfx::Rect(50, 50, 650, 650), false); @@ -359,7 +359,7 @@ TEST_F(ViewTest, Painting) { RDW_UPDATENOW | RDW_INVALIDATE | RDW_ALLCHILDREN); bool empty_paint = paint_window.empty_paint(); - views::ContainerWin window; + views::WidgetWin window; window.set_delete_on_destroy(false); window.set_window_style(WS_OVERLAPPEDWINDOW); window.Init(NULL, gfx::Rect(50, 50, 650, 650), NULL); @@ -446,7 +446,7 @@ TEST_F(ViewTest, RemoveNotification) { NotificationService::current()->AddObserver( observer.get(), NOTIFY_VIEW_REMOVED, NotificationService::AllSources()); - views::ContainerWin* window = new views::ContainerWin; + views::WidgetWin* window = new views::WidgetWin; views::RootView* root_view = window->GetRootView(); View* v1 = new View; @@ -550,7 +550,7 @@ gfx::Point ConvertPointToView(views::View* view, const gfx::Point& p) { } TEST_F(ViewTest, HitTestMasks) { - views::ContainerWin window; + views::WidgetWin window; views::RootView* root_view = window.GetRootView(); root_view->SetBounds(0, 0, 500, 500); diff --git a/chrome/views/views.vcproj b/chrome/views/views.vcproj index 505186f..104f77b 100644 --- a/chrome/views/views.vcproj +++ b/chrome/views/views.vcproj @@ -258,18 +258,6 @@ > </File> <File - RelativePath=".\container.h" - > - </File> - <File - RelativePath=".\container_win.cc" - > - </File> - <File - RelativePath=".\container_win.h" - > - </File> - <File RelativePath=".\controller.h" > </File> @@ -589,10 +577,10 @@ RelativePath=".\tooltip_manager.h" > </File> - <File - RelativePath=".\tree_model.h" - > - </File> + <File + RelativePath=".\tree_model.h" + > + </File> <File RelativePath=".\tree_node_model.h" > @@ -634,6 +622,18 @@ > </File> <File + RelativePath=".\widget.h" + > + </File> + <File + RelativePath=".\widget_win.cc" + > + </File> + <File + RelativePath=".\widget_win.h" + > + </File> + <File RelativePath=".\window.cc" > </File> diff --git a/chrome/views/widget.h b/chrome/views/widget.h new file mode 100644 index 0000000..221919d --- /dev/null +++ b/chrome/views/widget.h @@ -0,0 +1,87 @@ +// 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. + +#ifndef CHROME_VIEWS_WIDGET_H_ +#define CHROME_VIEWS_WIDGET_H_ + +// TODO(maruel): Remove once HWND is abstracted. +#include <windows.h> + +namespace gfx { +class Rect; +} + +// TODO(maruel): Remove once gfx::Rect is used instead. +namespace WTL { +class CRect; +} +using WTL::CRect; + +namespace views { + +class RootView; +class TooltipManager; +class Accelerator; + +//////////////////////////////////////////////////////////////////////////////// +// +// Widget interface +// +// Widget is an abstract class that defines the API that should be implemented +// by a native window in order to host a view hierarchy. +// +// Widget wraps a hierarchy of View objects (see view.h) that implement +// painting and flexible layout within the bounds of the Widget's window. +// +// The Widget is responsible for handling various system events and forwarding +// them to the appropriate view. +// +///////////////////////////////////////////////////////////////////////////// + +class Widget { + public: + virtual ~Widget() { } + + // Returns the bounds of this Widget in the screen coordinate system. + // If the receiving Widget is a frame which is larger than its client area, + // this method returns the client area if including_frame is false and the + // frame bounds otherwise. If the receiving Widget is not a frame, + // including_frame is ignored. + virtual void GetBounds(CRect *out, bool including_frame) const = 0; + + // Moves this Widget to the front of the Z-Order If should_activate is TRUE, + // the window should also become the active window. + virtual void MoveToFront(bool should_activate) = 0; + + // Returns the Window HWND associated with this Widget. + virtual HWND GetHWND() const = 0; + + // Forces a paint of a specified rectangle immediately. + virtual void PaintNow(const gfx::Rect& update_rect) = 0; + + // Returns the RootView contained by this Widget. + virtual RootView* GetRootView() = 0; + + // Returns whether the Widget is visible to the user. + virtual bool IsVisible() = 0; + + // Returns whether the Widget is the currently active window. + virtual bool IsActive() = 0; + + // Returns the TooltipManager for this Widget. If this Widget does not support + // tooltips, NULL is returned. + virtual TooltipManager* GetTooltipManager() { + return NULL; + } + + // Returns the accelerator given a command id. Returns false if there is + // no accelerator associated with a given id, which is a common condition. + virtual bool GetAccelerator(int cmd_id, + Accelerator* accelerator) = 0; +}; + +} // namespace views + +#endif // CHROME_VIEWS_WIDGET_H_ + diff --git a/chrome/views/container_win.cc b/chrome/views/widget_win.cc index dc011742..cd0e913 100644 --- a/chrome/views/container_win.cc +++ b/chrome/views/widget_win.cc @@ -2,7 +2,7 @@ // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. -#include "chrome/views/container_win.h" +#include "chrome/views/widget_win.h" #include "base/gfx/native_theme.h" #include "base/string_util.h" @@ -33,12 +33,12 @@ RootView* GetRootViewForHWND(HWND hwnd) { return reinterpret_cast<RootView*>(::GetProp(hwnd, kRootViewWindowProperty)); } -// Used to locate the ContainerWin issuing the current Create. Only valid for -// the life of Create. +// Used to locate the WidgetWin issuing the current Create. Only valid for the +// life of Create. // -// This obviously assumes we only create ContainerWins from the same thread, +// This obviously assumes we only create WidgetWins from the same thread, // which is currently the case. -static ContainerWin* instance_issuing_create = NULL; +static WidgetWin* instance_issuing_create = NULL; /////////////////////////////////////////////////////////////////////////////// // FillLayout @@ -66,8 +66,8 @@ gfx::Size FillLayout::GetPreferredSize(View* host) { // Window class tracking. // static -const wchar_t* const ContainerWin::kBaseClassName = - L"Chrome_ContainerWin_"; +const wchar_t* const WidgetWin::kBaseClassName = + L"Chrome_WidgetWin_"; // Window class information used for registering unique windows. struct ClassInfo { @@ -111,9 +111,9 @@ static RegisteredClasses* registered_classes = NULL; /////////////////////////////////////////////////////////////////////////////// -// ContainerWin, public +// WidgetWin, public -ContainerWin::ContainerWin() +WidgetWin::WidgetWin() : active_mouse_tracking_flags_(0), has_capture_(false), current_action_(FA_NONE), @@ -128,15 +128,15 @@ ContainerWin::ContainerWin() is_mouse_down_(false), class_style_(CS_DBLCLKS), hwnd_(NULL), - close_container_factory_(this) { + close_widget_factory_(this) { } -ContainerWin::~ContainerWin() { +WidgetWin::~WidgetWin() { MessageLoopForUI::current()->RemoveObserver(this); } -void ContainerWin::Init(HWND parent, const gfx::Rect& bounds, - bool has_own_focus_manager) { +void WidgetWin::Init(HWND parent, const gfx::Rect& bounds, + bool has_own_focus_manager) { toplevel_ = parent == NULL; if (window_style_ == 0) @@ -163,7 +163,7 @@ void ContainerWin::Init(HWND parent, const gfx::Rect& bounds, // The window procedure should have set the data for us. DCHECK(win_util::GetWindowUserData(hwnd_) == this); - root_view_->OnContainerCreated(); + root_view_->OnWidgetCreated(); if (has_own_focus_manager) { FocusManager::CreateFocusManager(hwnd_, GetRootView()); @@ -199,10 +199,10 @@ void ContainerWin::Init(HWND parent, const gfx::Rect& bounds, ::ImmAssociateContextEx(GetHWND(), NULL, 0); } -void ContainerWin::SetContentsView(View* view) { +void WidgetWin::SetContentsView(View* view) { DCHECK(view && hwnd_) << "Can't be called until after the HWND is created!"; // The ContentsView must be set up _after_ the window is created so that its - // Container pointer is valid. + // Widget pointer is valid. root_view_->SetLayoutManager(new FillLayout); if (root_view_->GetChildViewCount() != 0) root_view_->RemoveAllChildViews(true); @@ -215,9 +215,9 @@ void ContainerWin::SetContentsView(View* view) { } /////////////////////////////////////////////////////////////////////////////// -// Container implementation: +// Widget implementation: -void ContainerWin::GetBounds(CRect *out, bool including_frame) const { +void WidgetWin::GetBounds(CRect *out, bool including_frame) const { if (including_frame) { GetWindowRect(out); } else { @@ -233,7 +233,7 @@ void ContainerWin::GetBounds(CRect *out, bool including_frame) const { } } -void ContainerWin::MoveToFront(bool should_activate) { +void WidgetWin::MoveToFront(bool should_activate) { int flags = SWP_NOMOVE | SWP_NOSIZE; if (!should_activate) { flags |= SWP_NOACTIVATE; @@ -241,11 +241,11 @@ void ContainerWin::MoveToFront(bool should_activate) { SetWindowPos(HWND_NOTOPMOST, 0, 0, 0, 0, flags); } -HWND ContainerWin::GetHWND() const { +HWND WidgetWin::GetHWND() const { return hwnd_; } -void ContainerWin::PaintNow(const gfx::Rect& update_rect) { +void WidgetWin::PaintNow(const gfx::Rect& update_rect) { if (layered_) { PaintLayeredWindow(); } else if (root_view_->NeedsPainting(false) && IsWindow()) { @@ -274,7 +274,7 @@ void ContainerWin::PaintNow(const gfx::Rect& update_rect) { } } -RootView* ContainerWin::GetRootView() { +RootView* WidgetWin::GetRootView() { if (!root_view_.get()) { // First time the root view is being asked for, create it now. root_view_.reset(CreateRootView()); @@ -282,20 +282,20 @@ RootView* ContainerWin::GetRootView() { return root_view_.get(); } -bool ContainerWin::IsVisible() { +bool WidgetWin::IsVisible() { return !!::IsWindowVisible(GetHWND()); } -bool ContainerWin::IsActive() { +bool WidgetWin::IsActive() { return win_util::IsWindowActive(GetHWND()); } -TooltipManager* ContainerWin::GetTooltipManager() { +TooltipManager* WidgetWin::GetTooltipManager() { return tooltip_manager_.get(); } -void ContainerWin::SetLayeredAlpha(BYTE layered_alpha) { +void WidgetWin::SetLayeredAlpha(BYTE layered_alpha) { layered_alpha_ = layered_alpha; // if (hwnd_) @@ -313,7 +313,7 @@ static BOOL CALLBACK EnumChildProc(HWND hwnd, LPARAM l_param) { } // static -RootView* ContainerWin::FindRootView(HWND hwnd) { +RootView* WidgetWin::FindRootView(HWND hwnd) { RootView* root_view = reinterpret_cast<RootView*>(GetProp(hwnd, kRootViewWindowProperty)); if (root_view) @@ -325,21 +325,21 @@ RootView* ContainerWin::FindRootView(HWND hwnd) { return root_view; } -void ContainerWin::Close() { +void WidgetWin::Close() { // Let's hide ourselves right away. Hide(); - if (close_container_factory_.empty()) { + if (close_widget_factory_.empty()) { // And we delay the close so that if we are called from an ATL callback, // we don't destroy the window before the callback returned (as the caller // may delete ourselves on destroy and the ATL callback would still // dereference us when the callback returns). MessageLoop::current()->PostTask(FROM_HERE, - close_container_factory_.NewRunnableMethod( - &ContainerWin::CloseNow)); + close_widget_factory_.NewRunnableMethod( + &WidgetWin::CloseNow)); } } -void ContainerWin::Hide() { +void WidgetWin::Hide() { // NOTE: Be careful not to activate any windows here (for example, calling // ShowWindow(SW_HIDE) will automatically activate another window). This // code can be called while a window is being deactivated, and activating @@ -349,7 +349,7 @@ void ContainerWin::Hide() { SWP_NOREPOSITION | SWP_NOSIZE | SWP_NOZORDER); } -void ContainerWin::CloseNow() { +void WidgetWin::CloseNow() { // We may already have been destroyed if the selection resulted in a tab // switch which will have reactivated the browser window and closed us, so // we need to check to see if we're still a window before trying to destroy @@ -361,10 +361,10 @@ void ContainerWin::CloseNow() { /////////////////////////////////////////////////////////////////////////////// // MessageLoop::Observer -void ContainerWin::WillProcessMessage(const MSG& msg) { +void WidgetWin::WillProcessMessage(const MSG& msg) { } -void ContainerWin::DidProcessMessage(const MSG& msg) { +void WidgetWin::DidProcessMessage(const MSG& msg) { if (root_view_->NeedsPainting(true)) { PaintNow(root_view_->GetScheduledPaintRect()); } @@ -373,7 +373,7 @@ void ContainerWin::DidProcessMessage(const MSG& msg) { /////////////////////////////////////////////////////////////////////////////// // FocusTraversable -View* ContainerWin::FindNextFocusableView( +View* WidgetWin::FindNextFocusableView( View* starting_view, bool reverse, Direction direction, bool dont_loop, FocusTraversable** focus_traversable, View** focus_traversable_view) { return root_view_->FindNextFocusableView(starting_view, @@ -384,32 +384,32 @@ View* ContainerWin::FindNextFocusableView( focus_traversable_view); } -FocusTraversable* ContainerWin::GetFocusTraversableParent() { +FocusTraversable* WidgetWin::GetFocusTraversableParent() { // We are a proxy to the root view, so we should be bypassed when traversing // up and as a result this should not be called. NOTREACHED(); return NULL; } -void ContainerWin::SetFocusTraversableParent(FocusTraversable* parent) { +void WidgetWin::SetFocusTraversableParent(FocusTraversable* parent) { root_view_->SetFocusTraversableParent(parent); } -View* ContainerWin::GetFocusTraversableParentView() { +View* WidgetWin::GetFocusTraversableParentView() { // We are a proxy to the root view, so we should be bypassed when traversing // up and as a result this should not be called. NOTREACHED(); return NULL; } -void ContainerWin::SetFocusTraversableParentView(View* parent_view) { +void WidgetWin::SetFocusTraversableParentView(View* parent_view) { root_view_->SetFocusTraversableParentView(parent_view); } /////////////////////////////////////////////////////////////////////////////// // Message handlers -void ContainerWin::OnCaptureChanged(HWND hwnd) { +void WidgetWin::OnCaptureChanged(HWND hwnd) { if (has_capture_) { if (is_mouse_down_) root_view_->ProcessMouseDragCanceled(); @@ -418,11 +418,9 @@ void ContainerWin::OnCaptureChanged(HWND hwnd) { } } -void ContainerWin::OnClose() { - // WARNING: this method is NOT called for all ContainerWins. If you need to - // do cleanup code before ContainerWin is destroyed, put it in - // OnDestroy. - +void WidgetWin::OnClose() { + // WARNING: this method is NOT called for all WidgetWins. If you need to do + // cleanup code before WidgetWin is destroyed, put it in OnDestroy. NotificationService::current()->Notify( NOTIFY_WINDOW_CLOSED, Source<HWND>(hwnd_), NotificationService::NoDetails()); @@ -430,18 +428,18 @@ void ContainerWin::OnClose() { Close(); } -void ContainerWin::OnDestroy() { - root_view_->OnContainerDestroyed(); +void WidgetWin::OnDestroy() { + root_view_->OnWidgetDestroyed(); RemoveProp(hwnd_, kRootViewWindowProperty); } -LRESULT ContainerWin::OnEraseBkgnd(HDC dc) { +LRESULT WidgetWin::OnEraseBkgnd(HDC dc) { // This is needed for magical win32 flicker ju-ju return 1; } -LRESULT ContainerWin::OnGetObject(UINT uMsg, WPARAM w_param, LPARAM l_param) { +LRESULT WidgetWin::OnGetObject(UINT uMsg, WPARAM w_param, LPARAM l_param) { LRESULT reference_result = static_cast<LRESULT>(0L); // Accessibility readers will send an OBJID_CLIENT message @@ -487,58 +485,58 @@ LRESULT ContainerWin::OnGetObject(UINT uMsg, WPARAM w_param, LPARAM l_param) { return reference_result; } -void ContainerWin::OnKeyDown(TCHAR c, UINT rep_cnt, UINT flags) { +void WidgetWin::OnKeyDown(TCHAR c, UINT rep_cnt, UINT flags) { KeyEvent event(Event::ET_KEY_PRESSED, c, rep_cnt, flags); root_view_->ProcessKeyEvent(event); } -void ContainerWin::OnKeyUp(TCHAR c, UINT rep_cnt, UINT flags) { +void WidgetWin::OnKeyUp(TCHAR c, UINT rep_cnt, UINT flags) { KeyEvent event(Event::ET_KEY_RELEASED, c, rep_cnt, flags); root_view_->ProcessKeyEvent(event); } -void ContainerWin::OnLButtonDown(UINT flags, const CPoint& point) { +void WidgetWin::OnLButtonDown(UINT flags, const CPoint& point) { ProcessMousePressed(point, flags | MK_LBUTTON, false); } -void ContainerWin::OnLButtonUp(UINT flags, const CPoint& point) { +void WidgetWin::OnLButtonUp(UINT flags, const CPoint& point) { ProcessMouseReleased(point, flags | MK_LBUTTON); } -void ContainerWin::OnLButtonDblClk(UINT flags, const CPoint& point) { +void WidgetWin::OnLButtonDblClk(UINT flags, const CPoint& point) { ProcessMousePressed(point, flags | MK_LBUTTON, true); } -void ContainerWin::OnMButtonDown(UINT flags, const CPoint& point) { +void WidgetWin::OnMButtonDown(UINT flags, const CPoint& point) { ProcessMousePressed(point, flags | MK_MBUTTON, false); } -void ContainerWin::OnMButtonUp(UINT flags, const CPoint& point) { +void WidgetWin::OnMButtonUp(UINT flags, const CPoint& point) { ProcessMouseReleased(point, flags | MK_MBUTTON); } -void ContainerWin::OnMButtonDblClk(UINT flags, const CPoint& point) { +void WidgetWin::OnMButtonDblClk(UINT flags, const CPoint& point) { ProcessMousePressed(point, flags | MK_MBUTTON, true); } -LRESULT ContainerWin::OnMouseActivate(HWND window, UINT hittest_code, - UINT message) { +LRESULT WidgetWin::OnMouseActivate(HWND window, UINT hittest_code, + UINT message) { SetMsgHandled(FALSE); return MA_ACTIVATE; } -void ContainerWin::OnMouseMove(UINT flags, const CPoint& point) { +void WidgetWin::OnMouseMove(UINT flags, const CPoint& point) { ProcessMouseMoved(point, flags, false); } -LRESULT ContainerWin::OnMouseLeave(UINT uMsg, WPARAM w_param, LPARAM l_param) { +LRESULT WidgetWin::OnMouseLeave(UINT uMsg, WPARAM w_param, LPARAM l_param) { tooltip_manager_->OnMouseLeave(); ProcessMouseExited(); return 0; } -LRESULT ContainerWin::OnMouseWheel(UINT flags, short distance, - const CPoint& point) { +LRESULT WidgetWin::OnMouseWheel(UINT flags, short distance, + const CPoint& point) { MouseWheelEvent e(distance, point.x, point.y, @@ -546,43 +544,42 @@ LRESULT ContainerWin::OnMouseWheel(UINT flags, short distance, return root_view_->ProcessMouseWheelEvent(e) ? 0 : 1; } -LRESULT ContainerWin::OnMouseRange(UINT msg, WPARAM w_param, LPARAM l_param) { +LRESULT WidgetWin::OnMouseRange(UINT msg, WPARAM w_param, LPARAM l_param) { tooltip_manager_->OnMouse(msg, w_param, l_param); SetMsgHandled(FALSE); return 0; } -void ContainerWin::OnNCLButtonDblClk(UINT flags, const CPoint& point) { +void WidgetWin::OnNCLButtonDblClk(UINT flags, const CPoint& point) { SetMsgHandled(FALSE); } -void ContainerWin::OnNCLButtonDown(UINT flags, const CPoint& point) { +void WidgetWin::OnNCLButtonDown(UINT flags, const CPoint& point) { SetMsgHandled(FALSE); } -void ContainerWin::OnNCLButtonUp(UINT flags, const CPoint& point) { +void WidgetWin::OnNCLButtonUp(UINT flags, const CPoint& point) { SetMsgHandled(FALSE); } -void ContainerWin::OnNCMButtonDblClk(UINT flags, const CPoint& point) { +void WidgetWin::OnNCMButtonDblClk(UINT flags, const CPoint& point) { SetMsgHandled(FALSE); } -void ContainerWin::OnNCMButtonDown(UINT flags, const CPoint& point) { +void WidgetWin::OnNCMButtonDown(UINT flags, const CPoint& point) { SetMsgHandled(FALSE); } -void ContainerWin::OnNCMButtonUp(UINT flags, const CPoint& point) { +void WidgetWin::OnNCMButtonUp(UINT flags, const CPoint& point) { SetMsgHandled(FALSE); } -LRESULT ContainerWin::OnNCMouseLeave(UINT uMsg, WPARAM w_param, - LPARAM l_param) { +LRESULT WidgetWin::OnNCMouseLeave(UINT uMsg, WPARAM w_param, LPARAM l_param) { ProcessMouseExited(); return 0; } -LRESULT ContainerWin::OnNCMouseMove(UINT flags, const CPoint& point) { +LRESULT WidgetWin::OnNCMouseMove(UINT flags, const CPoint& point) { // NC points are in screen coordinates. CPoint temp = point; MapWindowPoints(HWND_DESKTOP, GetHWND(), &temp, 1); @@ -594,19 +591,19 @@ LRESULT ContainerWin::OnNCMouseMove(UINT flags, const CPoint& point) { return 0; } -void ContainerWin::OnNCRButtonDblClk(UINT flags, const CPoint& point) { +void WidgetWin::OnNCRButtonDblClk(UINT flags, const CPoint& point) { SetMsgHandled(FALSE); } -void ContainerWin::OnNCRButtonDown(UINT flags, const CPoint& point) { +void WidgetWin::OnNCRButtonDown(UINT flags, const CPoint& point) { SetMsgHandled(FALSE); } -void ContainerWin::OnNCRButtonUp(UINT flags, const CPoint& point) { +void WidgetWin::OnNCRButtonUp(UINT flags, const CPoint& point) { SetMsgHandled(FALSE); } -LRESULT ContainerWin::OnNotify(int w_param, NMHDR* l_param) { +LRESULT WidgetWin::OnNotify(int w_param, NMHDR* l_param) { // We can be sent this message before the tooltip manager is created, if a // subclass overrides OnCreate and creates some kind of Windows control there // that sends WM_NOTIFY messages. @@ -620,24 +617,23 @@ LRESULT ContainerWin::OnNotify(int w_param, NMHDR* l_param) { return 0; } -void ContainerWin::OnPaint(HDC dc) { +void WidgetWin::OnPaint(HDC dc) { root_view_->OnPaint(GetHWND()); } -void ContainerWin::OnRButtonDown(UINT flags, const CPoint& point) { +void WidgetWin::OnRButtonDown(UINT flags, const CPoint& point) { ProcessMousePressed(point, flags | MK_RBUTTON, false); } -void ContainerWin::OnRButtonUp(UINT flags, const CPoint& point) { +void WidgetWin::OnRButtonUp(UINT flags, const CPoint& point) { ProcessMouseReleased(point, flags | MK_RBUTTON); } -void ContainerWin::OnRButtonDblClk(UINT flags, const CPoint& point) { +void WidgetWin::OnRButtonDblClk(UINT flags, const CPoint& point) { ProcessMousePressed(point, flags | MK_RBUTTON, true); } -LRESULT ContainerWin::OnSettingChange(UINT msg, WPARAM w_param, - LPARAM l_param) { +LRESULT WidgetWin::OnSettingChange(UINT msg, WPARAM w_param, LPARAM l_param) { if (toplevel_) { SetMsgHandled(FALSE); if (w_param != SPI_SETWORKAREA) @@ -650,24 +646,24 @@ LRESULT ContainerWin::OnSettingChange(UINT msg, WPARAM w_param, return 0; } -void ContainerWin::OnSize(UINT param, const CSize& size) { +void WidgetWin::OnSize(UINT param, const CSize& size) { ChangeSize(param, size); } -void ContainerWin::OnThemeChanged() { +void WidgetWin::OnThemeChanged() { // Notify NativeTheme. gfx::NativeTheme::instance()->CloseHandles(); } -void ContainerWin::OnFinalMessage(HWND window) { +void WidgetWin::OnFinalMessage(HWND window) { if (delete_on_destroy_) delete this; } /////////////////////////////////////////////////////////////////////////////// -// ContainerWin, protected: +// WidgetWin, protected: -void ContainerWin::TrackMouseEvents(DWORD mouse_tracking_flags) { +void WidgetWin::TrackMouseEvents(DWORD mouse_tracking_flags) { // Begin tracking mouse events for this HWND so that we get WM_MOUSELEAVE // when the user moves the mouse outside this HWND's bounds. if (active_mouse_tracking_flags_ == 0 || mouse_tracking_flags & TME_CANCEL) { @@ -691,8 +687,8 @@ void ContainerWin::TrackMouseEvents(DWORD mouse_tracking_flags) { } } -bool ContainerWin::ProcessMousePressed(const CPoint& point, UINT flags, - bool dbl_click) { +bool WidgetWin::ProcessMousePressed(const CPoint& point, UINT flags, + bool dbl_click) { last_mouse_event_was_move_ = false; MouseEvent mouse_pressed(Event::ET_MOUSE_PRESSED, point.x, @@ -711,7 +707,7 @@ bool ContainerWin::ProcessMousePressed(const CPoint& point, UINT flags, return false; } -void ContainerWin::ProcessMouseDragged(const CPoint& point, UINT flags) { +void WidgetWin::ProcessMouseDragged(const CPoint& point, UINT flags) { last_mouse_event_was_move_ = false; MouseEvent mouse_drag(Event::ET_MOUSE_DRAGGED, point.x, @@ -720,7 +716,7 @@ void ContainerWin::ProcessMouseDragged(const CPoint& point, UINT flags) { root_view_->OnMouseDragged(mouse_drag); } -void ContainerWin::ProcessMouseReleased(const CPoint& point, UINT flags) { +void WidgetWin::ProcessMouseReleased(const CPoint& point, UINT flags) { last_mouse_event_was_move_ = false; MouseEvent mouse_up(Event::ET_MOUSE_RELEASED, point.x, @@ -737,8 +733,8 @@ void ContainerWin::ProcessMouseReleased(const CPoint& point, UINT flags) { root_view_->OnMouseReleased(mouse_up, false); } -void ContainerWin::ProcessMouseMoved(const CPoint &point, UINT flags, - bool is_nonclient) { +void WidgetWin::ProcessMouseMoved(const CPoint &point, UINT flags, + bool is_nonclient) { // Windows only fires WM_MOUSELEAVE events if the application begins // "tracking" mouse events for a given HWND during WM_MOUSEMOVE events. // We need to call |TrackMouseEvents| to listen for WM_MOUSELEAVE. @@ -765,15 +761,15 @@ void ContainerWin::ProcessMouseMoved(const CPoint &point, UINT flags, } } -void ContainerWin::ProcessMouseExited() { +void WidgetWin::ProcessMouseExited() { last_mouse_event_was_move_ = false; root_view_->ProcessOnMouseExited(); - // Reset our tracking flag so that future mouse movement over this - // ContainerWin results in a new tracking session. + // Reset our tracking flag so that future mouse movement over this WidgetWin + // results in a new tracking session. active_mouse_tracking_flags_ = 0; } -void ContainerWin::AdjustWindowToFitScreenSize() { +void WidgetWin::AdjustWindowToFitScreenSize() { // Desktop size has changed. Make sure we're still on screen. CRect wr; GetWindowRect(&wr); @@ -801,7 +797,7 @@ void ContainerWin::AdjustWindowToFitScreenSize() { } } -void ContainerWin::ChangeSize(UINT size_param, const CSize& size) { +void WidgetWin::ChangeSize(UINT size_param, const CSize& size) { CRect rect; if (layered_) { GetWindowRect(&rect); @@ -820,20 +816,20 @@ void ContainerWin::ChangeSize(UINT size_param, const CSize& size) { PaintNow(gfx::Rect(rect)); } -RootView* ContainerWin::CreateRootView() { +RootView* WidgetWin::CreateRootView() { return new RootView(this); } /////////////////////////////////////////////////////////////////////////////// -// ContainerWin, private: +// WidgetWin, private: -void ContainerWin::SizeContents(const CRect& window_rect) { +void WidgetWin::SizeContents(const CRect& window_rect) { contents_.reset(new ChromeCanvas(window_rect.Width(), window_rect.Height(), false)); } -void ContainerWin::PaintLayeredWindow() { +void WidgetWin::PaintLayeredWindow() { // Painting monkeys with our cliprect, so we need to save it so that the // call to UpdateLayeredWindow updates the entire window, not just the // cliprect. @@ -847,7 +843,7 @@ void ContainerWin::PaintLayeredWindow() { UpdateWindowFromContents(contents_->getTopPlatformDevice().getBitmapDC()); } -void ContainerWin::UpdateWindowFromContents(HDC dib_dc) { +void WidgetWin::UpdateWindowFromContents(HDC dib_dc) { DCHECK(layered_); if (can_update_layered_window_) { CRect wr; @@ -863,7 +859,7 @@ void ContainerWin::UpdateWindowFromContents(HDC dib_dc) { } } -std::wstring ContainerWin::GetWindowClassName() { +std::wstring WidgetWin::GetWindowClassName() { if (!registered_classes) registered_classes = new RegisteredClasses(); ClassInfo class_info(initial_class_style()); @@ -880,7 +876,7 @@ std::wstring ContainerWin::GetWindowClassName() { WNDCLASSEX class_ex; class_ex.cbSize = sizeof(WNDCLASSEX); class_ex.style = class_info.style; - class_ex.lpfnWndProc = &ContainerWin::WndProc; + class_ex.lpfnWndProc = &WidgetWin::WndProc; class_ex.cbClsExtra = 0; class_ex.cbWndExtra = 0; class_ex.hInstance = NULL; @@ -899,27 +895,26 @@ std::wstring ContainerWin::GetWindowClassName() { } // static -LRESULT CALLBACK ContainerWin::WndProc(HWND window, UINT message, - WPARAM w_param, LPARAM l_param) { +LRESULT CALLBACK WidgetWin::WndProc(HWND window, UINT message, + WPARAM w_param, LPARAM l_param) { if (message == WM_NCCREATE) { CREATESTRUCT* cs = reinterpret_cast<CREATESTRUCT*>(l_param); - ContainerWin* vc = - reinterpret_cast<ContainerWin*>(cs->lpCreateParams); - DCHECK(vc); - win_util::SetWindowUserData(window, vc); - vc->hwnd_ = window; + WidgetWin* widget = reinterpret_cast<WidgetWin*>(cs->lpCreateParams); + DCHECK(widget); + win_util::SetWindowUserData(window, widget); + widget->hwnd_ = window; return TRUE; } - ContainerWin* vc = reinterpret_cast<ContainerWin*>( + WidgetWin* widget = reinterpret_cast<WidgetWin*>( win_util::GetWindowUserData(window)); - if (!vc) + if (!widget) return 0; LRESULT result = 0; - if (!vc->ProcessWindowMessage(window, message, w_param, l_param, result)) + if (!widget->ProcessWindowMessage(window, message, w_param, l_param, result)) result = DefWindowProc(window, message, w_param, l_param); if (message == WM_NCDESTROY) { - vc->hwnd_ = NULL; - vc->OnFinalMessage(window); + widget->hwnd_ = NULL; + widget->OnFinalMessage(window); } return result; } diff --git a/chrome/views/container_win.h b/chrome/views/widget_win.h index 84309b9..9e402e8 100644 --- a/chrome/views/container_win.h +++ b/chrome/views/widget_win.h @@ -2,8 +2,8 @@ // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. -#ifndef CHROME_VIEWS_CONTAINER_WIN_H_ -#define CHROME_VIEWS_CONTAINER_WIN_H_ +#ifndef CHROME_VIEWS_WIDGET_WIN_H_ +#define CHROME_VIEWS_WIDGET_WIN_H_ #include <atlbase.h> #include <atlcrack.h> @@ -11,7 +11,7 @@ #include "base/message_loop.h" #include "chrome/views/focus_manager.h" #include "chrome/views/layout_manager.h" -#include "chrome/views/container.h" +#include "chrome/views/widget.h" class ChromeCanvas; @@ -68,34 +68,28 @@ class FillLayout : public LayoutManager { /////////////////////////////////////////////////////////////////////////////// // -// ContainerWin -// A container for a views hierarchy used to represent anything that can be +// WidgetWin +// A Widget for a views hierarchy used to represent anything that can be // contained within an HWND, e.g. a control, a window, etc. Specializations // suitable for specific tasks, e.g. top level window, are derived from this. // -// This Container contains a RootView which owns the hierarchy of views -// within it. As long as views are part of this tree, they will be deleted -// automatically when the RootView is destroyed. If you remove a view from the -// tree, you are then responsible for cleaning up after it. -// -// Note: We try and keep this API platform-neutral, since to some extent we -// consider this the boundary between the platform and potentially cross -// platform views code. In some cases this isn't true, primarily -// because of other code that has not yet been refactored to maintain -// this <controller>-<view>-<platform-specific-view> separation. +// This Widget contains a RootView which owns the hierarchy of views within it. +// As long as views are part of this tree, they will be deleted automatically +// when the RootView is destroyed. If you remove a view from the tree, you are +// then responsible for cleaning up after it. // /////////////////////////////////////////////////////////////////////////////// -class ContainerWin : public Container, - public MessageLoopForUI::Observer, - public FocusTraversable, - public AcceleratorTarget { +class WidgetWin : public Widget, + public MessageLoopForUI::Observer, + public FocusTraversable, + public AcceleratorTarget { public: - ContainerWin(); - virtual ~ContainerWin(); + WidgetWin(); + virtual ~WidgetWin(); - // Initialize the container with a parent and an initial desired size. + // Initialize the Widget with a parent and an initial desired size. // |contents_view| is the view that will be the single child of RootView - // within this Container. As contents_view is inserted into RootView's tree, + // within this Widget. As contents_view is inserted into RootView's tree, // RootView assumes ownership of this view and cleaning it up. If you remove // this view, you are responsible for its destruction. If this value is NULL, // the caller is responsible for populating the RootView, and sizing its @@ -106,10 +100,10 @@ class ContainerWin : public Container, const gfx::Rect& bounds, bool has_own_focus_manager); - // Sets the specified view as the contents of this Container. There can only - // be one contnets view child of this Container's RootView. This view is - // sized to fit the entire size of the RootView. The RootView takes ownership - // of this View, unless it is set as not being parent-owned. + // Sets the specified view as the contents of this Widget. There can only + // be one contnets view child of this Widget's RootView. This view is sized to + // fit the entire size of the RootView. The RootView takes ownership of this + // View, unless it is set as not being parent-owned. virtual void SetContentsView(View* view); // Sets the window styles. This is ONLY used when the window is created. @@ -155,11 +149,11 @@ class ContainerWin : public Container, virtual void Hide(); // Closes the window synchronously. Note that this should not be called from - // an ATL message callback as it deletes the ContainerWin and ATL will + // an ATL message callback as it deletes the WidgetWin and ATL will // dereference it after the callback is processed. void CloseNow(); - // All classes registered by ContainerWin start with this name. + // All classes registered by WidgetWin start with this name. static const wchar_t* const kBaseClassName; BEGIN_MSG_MAP_EX(0) @@ -242,7 +236,7 @@ class ContainerWin : public Container, MSG_WM_WINDOWPOSCHANGED(OnWindowPosChanged) END_MSG_MAP() - // Overridden from Container: + // Overridden from Widget: virtual void GetBounds(CRect *out, bool including_frame) const; virtual void MoveToFront(bool should_activate); virtual HWND GetHWND() const; @@ -338,8 +332,8 @@ class ContainerWin : public Container, } // Message Handlers - // These are all virtual so that specialized view containers can modify or - // augment processing. + // These are all virtual so that specialized Widgets can modify or augment + // processing. // This list is in _ALPHABETICAL_ order! // Note: in the base class these functions must do nothing but convert point // coordinates to client coordinates (if necessary) and forward the @@ -485,7 +479,7 @@ class ContainerWin : public Container, virtual RootView* CreateRootView(); - // Returns true if this ContainerWin is opaque. + // Returns true if this WidgetWin is opaque. bool opaque() const { return opaque_; } // The root of the View hierarchy attached to this window. @@ -518,7 +512,7 @@ class ContainerWin : public Container, // so that subclasses can do any cleanup they need to. void OnDestroyImpl(); - // The windows procedure used by all ContainerWins. + // The windows procedure used by all WidgetWins. static LRESULT CALLBACK WndProc(HWND window, UINT message, WPARAM w_param, @@ -528,9 +522,9 @@ class ContainerWin : public Container, // If necessary, this registers the window class. std::wstring GetWindowClassName(); - // The following factory is used for calls to close the ContainerWin + // The following factory is used for calls to close the WidgetWin // instance. - ScopedRunnableMethodFactory<ContainerWin> close_container_factory_; + ScopedRunnableMethodFactory<WidgetWin> close_widget_factory_; // The flags currently being used with TrackMouseEvent to track mouse // messages. 0 if there is no active tracking. The value of this member is @@ -589,5 +583,5 @@ class ContainerWin : public Container, } // namespace views -#endif // #ifndef CHROME_VIEWS_CONTAINER_WIN_H_ +#endif // #ifndef CHROME_VIEWS_WIDGET_WIN_H_ diff --git a/chrome/views/window.cc b/chrome/views/window.cc index e5726c8..6c61ff0 100644 --- a/chrome/views/window.cc +++ b/chrome/views/window.cc @@ -129,7 +129,7 @@ void Window::Close() { if (client_view_->CanClose()) { SaveWindowPosition(); RestoreEnabledIfNecessary(); - ContainerWin::Close(); + WidgetWin::Close(); // If the user activates another app after opening us, then comes back and // closes us, we want our owner to gain activation. But only if the owner // is visible. If we don't manually force that here, the other app will @@ -221,7 +221,7 @@ gfx::Size Window::GetLocalizedContentsSize(int col_resource_id, // Window, protected: Window::Window(WindowDelegate* window_delegate) - : ContainerWin(), + : WidgetWin(), focus_on_creation_(true), window_delegate_(window_delegate), non_client_view_(NULL), @@ -249,7 +249,7 @@ void Window::Init(HWND parent, const gfx::Rect& bounds) { // return NULL. owning_hwnd_ = parent; // We call this after initializing our members since our implementations of - // assorted ContainerWin functions may be called during initialization. + // assorted WidgetWin functions may be called during initialization. is_modal_ = window_delegate_->IsModal(); if (is_modal_) BecomeModal(); @@ -260,7 +260,7 @@ void Window::Init(HWND parent, const gfx::Rect& bounds) { if (window_ex_style() == 0) set_window_ex_style(CalculateWindowExStyle()); - ContainerWin::Init(parent, bounds, true); + WidgetWin::Init(parent, bounds, true); win_util::SetWindowUserData(GetHWND(), this); std::wstring window_title = window_delegate_->GetWindowTitle(); @@ -279,9 +279,9 @@ void Window::SetClientView(ClientView* client_view) { client_view_ = client_view; if (non_client_view_) { // This will trigger the ClientView to be added by the non-client view. - ContainerWin::SetContentsView(non_client_view_); + WidgetWin::SetContentsView(non_client_view_); } else { - ContainerWin::SetContentsView(client_view_); + WidgetWin::SetContentsView(client_view_); } } @@ -313,7 +313,7 @@ void Window::RunSystemMenu(const CPoint& point) { } /////////////////////////////////////////////////////////////////////////////// -// Window, ContainerWin overrides: +// Window, WidgetWin overrides: void Window::OnActivate(UINT action, BOOL minimized, HWND window) { if (action == WA_INACTIVE) @@ -325,13 +325,13 @@ LRESULT Window::OnAppCommand(HWND window, short app_command, WORD device, // We treat APPCOMMAND ids as an extension of our command namespace, and just // let the delegate figure out what to do... if (!window_delegate_->ExecuteWindowsCommand(app_command)) - return ContainerWin::OnAppCommand(window, app_command, device, keystate); + return WidgetWin::OnAppCommand(window, app_command, device, keystate); return 0; } void Window::OnCommand(UINT notification_code, int command_id, HWND window) { if (!window_delegate_->ExecuteWindowsCommand(command_id)) - ContainerWin::OnCommand(notification_code, command_id, window); + WidgetWin::OnCommand(notification_code, command_id, window); } void Window::OnDestroy() { @@ -340,7 +340,7 @@ void Window::OnDestroy() { window_delegate_ = NULL; } RestoreEnabledIfNecessary(); - ContainerWin::OnDestroy(); + WidgetWin::OnDestroy(); } LRESULT Window::OnNCActivate(BOOL active) { @@ -349,7 +349,7 @@ LRESULT Window::OnNCActivate(BOOL active) { return DefWindowProc(GetHWND(), WM_NCACTIVATE, TRUE, 0); } // Otherwise just do the default thing. - return ContainerWin::OnNCActivate(active); + return WidgetWin::OnNCActivate(active); } LRESULT Window::OnNCHitTest(const CPoint& point) { @@ -375,14 +375,14 @@ LRESULT Window::OnNCHitTest(const CPoint& point) { void Window::OnNCLButtonDown(UINT ht_component, const CPoint& point) { if (non_client_view_ && ht_component == HTSYSMENU) RunSystemMenu(non_client_view_->GetSystemMenuPoint()); - ContainerWin::OnNCLButtonDown(ht_component, point); + WidgetWin::OnNCLButtonDown(ht_component, point); } void Window::OnNCRButtonDown(UINT ht_component, const CPoint& point) { if (ht_component == HTCAPTION || ht_component == HTSYSMENU) { RunSystemMenu(point); } else { - ContainerWin::OnNCRButtonDown(ht_component, point); + WidgetWin::OnNCRButtonDown(ht_component, point); } } diff --git a/chrome/views/window.h b/chrome/views/window.h index 9758f9f..3a3ae7b 100644 --- a/chrome/views/window.h +++ b/chrome/views/window.h @@ -5,7 +5,7 @@ #ifndef CHROME_VIEWS_WINDOW_H__ #define CHROME_VIEWS_WINDOW_H__ -#include "chrome/views/container_win.h" +#include "chrome/views/widget_win.h" namespace gfx { class Size; @@ -26,11 +26,11 @@ class WindowDelegate; // // Window // -// A Window is a ContainerWin that has a caption and a border. The frame is +// A Window is a WidgetWIn that has a caption and a border. The frame is // rendered by the operating system. // /////////////////////////////////////////////////////////////////////////////// -class Window : public ContainerWin { +class Window : public WidgetWin { public: virtual ~Window(); @@ -146,7 +146,7 @@ class Window : public ContainerWin { // Shows the system menu at the specified screen point. void RunSystemMenu(const CPoint& point); - // Overridden from ContainerWin: + // Overridden from WidgetWin: virtual void OnActivate(UINT action, BOOL minimized, HWND window); virtual LRESULT OnAppCommand(HWND window, short app_command, WORD device, int keystate); |