OLD | NEW |
---|---|
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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 #include "ash/drag_drop/drag_drop_controller.h" | 5 #include "ash/drag_drop/drag_drop_controller.h" |
6 | 6 |
7 #include "ash/drag_drop/drag_drop_tracker.h" | 7 #include "ash/drag_drop/drag_drop_tracker.h" |
8 #include "ash/drag_drop/drag_image_view.h" | 8 #include "ash/drag_drop/drag_image_view.h" |
9 #include "ash/shell.h" | 9 #include "ash/shell.h" |
10 #include "ash/wm/coordinate_conversion.h" | 10 #include "ash/wm/coordinate_conversion.h" |
(...skipping 44 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
55 if (drag_image_.get()) | 55 if (drag_image_.get()) |
56 drag_image_.reset(); | 56 drag_image_.reset(); |
57 } | 57 } |
58 | 58 |
59 int DragDropController::StartDragAndDrop(const ui::OSExchangeData& data, | 59 int DragDropController::StartDragAndDrop(const ui::OSExchangeData& data, |
60 aura::RootWindow* root_window, | 60 aura::RootWindow* root_window, |
61 const gfx::Point& root_location, | 61 const gfx::Point& root_location, |
62 int operation) { | 62 int operation) { |
63 DCHECK(!IsDragDropInProgress()); | 63 DCHECK(!IsDragDropInProgress()); |
64 | 64 |
65 drag_cursor_ = ui::kCursorPointer; | 65 SetDragCursor(ui::kCursorPointer); |
66 drag_drop_tracker_.reset(new DragDropTracker(root_window)); | 66 drag_drop_tracker_.reset(new DragDropTracker(root_window)); |
67 | 67 |
68 drag_data_ = &data; | 68 drag_data_ = &data; |
69 drag_operation_ = operation; | 69 drag_operation_ = operation; |
70 const ui::OSExchangeDataProviderAura& provider = | 70 const ui::OSExchangeDataProviderAura& provider = |
71 static_cast<const ui::OSExchangeDataProviderAura&>(data.provider()); | 71 static_cast<const ui::OSExchangeDataProviderAura&>(data.provider()); |
72 | 72 |
73 drag_image_.reset(new DragImageView); | 73 drag_image_.reset(new DragImageView); |
74 drag_image_->SetImage(provider.drag_image()); | 74 drag_image_->SetImage(provider.drag_image()); |
75 drag_image_offset_ = provider.drag_image_offset(); | 75 drag_image_offset_ = provider.drag_image_offset(); |
(...skipping 45 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
121 drag_operation_); | 121 drag_operation_); |
122 e.set_flags(event.flags()); | 122 e.set_flags(event.flags()); |
123 int op = delegate->OnDragUpdated(e); | 123 int op = delegate->OnDragUpdated(e); |
124 gfx::NativeCursor cursor = ui::kCursorNoDrop; | 124 gfx::NativeCursor cursor = ui::kCursorNoDrop; |
125 if (op & ui::DragDropTypes::DRAG_COPY) | 125 if (op & ui::DragDropTypes::DRAG_COPY) |
126 cursor = ui::kCursorCopy; | 126 cursor = ui::kCursorCopy; |
127 else if (op & ui::DragDropTypes::DRAG_LINK) | 127 else if (op & ui::DragDropTypes::DRAG_LINK) |
128 cursor = ui::kCursorAlias; | 128 cursor = ui::kCursorAlias; |
129 else if (op & ui::DragDropTypes::DRAG_MOVE) | 129 else if (op & ui::DragDropTypes::DRAG_MOVE) |
130 cursor = ui::kCursorMove; | 130 cursor = ui::kCursorMove; |
131 drag_cursor_ = cursor; | 131 SetDragCursor(cursor); |
132 ash::Shell::GetInstance()->cursor_manager()->SetCursor(cursor); | 132 ash::Shell::GetInstance()->cursor_manager()->SetCursor(drag_cursor_); |
133 } | 133 } |
134 } | 134 } |
135 | 135 |
136 DCHECK(drag_image_.get()); | 136 DCHECK(drag_image_.get()); |
137 if (drag_image_->visible()) { | 137 if (drag_image_->visible()) { |
138 gfx::Point root_location_in_screen = event.root_location(); | 138 gfx::Point root_location_in_screen = event.root_location(); |
139 ash::wm::ConvertPointToScreen(target->GetRootWindow(), | 139 ash::wm::ConvertPointToScreen(target->GetRootWindow(), |
140 &root_location_in_screen); | 140 &root_location_in_screen); |
141 drag_image_->SetScreenPosition( | 141 drag_image_->SetScreenPosition( |
142 root_location_in_screen.Subtract(drag_image_offset_)); | 142 root_location_in_screen.Subtract(drag_image_offset_)); |
143 } | 143 } |
144 } | 144 } |
145 | 145 |
146 void DragDropController::Drop(aura::Window* target, | 146 void DragDropController::Drop(aura::Window* target, |
147 const ui::LocatedEvent& event) { | 147 const ui::LocatedEvent& event) { |
148 drag_cursor_ = ui::kCursorPointer; | 148 SetDragCursor(ui::kCursorPointer); |
149 ash::Shell::GetInstance()->cursor_manager()->SetCursor(ui::kCursorPointer); | 149 ash::Shell::GetInstance()->cursor_manager()->SetCursor(ui::kCursorPointer); |
150 aura::client::DragDropDelegate* delegate = NULL; | 150 aura::client::DragDropDelegate* delegate = NULL; |
151 | 151 |
152 // We must guarantee that a target gets a OnDragEntered before Drop. WebKit | 152 // We must guarantee that a target gets a OnDragEntered before Drop. WebKit |
153 // depends on not getting a Drop without DragEnter. This behavior is | 153 // depends on not getting a Drop without DragEnter. This behavior is |
154 // consistent with drag/drop on other platforms. | 154 // consistent with drag/drop on other platforms. |
155 if (target != drag_window_) | 155 if (target != drag_window_) |
156 DragUpdate(target, event); | 156 DragUpdate(target, event); |
157 DCHECK(target == drag_window_); | 157 DCHECK(target == drag_window_); |
158 | 158 |
159 if ((delegate = aura::client::GetDragDropDelegate(target))) { | 159 if ((delegate = aura::client::GetDragDropDelegate(target))) { |
160 ui::DropTargetEvent e( | 160 ui::DropTargetEvent e( |
161 *drag_data_, event.location(), event.root_location(), drag_operation_); | 161 *drag_data_, event.location(), event.root_location(), drag_operation_); |
162 e.set_flags(event.flags()); | 162 e.set_flags(event.flags()); |
163 drag_operation_ = delegate->OnPerformDrop(e); | 163 drag_operation_ = delegate->OnPerformDrop(e); |
164 if (drag_operation_ == 0) | 164 if (drag_operation_ == 0) |
165 StartCanceledAnimation(); | 165 StartCanceledAnimation(); |
166 else | 166 else |
167 drag_image_.reset(); | 167 drag_image_.reset(); |
168 } else { | 168 } else { |
169 drag_image_.reset(); | 169 drag_image_.reset(); |
170 } | 170 } |
171 | 171 |
172 Cleanup(); | 172 Cleanup(); |
173 if (should_block_during_drag_drop_) | 173 if (should_block_during_drag_drop_) |
174 quit_closure_.Run(); | 174 quit_closure_.Run(); |
175 } | 175 } |
176 | 176 |
177 void DragDropController::DragCancel() { | 177 void DragDropController::DragCancel() { |
178 drag_cursor_ = ui::kCursorPointer; | 178 SetDragCursor(ui::kCursorPointer); |
Daniel Erat
2012/09/06 23:47:15
Can SetDragCursor() just call ash::Shell::GetInsta
mazda
2012/09/07 02:20:57
It turned out that we don't need to set drag_curso
| |
179 ash::Shell::GetInstance()->cursor_manager()->SetCursor(ui::kCursorPointer); | 179 ash::Shell::GetInstance()->cursor_manager()->SetCursor(drag_cursor_); |
180 | 180 |
181 // |drag_window_| can be NULL if we have just started the drag and have not | 181 // |drag_window_| can be NULL if we have just started the drag and have not |
182 // received any DragUpdates, or, if the |drag_window_| gets destroyed during | 182 // received any DragUpdates, or, if the |drag_window_| gets destroyed during |
183 // a drag/drop. | 183 // a drag/drop. |
184 aura::client::DragDropDelegate* delegate = drag_window_? | 184 aura::client::DragDropDelegate* delegate = drag_window_? |
185 aura::client::GetDragDropDelegate(drag_window_) : NULL; | 185 aura::client::GetDragDropDelegate(drag_window_) : NULL; |
186 if (delegate) | 186 if (delegate) |
187 delegate->OnDragExited(); | 187 delegate->OnDragExited(); |
188 | 188 |
189 Cleanup(); | 189 Cleanup(); |
(...skipping 114 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
304 void DragDropController::Cleanup() { | 304 void DragDropController::Cleanup() { |
305 if (drag_window_) | 305 if (drag_window_) |
306 drag_window_->RemoveObserver(this); | 306 drag_window_->RemoveObserver(this); |
307 drag_window_ = NULL; | 307 drag_window_ = NULL; |
308 drag_data_ = NULL; | 308 drag_data_ = NULL; |
309 // Cleanup can be called again while deleting DragDropTracker, so use Pass | 309 // Cleanup can be called again while deleting DragDropTracker, so use Pass |
310 // instead of reset to avoid double free. | 310 // instead of reset to avoid double free. |
311 drag_drop_tracker_.Pass(); | 311 drag_drop_tracker_.Pass(); |
312 } | 312 } |
313 | 313 |
314 void DragDropController::SetDragCursor(gfx::NativeCursor cursor) { | |
315 drag_cursor_ = ash::Shell::GetInstance()->cursor_manager()-> | |
316 GetCursorFromNativeType(cursor); | |
317 } | |
318 | |
314 } // namespace internal | 319 } // namespace internal |
315 } // namespace ash | 320 } // namespace ash |
OLD | NEW |