// 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_WINDOW_H__ #define CHROME_VIEWS_WINDOW_H__ #include "chrome/common/notification_registrar.h" #include "chrome/views/widget_win.h" namespace gfx { class Size; class Path; class Point; }; class PrefService; namespace views { class ClientView; class Client; class NonClientView; class WindowDelegate; /////////////////////////////////////////////////////////////////////////////// // // Window // // A Window is a WidgetWIn that has a caption and a border. The frame is // rendered by the operating system. // /////////////////////////////////////////////////////////////////////////////// class Window : public WidgetWin, public NotificationObserver { public: virtual ~Window(); // Creates the appropriate Window class for a Chrome dialog or window. This // means a ChromeWindow or a standard Windows frame. static Window* CreateChromeWindow(HWND parent, const gfx::Rect& bounds, WindowDelegate* window_delegate); // Return the size of window (including non-client area) required to contain // a window of the specified client size. virtual gfx::Size CalculateWindowSizeForClientSize( const gfx::Size& client_size) const; // Return the maximum size possible size the window should be have if it is // to be positioned within the bounds of the current "work area" (screen or // parent window). gfx::Size CalculateMaximumSize() const; // Show the window. void Show(); void Show(int show_state); // Retrieve the show state of the window. This is one of the SW_SHOW* flags // passed into Windows' ShowWindow method. For normal windows this defaults // to SW_SHOWNORMAL, however windows (e.g. the main window) can override this // method to provide different values (e.g. retrieve the user's specified // show state from the shortcut starutp info). virtual int GetShowState() const; // Activate the window, assuming it already exists and is visible. void Activate(); // Sizes and/or places the window to the specified bounds, size or position. void SetBounds(const gfx::Rect& bounds); // As above, except the window is inserted after |other_hwnd| in the window // Z-order. If this window's HWND is not yet visible, other_hwnd's monitor // is used as the constraining rectangle, rather than this window's hwnd's // monitor. void SetBounds(const gfx::Rect& bounds, HWND other_hwnd); // Closes the window, ultimately destroying it. virtual void Close(); // Whether or not the window is maximized or minimized. bool IsMaximized() const; bool IsMinimized() const; // Toggles the enable state for the Close button (and the Close menu item in // the system menu). virtual void EnableClose(bool enable); // Prevents the window from being rendered as deactivated when |disable| is // true, until called with |disable| false. Used when a sub-window is to be // shown that shouldn't visually de-activate the window. // Subclasses can override this to perform additional actions when this value // changes. virtual void DisableInactiveRendering(bool disable); WindowDelegate* window_delegate() const { return window_delegate_; } // Returns the ClientView object used by this Window. ClientView* client_view() const { return client_view_; } void set_focus_on_creation(bool focus_on_creation) { focus_on_creation_ = focus_on_creation; } // Tell the window to update its title from the delegate. virtual void UpdateWindowTitle(); // Tell the window to update its icon from the delegate. virtual void UpdateWindowIcon(); // Executes the specified SC_command. void ExecuteSystemMenuCommand(int command); // The parent of this window. HWND owning_window() const { return owning_hwnd_; } // Returns the preferred size of the contents view of this window based on // its localized size data. The width in cols is held in a localized string // resource identified by |col_resource_id|, the height in the same fashion. // TODO(beng): This should eventually live somewhere else, probably closer to // ClientView. static int GetLocalizedContentsWidth(int col_resource_id); static int GetLocalizedContentsHeight(int row_resource_id); static gfx::Size GetLocalizedContentsSize(int col_resource_id, int row_resource_id); // NotificationObserver overrides: virtual void Observe(NotificationType type, const NotificationSource& source, const NotificationDetails& details); protected: // Constructs the Window. |window_delegate| cannot be NULL. explicit Window(WindowDelegate* window_delegate); // Create the Window. // If parent is NULL, this Window is top level on the desktop. // If |bounds| is empty, the view is queried for its preferred size and // centered on screen. virtual void Init(HWND parent, const gfx::Rect& bounds); // Sets the specified view as the ClientView of this Window. The ClientView // is responsible for laying out the Window's contents view, as well as // performing basic hit-testing, and perhaps other responsibilities depending // on the implementation. The Window's view hierarchy takes ownership of the // ClientView unless the ClientView specifies otherwise. This must be called // only once, and after the native window has been created. // This is called by Init. |client_view| cannot be NULL. virtual void SetClientView(ClientView* client_view); // Sizes the window to the default size specified by its ClientView. virtual void SizeWindowToDefault(); // Returns true if the Window is considered to be an "app window" - i.e. any // window which when it is the last of its type closed causes the application // to exit. virtual bool IsAppWindow() const { return false; } void set_client_view(ClientView* client_view) { client_view_ = client_view; } // Shows the system menu at the specified screen point. void RunSystemMenu(const CPoint& point); // Overridden from WidgetWin: virtual void OnActivate(UINT action, BOOL minimized, HWND window); virtual LRESULT OnAppCommand(HWND window, short app_command, WORD device, int keystate); virtual void OnCommand(UINT notification_code, int command_id, HWND window); virtual void OnDestroy(); virtual LRESULT OnNCActivate(BOOL active); virtual LRESULT OnNCHitTest(const CPoint& point); virtual void OnNCLButtonDown(UINT ht_component, const CPoint& point); virtual void OnNCRButtonDown(UINT ht_component, const CPoint& point); virtual LRESULT OnSetCursor(HWND window, UINT hittest_code, UINT message); virtual void OnSize(UINT size_param, const CSize& new_size); virtual void OnSysCommand(UINT notification_code, CPoint click); // The View that provides the non-client area of the window (title bar, // window controls, sizing borders etc). To use an implementation other than // the default, this class must be subclassed and this value set to the // desired implementation before calling |Init|. NonClientView* non_client_view_; // Accessor for disable_inactive_rendering_. bool disable_inactive_rendering() const { return disable_inactive_rendering_; } private: // Set the window as modal (by disabling all the other windows). void BecomeModal(); // Sets-up the focus manager with the view that should have focus when the // window is shown the first time. If NULL is returned, the focus goes to the // button if there is one, otherwise the to the Cancel button. void SetInitialFocus(); // Place and size the window when it is created. |create_bounds| are the // bounds used when the window was created. void SetInitialBounds(const gfx::Rect& create_bounds); // Restore saved always on stop state and add the always on top system menu // if needed. void InitAlwaysOnTopState(); // Add an item for "Always on Top" to the System Menu. void AddAlwaysOnTopSystemMenuItem(); // If necessary, enables all ancestors. void RestoreEnabledIfNecessary(); // Update the window style to reflect the always on top state. void AlwaysOnTopChanged(); // Calculate the appropriate window styles for this window. DWORD CalculateWindowStyle(); DWORD CalculateWindowExStyle(); // Asks the delegate if any to save the window's location and size. void SaveWindowPosition(); // Static resource initialization. static void InitClass(); static HCURSOR nwse_cursor_; // A ClientView object or subclass, responsible for sizing the contents view // of the window, hit testing and perhaps other tasks depending on the // implementation. ClientView* client_view_; // Our window delegate (see Init method for documentation). WindowDelegate* window_delegate_; // Whether we should SetFocus() on a newly created window after // Init(). Defaults to true. bool focus_on_creation_; // We need to save the parent window that spawned us, since GetParent() // returns NULL for dialogs. HWND owning_hwnd_; // The smallest size the window can be. CSize minimum_size_; // Whether or not the window is modal. This comes from the delegate and is // cached at Init time to avoid calling back to the delegate from the // destructor. bool is_modal_; // Whether all ancestors have been enabled. This is only used if is_modal_ is // true. bool restored_enabled_; // Whether the window is currently always on top. bool is_always_on_top_; // We need to own the text of the menu, the Windows API does not copy it. std::wstring always_on_top_menu_text_; // Set to true if the window is in the process of closing . bool window_closed_; // True when the window should be rendered as active, regardless of whether // or not it actually is. bool disable_inactive_rendering_; // The saved maximized state for this window. See note in SetInitialBounds // that explains why we save this. bool saved_maximized_state_; // Hold onto notifications. NotificationRegistrar notification_registrar_; DISALLOW_EVIL_CONSTRUCTORS(Window); }; } // namespace views #endif // CHROME_VIEWS_WINDOW_H__