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

Side by Side Diff: ash/drag_drop/drag_drop_tracker.cc

Issue 2900423002: [mus+ash] Removes WmWindow from ash/wm/root_window_finder.h (Closed)
Patch Set: Remove WmWindow from ash/wm/root_window_finder.h (tab drag test) Created 3 years, 7 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
« no previous file with comments | « ash/display/screen_ash.cc ('k') | ash/extended_desktop_unittest.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
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_tracker.h" 5 #include "ash/drag_drop/drag_drop_tracker.h"
6 6
7 #include "ash/public/cpp/shell_window_ids.h" 7 #include "ash/public/cpp/shell_window_ids.h"
8 #include "ash/shell.h" 8 #include "ash/shell.h"
9 #include "ash/wm/root_window_finder.h" 9 #include "ash/wm/root_window_finder.h"
10 #include "ash/wm_window.h"
11 #include "ui/aura/client/window_parenting_client.h" 10 #include "ui/aura/client/window_parenting_client.h"
12 #include "ui/aura/window.h" 11 #include "ui/aura/window.h"
13 #include "ui/aura/window_event_dispatcher.h" 12 #include "ui/aura/window_event_dispatcher.h"
14 #include "ui/events/event.h" 13 #include "ui/events/event.h"
15 #include "ui/events/event_utils.h" 14 #include "ui/events/event_utils.h"
16 #include "ui/wm/core/coordinate_conversion.h" 15 #include "ui/wm/core/coordinate_conversion.h"
17 #include "ui/wm/public/activation_delegate.h" 16 #include "ui/wm/public/activation_delegate.h"
18 17
19 namespace ash { 18 namespace ash {
20 namespace { 19 namespace {
(...skipping 41 matching lines...) Expand 10 before | Expand all | Expand 10 after
62 } 61 }
63 62
64 void DragDropTracker::TakeCapture() { 63 void DragDropTracker::TakeCapture() {
65 capture_window_->SetCapture(); 64 capture_window_->SetCapture();
66 } 65 }
67 66
68 aura::Window* DragDropTracker::GetTarget(const ui::LocatedEvent& event) { 67 aura::Window* DragDropTracker::GetTarget(const ui::LocatedEvent& event) {
69 DCHECK(capture_window_.get()); 68 DCHECK(capture_window_.get());
70 gfx::Point location_in_screen = event.location(); 69 gfx::Point location_in_screen = event.location();
71 ::wm::ConvertPointToScreen(capture_window_.get(), &location_in_screen); 70 ::wm::ConvertPointToScreen(capture_window_.get(), &location_in_screen);
72 aura::Window* root_window_at_point = 71 aura::Window* root_window_at_point = wm::GetRootWindowAt(location_in_screen);
73 WmWindow::GetAuraWindow(wm::GetRootWindowAt(location_in_screen));
74 gfx::Point location_in_root = location_in_screen; 72 gfx::Point location_in_root = location_in_screen;
75 ::wm::ConvertPointFromScreen(root_window_at_point, &location_in_root); 73 ::wm::ConvertPointFromScreen(root_window_at_point, &location_in_root);
76 return root_window_at_point->GetEventHandlerForPoint(location_in_root); 74 return root_window_at_point->GetEventHandlerForPoint(location_in_root);
77 } 75 }
78 76
79 ui::LocatedEvent* DragDropTracker::ConvertEvent(aura::Window* target, 77 ui::LocatedEvent* DragDropTracker::ConvertEvent(aura::Window* target,
80 const ui::LocatedEvent& event) { 78 const ui::LocatedEvent& event) {
81 DCHECK(capture_window_.get()); 79 DCHECK(capture_window_.get());
82 gfx::Point target_location = event.location(); 80 gfx::Point target_location = event.location();
83 aura::Window::ConvertPointToTarget(capture_window_.get(), target, 81 aura::Window::ConvertPointToTarget(capture_window_.get(), target,
84 &target_location); 82 &target_location);
85 gfx::Point location_in_screen = event.location(); 83 gfx::Point location_in_screen = event.location();
86 ::wm::ConvertPointToScreen(capture_window_.get(), &location_in_screen); 84 ::wm::ConvertPointToScreen(capture_window_.get(), &location_in_screen);
87 gfx::Point target_root_location = event.root_location(); 85 gfx::Point target_root_location = event.root_location();
88 aura::Window::ConvertPointToTarget( 86 aura::Window::ConvertPointToTarget(capture_window_->GetRootWindow(),
89 capture_window_->GetRootWindow(), 87 wm::GetRootWindowAt(location_in_screen),
90 WmWindow::GetAuraWindow(wm::GetRootWindowAt(location_in_screen)), 88 &target_root_location);
91 &target_root_location);
92 return new ui::MouseEvent( 89 return new ui::MouseEvent(
93 event.type(), target_location, target_root_location, 90 event.type(), target_location, target_root_location,
94 ui::EventTimeForNow(), event.flags(), 91 ui::EventTimeForNow(), event.flags(),
95 static_cast<const ui::MouseEvent&>(event).changed_button_flags()); 92 static_cast<const ui::MouseEvent&>(event).changed_button_flags());
96 } 93 }
97 94
98 } // namespace ash 95 } // namespace ash
OLDNEW
« no previous file with comments | « ash/display/screen_ash.cc ('k') | ash/extended_desktop_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698