Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(157)

Side by Side Diff: chrome/browser/gtk/tabs/dragged_tab_controller_gtk.h

Issue 6251001: Move chrome/browser/gtk/ to chrome/browser/ui/gtk/... (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src/
Patch Set: '' Created 9 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #ifndef CHROME_BROWSER_GTK_TABS_DRAGGED_TAB_CONTROLLER_GTK_H_ 5 #ifndef CHROME_BROWSER_GTK_TABS_DRAGGED_TAB_CONTROLLER_GTK_H_
6 #define CHROME_BROWSER_GTK_TABS_DRAGGED_TAB_CONTROLLER_GTK_H_ 6 #define CHROME_BROWSER_GTK_TABS_DRAGGED_TAB_CONTROLLER_GTK_H_
7 #pragma once 7 #pragma once
8 8
9 #include <gtk/gtk.h> 9 #include "chrome/browser/ui/gtk/tabs/dragged_tab_controller_gtk.h"
10 10 // TODO(msw): remove this file once all includes have been updated.
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 11
272 #endif // CHROME_BROWSER_GTK_TABS_DRAGGED_TAB_CONTROLLER_GTK_H_ 12 #endif // CHROME_BROWSER_GTK_TABS_DRAGGED_TAB_CONTROLLER_GTK_H_
OLDNEW
« no previous file with comments | « chrome/browser/gtk/tab_contents_drag_source.cc ('k') | chrome/browser/gtk/tabs/dragged_tab_controller_gtk.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698