OLD | NEW |
(Empty) | |
| 1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. |
| 4 |
| 5 #ifndef CHROME_BROWSER_UI_GTK_TABS_DRAGGED_TAB_CONTROLLER_GTK_H_ |
| 6 #define CHROME_BROWSER_UI_GTK_TABS_DRAGGED_TAB_CONTROLLER_GTK_H_ |
| 7 #pragma once |
| 8 |
| 9 #include <gtk/gtk.h> |
| 10 |
| 11 #include <set> |
| 12 |
| 13 #include "app/x11_util.h" |
| 14 #include "base/scoped_ptr.h" |
| 15 #include "base/timer.h" |
| 16 #include "chrome/browser/tab_contents/tab_contents_delegate.h" |
| 17 #include "chrome/browser/ui/tabs/dock_info.h" |
| 18 #include "chrome/common/notification_observer.h" |
| 19 #include "chrome/common/notification_registrar.h" |
| 20 |
| 21 class DraggedTabGtk; |
| 22 class TabGtk; |
| 23 class TabStripGtk; |
| 24 class TabContentsWrapper; |
| 25 |
| 26 class DraggedTabControllerGtk : public NotificationObserver, |
| 27 public TabContentsDelegate { |
| 28 public: |
| 29 DraggedTabControllerGtk(TabGtk* source_tab, TabStripGtk* source_tabstrip); |
| 30 virtual ~DraggedTabControllerGtk(); |
| 31 |
| 32 // Capture information needed to be used during a drag session for this |
| 33 // controller's associated source Tab and TabStrip. |mouse_offset| is the |
| 34 // distance of the mouse pointer from the Tab's origin. |
| 35 void CaptureDragInfo(const gfx::Point& mouse_offset); |
| 36 |
| 37 // Responds to drag events subsequent to StartDrag. If the mouse moves a |
| 38 // sufficient distance before the mouse is released, a drag session is |
| 39 // initiated. |
| 40 void Drag(); |
| 41 |
| 42 // Complete the current drag session. If the drag session was canceled |
| 43 // because the user pressed Escape or something interrupted it, |canceled| |
| 44 // is true so the helper can revert the state to the world before the drag |
| 45 // begun. Returns whether the tab has been destroyed. |
| 46 bool EndDrag(bool canceled); |
| 47 |
| 48 // Retrieve the source tab if the TabContents specified matches the one being |
| 49 // dragged by this controller, or NULL if the specified TabContents is not |
| 50 // the same as the one being dragged. |
| 51 TabGtk* GetDragSourceTabForContents(TabContents* contents) const; |
| 52 |
| 53 // Returns true if the specified tab matches the tab being dragged. |
| 54 bool IsDragSourceTab(const TabGtk* tab) const; |
| 55 |
| 56 // Returns true if the specified tab is detached. |
| 57 bool IsTabDetached(const TabGtk* tab) const; |
| 58 |
| 59 private: |
| 60 // Enumeration of the ways a drag session can end. |
| 61 enum EndDragType { |
| 62 // Drag session exited normally: the user released the mouse. |
| 63 NORMAL, |
| 64 |
| 65 // The drag session was canceled (alt-tab during drag, escape ...) |
| 66 CANCELED, |
| 67 |
| 68 // The tab (NavigationController) was destroyed during the drag. |
| 69 TAB_DESTROYED |
| 70 }; |
| 71 |
| 72 // Overridden from TabContentsDelegate: |
| 73 virtual void OpenURLFromTab(TabContents* source, |
| 74 const GURL& url, |
| 75 const GURL& referrer, |
| 76 WindowOpenDisposition disposition, |
| 77 PageTransition::Type transition); |
| 78 virtual void NavigationStateChanged(const TabContents* source, |
| 79 unsigned changed_flags); |
| 80 virtual void AddNewContents(TabContents* source, |
| 81 TabContents* new_contents, |
| 82 WindowOpenDisposition disposition, |
| 83 const gfx::Rect& initial_pos, |
| 84 bool user_gesture); |
| 85 virtual void ActivateContents(TabContents* contents); |
| 86 virtual void DeactivateContents(TabContents* contents); |
| 87 virtual void LoadingStateChanged(TabContents* source); |
| 88 virtual void CloseContents(TabContents* source); |
| 89 virtual void MoveContents(TabContents* source, const gfx::Rect& pos); |
| 90 virtual bool IsPopup(TabContents* source); |
| 91 virtual void ToolbarSizeChanged(TabContents* source, bool is_animating); |
| 92 virtual void URLStarredChanged(TabContents* source, bool starred); |
| 93 virtual void UpdateTargetURL(TabContents* source, const GURL& url); |
| 94 |
| 95 // Overridden from NotificationObserver: |
| 96 virtual void Observe(NotificationType type, |
| 97 const NotificationSource& source, |
| 98 const NotificationDetails& details); |
| 99 |
| 100 // Initialize the offset used to calculate the position to create windows |
| 101 // in |GetWindowCreatePoint|. |
| 102 void InitWindowCreatePoint(); |
| 103 |
| 104 // Returns the point where a detached window should be created given the |
| 105 // current mouse position. |
| 106 gfx::Point GetWindowCreatePoint() const; |
| 107 |
| 108 // Sets the TabContents being dragged with the specified |new_contents|. |
| 109 void SetDraggedContents(TabContentsWrapper* new_contents); |
| 110 |
| 111 // Move the DraggedTabView according to the current mouse screen position, |
| 112 // potentially updating the source and other TabStrips. |
| 113 void ContinueDragging(); |
| 114 |
| 115 // Handles moving the Tab within a TabStrip as well as updating the View. |
| 116 void MoveTab(const gfx::Point& screen_point); |
| 117 |
| 118 // Returns the compatible TabStrip that is under the specified point (screen |
| 119 // coordinates), or NULL if there is none. |
| 120 TabStripGtk* GetTabStripForPoint(const gfx::Point& screen_point); |
| 121 |
| 122 // Returns the specified |tabstrip| if it contains the specified point |
| 123 // (screen coordinates), NULL if it does not. |
| 124 TabStripGtk* GetTabStripIfItContains(TabStripGtk* tabstrip, |
| 125 const gfx::Point& screen_point) const; |
| 126 |
| 127 // Attach the dragged Tab to the specified TabStrip. |
| 128 void Attach(TabStripGtk* attached_tabstrip, const gfx::Point& screen_point); |
| 129 |
| 130 // Detach the dragged Tab from the current TabStrip. |
| 131 void Detach(); |
| 132 |
| 133 // Converts a screen point to a point relative to the tab strip. |
| 134 gfx::Point ConvertScreenPointToTabStripPoint(TabStripGtk* tabstrip, |
| 135 const gfx::Point& screen_point); |
| 136 |
| 137 // Retrieve the bounds of the DraggedTabGtk, relative to the attached |
| 138 // TabStrip, given location of the dragged tab in screen coordinates. |
| 139 gfx::Rect GetDraggedTabTabStripBounds(const gfx::Point& screen_point); |
| 140 |
| 141 // Returns the index where the dragged TabContents should be inserted into |
| 142 // the attached TabStripModel given the DraggedTabView's bounds |
| 143 // |dragged_bounds| in coordinates relative to the attached TabStrip. |
| 144 // |is_tab_attached| is true if the tab has already been added. |
| 145 int GetInsertionIndexForDraggedBounds(const gfx::Rect& dragged_bounds, |
| 146 bool is_tab_attached) const; |
| 147 |
| 148 // Get the position of the dragged tab relative to the attached tab strip. |
| 149 gfx::Point GetDraggedTabPoint(const gfx::Point& screen_point); |
| 150 |
| 151 // Finds the Tab within the specified TabStrip that corresponds to the |
| 152 // dragged TabContents. |
| 153 TabGtk* GetTabMatchingDraggedContents(TabStripGtk* tabstrip) const; |
| 154 |
| 155 // Does the work for EndDrag. Returns whether the tab has been destroyed. |
| 156 bool EndDragImpl(EndDragType how_end); |
| 157 |
| 158 // If the drag was aborted for some reason, this function is called to un-do |
| 159 // the changes made during the drag operation. |
| 160 void RevertDrag(); |
| 161 |
| 162 // Finishes the drag operation. Returns true if the drag controller should |
| 163 // be destroyed immediately, false otherwise. |
| 164 bool CompleteDrag(); |
| 165 |
| 166 // Create the DraggedTabGtk if it does not yet exist. |
| 167 void EnsureDraggedTab(); |
| 168 |
| 169 // Utility for getting the mouse position in screen coordinates. |
| 170 gfx::Point GetCursorScreenPoint() const; |
| 171 |
| 172 // Gets the screen bounds of a tab. |
| 173 static gfx::Rect GetTabScreenBounds(TabGtk* tab); |
| 174 |
| 175 // Utility to convert the specified TabStripModel index to something valid |
| 176 // for the attached TabStrip. |
| 177 int NormalizeIndexToAttachedTabStrip(int index) const; |
| 178 |
| 179 // Hides the window that contains the tab strip the current drag session was |
| 180 // initiated from. |
| 181 void HideWindow(); |
| 182 |
| 183 // Presents the window that was hidden by HideWindow. |
| 184 void ShowWindow(); |
| 185 |
| 186 // Closes a hidden frame at the end of a drag session. |
| 187 void CleanUpHiddenFrame(); |
| 188 |
| 189 // Cleans up a source tab that is no longer used. |
| 190 void CleanUpSourceTab(); |
| 191 |
| 192 // Completes the drag session after the view has animated to its final |
| 193 // position. |
| 194 void OnAnimateToBoundsComplete(); |
| 195 |
| 196 // Activates whichever window is under the mouse. |
| 197 void BringWindowUnderMouseToFront(); |
| 198 |
| 199 // Handles registering for notifications. |
| 200 NotificationRegistrar registrar_; |
| 201 |
| 202 // The TabContents being dragged. |
| 203 TabContentsWrapper* dragged_contents_; |
| 204 |
| 205 // The original TabContentsDelegate of |dragged_contents_|, before it was |
| 206 // detached from the browser window. We store this so that we can forward |
| 207 // certain delegate notifications back to it if we can't handle them locally. |
| 208 TabContentsDelegate* original_delegate_; |
| 209 |
| 210 // The tab that initiated the drag session. |
| 211 TabGtk* source_tab_; |
| 212 |
| 213 // The tab strip |source_tab_| originated from. |
| 214 TabStripGtk* source_tabstrip_; |
| 215 |
| 216 // This is the index of the |source_tab_| in |source_tabstrip_| when the drag |
| 217 // began. This is used to restore the previous state if the drag is aborted. |
| 218 int source_model_index_; |
| 219 |
| 220 // The TabStrip the dragged Tab is currently attached to, or NULL if the |
| 221 // dragged Tab is detached. |
| 222 TabStripGtk* attached_tabstrip_; |
| 223 |
| 224 // The visual representation of the dragged Tab. |
| 225 scoped_ptr<DraggedTabGtk> dragged_tab_; |
| 226 |
| 227 // The position of the mouse (in screen coordinates) at the start of the drag |
| 228 // operation. This is used to calculate minimum elasticity before a |
| 229 // DraggedTabView is constructed. |
| 230 gfx::Point start_screen_point_; |
| 231 |
| 232 // This is the offset of the mouse from the top left of the Tab where |
| 233 // dragging begun. This is used to ensure that the dragged view is always |
| 234 // positioned at the correct location during the drag, and to ensure that the |
| 235 // detached window is created at the right location. |
| 236 gfx::Point mouse_offset_; |
| 237 |
| 238 // A hint to use when positioning new windows created by detaching Tabs. This |
| 239 // is the distance of the mouse from the top left of the dragged tab as if it |
| 240 // were the distance of the mouse from the top left of the first tab in the |
| 241 // attached TabStrip from the top left of the window. |
| 242 gfx::Point window_create_point_; |
| 243 |
| 244 // Whether we're in the destructor or not. Makes sure we don't destroy the |
| 245 // drag controller more than once. |
| 246 bool in_destructor_; |
| 247 |
| 248 // The horizontal position of the mouse cursor in screen coordinates at the |
| 249 // time of the last re-order event. |
| 250 int last_move_screen_x_; |
| 251 |
| 252 // DockInfo for the tabstrip. |
| 253 DockInfo dock_info_; |
| 254 |
| 255 typedef std::set<GtkWidget*> DockWindows; |
| 256 DockWindows dock_windows_; |
| 257 |
| 258 // Is the tab mini? |
| 259 const bool mini_; |
| 260 |
| 261 // Is the tab pinned? |
| 262 const bool pinned_; |
| 263 |
| 264 // Timer used to bring the window under the cursor to front. If the user |
| 265 // stops moving the mouse for a brief time over a browser window, it is |
| 266 // brought to front. |
| 267 base::OneShotTimer<DraggedTabControllerGtk> bring_to_front_timer_; |
| 268 |
| 269 DISALLOW_COPY_AND_ASSIGN(DraggedTabControllerGtk); |
| 270 }; |
| 271 |
| 272 #endif // CHROME_BROWSER_UI_GTK_TABS_DRAGGED_TAB_CONTROLLER_GTK_H_ |
OLD | NEW |