diff options
author | erg@google.com <erg@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2008-11-04 01:29:24 +0000 |
---|---|---|
committer | erg@google.com <erg@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2008-11-04 01:29:24 +0000 |
commit | bfd3886dea49078beed60f12b2c98e180172a2e7 (patch) | |
tree | 8bf0efa36b74a03a5425cbccc4a4b46b9b8ce0b9 /chrome/browser/views/constrained_window_impl.h | |
parent | 57ecbe8836e353ba61860ca2f8ef2b6ddca75d6a (diff) | |
download | chromium_src-bfd3886dea49078beed60f12b2c98e180172a2e7.zip chromium_src-bfd3886dea49078beed60f12b2c98e180172a2e7.tar.gz chromium_src-bfd3886dea49078beed60f12b2c98e180172a2e7.tar.bz2 |
Revert change r4523 because Vista doesn't like it.
TBR=nsylvain
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@4539 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/browser/views/constrained_window_impl.h')
-rw-r--r-- | chrome/browser/views/constrained_window_impl.h | 119 |
1 files changed, 114 insertions, 5 deletions
diff --git a/chrome/browser/views/constrained_window_impl.h b/chrome/browser/views/constrained_window_impl.h index f9371fe..479b173 100644 --- a/chrome/browser/views/constrained_window_impl.h +++ b/chrome/browser/views/constrained_window_impl.h @@ -25,31 +25,77 @@ class WindowDelegate; // a child HWND with a custom window frame. // class ConstrainedWindowImpl : public ConstrainedWindow, - public views::CustomFrameWindow { + public views::CustomFrameWindow, + public TabContentsDelegate { public: virtual ~ConstrainedWindowImpl(); // Returns the TabContents that constrains this Constrained Window. TabContents* owner() const { return owner_; } + TabContents* constrained_contents() const { return constrained_contents_; } // Returns the non-client view inside this Constrained Window. // NOTE: Defining the function body here would require pulling in the // declarations of ConstrainedWindowNonClientView, as well as all the classes // it depends on, from the .cc file; the benefit isn't worth it. ConstrainedWindowNonClientView* non_client_view(); - // Overridden from views::CustomFrameWindow: - virtual void UpdateWindowTitle(); - // Overridden from ConstrainedWindow: virtual void CloseConstrainedWindow(); virtual void ActivateConstrainedWindow(); - virtual void RepositionConstrainedWindowTo(const gfx::Point& anchor_point) {} + virtual void RepositionConstrainedWindowTo(const gfx::Point& anchor_point); + virtual bool IsSuppressedConstrainedWindow() const; virtual void WasHidden(); virtual void DidBecomeSelected(); virtual std::wstring GetWindowTitle() const; + virtual void UpdateWindowTitle(); virtual const gfx::Rect& GetCurrentBounds() const; + // Overridden from PageNavigator (TabContentsDelegate's base interface): + virtual void OpenURLFromTab(TabContents* source, + const GURL& url, + const GURL& referrer, + WindowOpenDisposition disposition, + PageTransition::Type transition); + + // Overridden from TabContentsDelegate: + virtual void NavigationStateChanged(const TabContents* source, + unsigned changed_flags); + virtual void ReplaceContents(TabContents* source, + TabContents* new_contents); + virtual void AddNewContents(TabContents* source, + TabContents* new_contents, + WindowOpenDisposition disposition, + const gfx::Rect& initial_pos, + bool user_gesture); + virtual void ActivateContents(TabContents* contents); + virtual void LoadingStateChanged(TabContents* source); + virtual void CloseContents(TabContents* source); + virtual void MoveContents(TabContents* source, const gfx::Rect& pos); + virtual bool IsPopup(TabContents* source); + virtual TabContents* GetConstrainingContents(TabContents* source); + virtual void ToolbarSizeChanged(TabContents* source, bool is_animating); + virtual void URLStarredChanged(TabContents* source, bool) {} + virtual void UpdateTargetURL(TabContents* source, const GURL& url) {} + virtual bool CanBlur() const { return false; } + + virtual void NavigateToPage(TabContents* source, const GURL& url, + PageTransition::Type transition); + + + bool is_dialog() { return is_dialog_; } + + // Changes the visibility of the titlebar. |percentage| is a real + // number ranged 0,1. + void SetTitlebarVisibilityPercentage(double percentage); + + // Starts a ConstrainedWindowAnimation to slide in the titlebar of + // this suppressed constrained popup window. + void StartSuppressedAnimation(); + + // Stops the ConstrainedWindowAnimation, making the entire titlebar visible. + void StopSuppressedAnimationIfRunning(); + protected: // Windows message handlers: virtual void OnDestroy(); @@ -64,23 +110,78 @@ class ConstrainedWindowImpl : public ConstrainedWindow, // Use the static factory methods on ConstrainedWindow to construct a // ConstrainedWindow. ConstrainedWindowImpl(TabContents* owner, + views::WindowDelegate* window_delegate, + TabContents* constrained_contents); + ConstrainedWindowImpl(TabContents* owner, views::WindowDelegate* window_delegate); void Init(TabContents* owner); + // Called after changing either the anchor point or titlebar + // visibility of a suppressed popup. + // + // @see RepositionConstrainedWindowTo + // @see SetTitlebarVisibilityPercentage + void ResizeConstrainedTitlebar(); + + // Called to change the size of a constrained window. Moves the + // window to the anchor point (taking titlebar visibility into + // account) and sets the pop up size. + void ResizeConstrainedWindow(int width, int height); + // Initialize the Constrained Window as a Constrained Dialog containing a // views::View client area. void InitAsDialog(const gfx::Rect& initial_bounds); + // Builds the underlying HWND and window delegates for a newly + // created popup window. + // + // We have to split the initialization process for a popup window in + // two because we first need to initialize a proper window delegate + // so that when we query for desired size, we get accurate data. If + // we didn't do this, windows will initialize to being smaller then + // the desired content size plus room for browser chrome. + void InitWindowForContents(TabContents* constrained_contents, + ConstrainedTabContentsWindowDelegate* delegate); + + // Sets the initial bounds for a newly created popup window. + // + // This is the second part of the initialization process started + // with InitWindowForContents. For the parameter initial_bounds to + // have been calculated correctly, InitWindowForContents must have + // been run first. + void InitSizeForContents(const gfx::Rect& initial_bounds); + + // Returns true if the Constrained Window can be detached from its owner. + bool CanDetach() const; + + // Detach the Constrained TabContents from its owner. + void Detach(); + // Updates the portions of the UI as specified in |changed_flags|. void UpdateUI(unsigned int changed_flags); + // Place and size the window, constraining to the bounds of the |owner_|. + void SetWindowBounds(const gfx::Rect& bounds); + // The TabContents that owns and constrains this ConstrainedWindow. TabContents* owner_; + // The TabContents constrained by |owner_|. + TabContents* constrained_contents_; + // True if focus should not be restored to whatever view was focused last // when this window is destroyed. bool focus_restoration_disabled_; + // A default views::WindowDelegate implementation for this window when + // a TabContents is being constrained. (For the Constrained Dialog case, the + // caller is required to provide the WindowDelegate). + scoped_ptr<views::WindowDelegate> contents_window_delegate_; + + // We keep a reference on the HWNDView so we can properly detach the tab + // contents when detaching. + views::HWNDView* contents_container_; + // true if this window is really a constrained dialog. This is set by // InitAsDialog(). bool is_dialog_; @@ -89,6 +190,14 @@ class ConstrainedWindowImpl : public ConstrainedWindow, // the constrained title bar. gfx::Point anchor_point_; + // The 0,1 percentage representing what amount of a titlebar of a + // suppressed popup window should be visible. Used to animate those + // titlebars in. + double titlebar_visibility_; + + // The animation class which animates constrained windows onto the page. + scoped_ptr<ConstrainedWindowAnimation> animation_; + // Current display rectangle (relative to owner_'s visible area). gfx::Rect current_bounds_; |