OLD | NEW |
1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 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/devtools/ash_devtools_dom_agent.h" | 5 #include "ash/devtools/ash_devtools_dom_agent.h" |
6 | 6 |
7 #include "ash/public/cpp/shell_window_ids.h" | 7 #include "ash/public/cpp/shell_window_ids.h" |
8 #include "ash/root_window_controller.h" | 8 #include "ash/root_window_controller.h" |
9 #include "ash/shell.h" | 9 #include "ash/shell.h" |
10 #include "ash/wm_window.h" | |
11 #include "components/ui_devtools/devtools_server.h" | 10 #include "components/ui_devtools/devtools_server.h" |
12 #include "third_party/skia/include/core/SkColor.h" | 11 #include "third_party/skia/include/core/SkColor.h" |
| 12 #include "ui/aura/window.h" |
13 #include "ui/display/display.h" | 13 #include "ui/display/display.h" |
14 #include "ui/views/background.h" | 14 #include "ui/views/background.h" |
15 #include "ui/views/border.h" | 15 #include "ui/views/border.h" |
| 16 #include "ui/wm/core/window_util.h" |
16 | 17 |
17 namespace ash { | 18 namespace ash { |
18 namespace devtools { | 19 namespace devtools { |
19 | 20 |
20 namespace { | 21 namespace { |
21 using namespace ui::devtools::protocol; | 22 using namespace ui::devtools::protocol; |
22 // TODO(mhashmi): Make ids reusable | 23 // TODO(mhashmi): Make ids reusable |
23 DOM::NodeId node_ids = 1; | 24 DOM::NodeId node_ids = 1; |
24 | 25 |
25 std::unique_ptr<DOM::Node> BuildNode( | 26 std::unique_ptr<DOM::Node> BuildNode( |
26 const std::string& name, | 27 const std::string& name, |
27 std::unique_ptr<Array<std::string>> attributes, | 28 std::unique_ptr<Array<std::string>> attributes, |
28 std::unique_ptr<Array<DOM::Node>> children) { | 29 std::unique_ptr<Array<DOM::Node>> children) { |
29 constexpr int kDomElementNodeType = 1; | 30 constexpr int kDomElementNodeType = 1; |
30 std::unique_ptr<DOM::Node> node = DOM::Node::create() | 31 std::unique_ptr<DOM::Node> node = DOM::Node::create() |
31 .setNodeId(node_ids++) | 32 .setNodeId(node_ids++) |
32 .setNodeName(name) | 33 .setNodeName(name) |
33 .setNodeType(kDomElementNodeType) | 34 .setNodeType(kDomElementNodeType) |
34 .setAttributes(std::move(attributes)) | 35 .setAttributes(std::move(attributes)) |
35 .build(); | 36 .build(); |
36 node->setChildNodeCount(children->length()); | 37 node->setChildNodeCount(children->length()); |
37 node->setChildren(std::move(children)); | 38 node->setChildren(std::move(children)); |
38 return node; | 39 return node; |
39 } | 40 } |
40 | 41 |
41 std::unique_ptr<Array<std::string>> GetAttributes(const ash::WmWindow* window) { | 42 std::unique_ptr<Array<std::string>> GetAttributes(const aura::Window* window) { |
42 std::unique_ptr<Array<std::string>> attributes = Array<std::string>::create(); | 43 std::unique_ptr<Array<std::string>> attributes = Array<std::string>::create(); |
43 attributes->addItem("name"); | 44 attributes->addItem("name"); |
44 attributes->addItem(window->aura_window()->GetName()); | 45 attributes->addItem(window->GetName()); |
45 attributes->addItem("active"); | 46 attributes->addItem("active"); |
46 attributes->addItem(window->IsActive() ? "true" : "false"); | 47 attributes->addItem(::wm::IsActiveWindow(window) ? "true" : "false"); |
47 return attributes; | 48 return attributes; |
48 } | 49 } |
49 | 50 |
50 std::unique_ptr<Array<std::string>> GetAttributes(const views::Widget* widget) { | 51 std::unique_ptr<Array<std::string>> GetAttributes(const views::Widget* widget) { |
51 std::unique_ptr<Array<std::string>> attributes = Array<std::string>::create(); | 52 std::unique_ptr<Array<std::string>> attributes = Array<std::string>::create(); |
52 attributes->addItem("name"); | 53 attributes->addItem("name"); |
53 attributes->addItem(widget->GetName()); | 54 attributes->addItem(widget->GetName()); |
54 attributes->addItem("active"); | 55 attributes->addItem("active"); |
55 attributes->addItem(widget->IsActive() ? "true" : "false"); | 56 attributes->addItem(widget->IsActive() ? "true" : "false"); |
56 return attributes; | 57 return attributes; |
57 } | 58 } |
58 | 59 |
59 std::unique_ptr<Array<std::string>> GetAttributes(const views::View* view) { | 60 std::unique_ptr<Array<std::string>> GetAttributes(const views::View* view) { |
60 std::unique_ptr<Array<std::string>> attributes = Array<std::string>::create(); | 61 std::unique_ptr<Array<std::string>> attributes = Array<std::string>::create(); |
61 attributes->addItem("name"); | 62 attributes->addItem("name"); |
62 attributes->addItem(view->GetClassName()); | 63 attributes->addItem(view->GetClassName()); |
63 return attributes; | 64 return attributes; |
64 } | 65 } |
65 | 66 |
66 WmWindow* FindPreviousSibling(WmWindow* window) { | 67 aura::Window* FindPreviousSibling(aura::Window* window) { |
67 std::vector<WmWindow*> siblings = window->GetParent()->GetChildren(); | 68 const aura::Window::Windows& siblings = window->parent()->children(); |
68 std::vector<WmWindow*>::iterator it = | 69 auto it = std::find(siblings.begin(), siblings.end(), window); |
69 std::find(siblings.begin(), siblings.end(), window); | |
70 DCHECK(it != siblings.end()); | 70 DCHECK(it != siblings.end()); |
71 // If this is the first child of its parent, the previous sibling is null | 71 // If this is the first child of its parent, the previous sibling is null |
72 return it == siblings.begin() ? nullptr : *std::prev(it); | 72 return it == siblings.begin() ? nullptr : *std::prev(it); |
73 } | 73 } |
74 | 74 |
75 views::View* FindPreviousSibling(views::View* view) { | 75 views::View* FindPreviousSibling(views::View* view) { |
76 views::View* parent = view->parent(); | 76 views::View* parent = view->parent(); |
77 int view_index = -1; | 77 int view_index = -1; |
78 for (int i = 0, count = parent->child_count(); i < count; i++) { | 78 for (int i = 0, count = parent->child_count(); i < count; i++) { |
79 if (view == parent->child_at(i)) { | 79 if (view == parent->child_at(i)) { |
(...skipping 12 matching lines...) Expand all Loading... |
92 SkColor RGBAToSkColor(DOM::RGBA* rgba) { | 92 SkColor RGBAToSkColor(DOM::RGBA* rgba) { |
93 if (!rgba) | 93 if (!rgba) |
94 return SkColorSetARGB(0, 0, 0, 0); | 94 return SkColorSetARGB(0, 0, 0, 0); |
95 // Default alpha value is 0 (not visible) and need to convert alpha decimal | 95 // Default alpha value is 0 (not visible) and need to convert alpha decimal |
96 // percentage value to hex | 96 // percentage value to hex |
97 return SkColorSetARGB(MaskColor(static_cast<int>(rgba->getA(0) * 255)), | 97 return SkColorSetARGB(MaskColor(static_cast<int>(rgba->getA(0) * 255)), |
98 MaskColor(rgba->getR()), MaskColor(rgba->getG()), | 98 MaskColor(rgba->getR()), MaskColor(rgba->getG()), |
99 MaskColor(rgba->getB())); | 99 MaskColor(rgba->getB())); |
100 } | 100 } |
101 | 101 |
102 views::Widget* GetWidgetFromWmWindow(WmWindow* window) { | 102 views::Widget* GetWidgetFromWindow(aura::Window* window) { |
103 return views::Widget::GetWidgetForNativeView(window->aura_window()); | 103 return views::Widget::GetWidgetForNativeView(window); |
104 } | 104 } |
105 | 105 |
106 } // namespace | 106 } // namespace |
107 | 107 |
108 AshDevToolsDOMAgent::AshDevToolsDOMAgent() {} | 108 AshDevToolsDOMAgent::AshDevToolsDOMAgent() {} |
109 | 109 |
110 AshDevToolsDOMAgent::~AshDevToolsDOMAgent() { | 110 AshDevToolsDOMAgent::~AshDevToolsDOMAgent() { |
111 RemoveObservers(); | 111 RemoveObservers(); |
112 } | 112 } |
113 | 113 |
(...skipping 25 matching lines...) Expand all Loading... |
139 void AshDevToolsDOMAgent::OnWindowHierarchyChanging( | 139 void AshDevToolsDOMAgent::OnWindowHierarchyChanging( |
140 const HierarchyChangeParams& params) { | 140 const HierarchyChangeParams& params) { |
141 // Only trigger this when params.receiver == params.old_parent. | 141 // Only trigger this when params.receiver == params.old_parent. |
142 // Only removals are handled here. Removing a node can occur as a result of | 142 // Only removals are handled here. Removing a node can occur as a result of |
143 // reorganizing a window or just destroying it. OnWindowHierarchyChanged | 143 // reorganizing a window or just destroying it. OnWindowHierarchyChanged |
144 // is only called if there is a new_parent. The only case this method isn't | 144 // is only called if there is a new_parent. The only case this method isn't |
145 // called is when adding a node because old_parent is then null. | 145 // called is when adding a node because old_parent is then null. |
146 // Finally, We only trigger this 0 or 1 times as an old_parent will | 146 // Finally, We only trigger this 0 or 1 times as an old_parent will |
147 // either exist and only call this callback once, or not at all. | 147 // either exist and only call this callback once, or not at all. |
148 if (params.receiver == params.old_parent) | 148 if (params.receiver == params.old_parent) |
149 RemoveWindowTree(WmWindow::Get(params.target), true); | 149 RemoveWindowTree(params.target, true); |
150 } | 150 } |
151 | 151 |
152 // Handles adding windows. | 152 // Handles adding windows. |
153 void AshDevToolsDOMAgent::OnWindowHierarchyChanged( | 153 void AshDevToolsDOMAgent::OnWindowHierarchyChanged( |
154 const HierarchyChangeParams& params) { | 154 const HierarchyChangeParams& params) { |
155 // Only trigger this when params.receiver == params.new_parent. | 155 // Only trigger this when params.receiver == params.new_parent. |
156 // If there is an old_parent + new_parent, then this window's node was | 156 // If there is an old_parent + new_parent, then this window's node was |
157 // removed in OnWindowHierarchyChanging and will now be added to the | 157 // removed in OnWindowHierarchyChanging and will now be added to the |
158 // new_parent. If there is only a new_parent, OnWindowHierarchyChanging is | 158 // new_parent. If there is only a new_parent, OnWindowHierarchyChanging is |
159 // never called and the window is only added here. | 159 // never called and the window is only added here. |
160 if (params.receiver == params.new_parent) | 160 if (params.receiver == params.new_parent) |
161 AddWindowTree(WmWindow::Get(params.target)); | 161 AddWindowTree(params.target); |
162 } | 162 } |
163 | 163 |
164 void AshDevToolsDOMAgent::OnWindowStackingChanged(aura::Window* window) { | 164 void AshDevToolsDOMAgent::OnWindowStackingChanged(aura::Window* window) { |
165 RemoveWindowTree(WmWindow::Get(window), false); | 165 RemoveWindowTree(window, false); |
166 AddWindowTree(WmWindow::Get(window)); | 166 AddWindowTree(window); |
167 } | 167 } |
168 | 168 |
169 void AshDevToolsDOMAgent::OnWindowBoundsChanged(aura::Window* window, | 169 void AshDevToolsDOMAgent::OnWindowBoundsChanged(aura::Window* window, |
170 const gfx::Rect& old_bounds, | 170 const gfx::Rect& old_bounds, |
171 const gfx::Rect& new_bounds) { | 171 const gfx::Rect& new_bounds) { |
172 for (auto& observer : observers_) | 172 for (auto& observer : observers_) |
173 observer.OnWindowBoundsChanged(WmWindow::Get(window)); | 173 observer.OnWindowBoundsChanged(window); |
174 } | 174 } |
175 | 175 |
176 void AshDevToolsDOMAgent::OnWillRemoveView(views::Widget* widget, | 176 void AshDevToolsDOMAgent::OnWillRemoveView(views::Widget* widget, |
177 views::View* view) { | 177 views::View* view) { |
178 if (view == widget->GetRootView()) | 178 if (view == widget->GetRootView()) |
179 RemoveViewTree(view, nullptr, true); | 179 RemoveViewTree(view, nullptr, true); |
180 } | 180 } |
181 | 181 |
182 void AshDevToolsDOMAgent::OnWidgetBoundsChanged(views::Widget* widget, | 182 void AshDevToolsDOMAgent::OnWidgetBoundsChanged(views::Widget* widget, |
183 const gfx::Rect& new_bounds) { | 183 const gfx::Rect& new_bounds) { |
(...skipping 15 matching lines...) Expand all Loading... |
199 views::View* view) { | 199 views::View* view) { |
200 RemoveViewTree(view, parent, false); | 200 RemoveViewTree(view, parent, false); |
201 AddViewTree(view); | 201 AddViewTree(view); |
202 } | 202 } |
203 | 203 |
204 void AshDevToolsDOMAgent::OnViewBoundsChanged(views::View* view) { | 204 void AshDevToolsDOMAgent::OnViewBoundsChanged(views::View* view) { |
205 for (auto& observer : observers_) | 205 for (auto& observer : observers_) |
206 observer.OnViewBoundsChanged(view); | 206 observer.OnViewBoundsChanged(view); |
207 } | 207 } |
208 | 208 |
209 WmWindow* AshDevToolsDOMAgent::GetWindowFromNodeId(int nodeId) { | 209 aura::Window* AshDevToolsDOMAgent::GetWindowFromNodeId(int nodeId) { |
210 return node_id_to_window_map_.count(nodeId) ? node_id_to_window_map_[nodeId] | 210 return node_id_to_window_map_.count(nodeId) ? node_id_to_window_map_[nodeId] |
211 : nullptr; | 211 : nullptr; |
212 } | 212 } |
213 | 213 |
214 views::Widget* AshDevToolsDOMAgent::GetWidgetFromNodeId(int nodeId) { | 214 views::Widget* AshDevToolsDOMAgent::GetWidgetFromNodeId(int nodeId) { |
215 return node_id_to_widget_map_.count(nodeId) ? node_id_to_widget_map_[nodeId] | 215 return node_id_to_widget_map_.count(nodeId) ? node_id_to_widget_map_[nodeId] |
216 : nullptr; | 216 : nullptr; |
217 } | 217 } |
218 | 218 |
219 views::View* AshDevToolsDOMAgent::GetViewFromNodeId(int nodeId) { | 219 views::View* AshDevToolsDOMAgent::GetViewFromNodeId(int nodeId) { |
220 return node_id_to_view_map_.count(nodeId) ? node_id_to_view_map_[nodeId] | 220 return node_id_to_view_map_.count(nodeId) ? node_id_to_view_map_[nodeId] |
221 : nullptr; | 221 : nullptr; |
222 } | 222 } |
223 | 223 |
224 int AshDevToolsDOMAgent::GetNodeIdFromWindow(WmWindow* window) { | 224 int AshDevToolsDOMAgent::GetNodeIdFromWindow(aura::Window* window) { |
225 DCHECK(window_to_node_id_map_.count(window)); | 225 DCHECK(window_to_node_id_map_.count(window)); |
226 return window_to_node_id_map_[window]; | 226 return window_to_node_id_map_[window]; |
227 } | 227 } |
228 | 228 |
229 int AshDevToolsDOMAgent::GetNodeIdFromWidget(views::Widget* widget) { | 229 int AshDevToolsDOMAgent::GetNodeIdFromWidget(views::Widget* widget) { |
230 DCHECK(widget_to_node_id_map_.count(widget)); | 230 DCHECK(widget_to_node_id_map_.count(widget)); |
231 return widget_to_node_id_map_[widget]; | 231 return widget_to_node_id_map_[widget]; |
232 } | 232 } |
233 | 233 |
234 int AshDevToolsDOMAgent::GetNodeIdFromView(views::View* view) { | 234 int AshDevToolsDOMAgent::GetNodeIdFromView(views::View* view) { |
235 DCHECK(view_to_node_id_map_.count(view)); | 235 DCHECK(view_to_node_id_map_.count(view)); |
236 return view_to_node_id_map_[view]; | 236 return view_to_node_id_map_[view]; |
237 } | 237 } |
238 | 238 |
239 void AshDevToolsDOMAgent::AddObserver(AshDevToolsDOMAgentObserver* observer) { | 239 void AshDevToolsDOMAgent::AddObserver(AshDevToolsDOMAgentObserver* observer) { |
240 observers_.AddObserver(observer); | 240 observers_.AddObserver(observer); |
241 } | 241 } |
242 | 242 |
243 void AshDevToolsDOMAgent::RemoveObserver( | 243 void AshDevToolsDOMAgent::RemoveObserver( |
244 AshDevToolsDOMAgentObserver* observer) { | 244 AshDevToolsDOMAgentObserver* observer) { |
245 observers_.RemoveObserver(observer); | 245 observers_.RemoveObserver(observer); |
246 } | 246 } |
247 | 247 |
248 std::unique_ptr<ui::devtools::protocol::DOM::Node> | 248 std::unique_ptr<ui::devtools::protocol::DOM::Node> |
249 AshDevToolsDOMAgent::BuildInitialTree() { | 249 AshDevToolsDOMAgent::BuildInitialTree() { |
250 std::unique_ptr<Array<DOM::Node>> children = Array<DOM::Node>::create(); | 250 std::unique_ptr<Array<DOM::Node>> children = Array<DOM::Node>::create(); |
251 for (aura::Window* window : Shell::GetAllRootWindows()) | 251 for (aura::Window* window : Shell::GetAllRootWindows()) |
252 children->addItem(BuildTreeForWindow(WmWindow::Get(window))); | 252 children->addItem(BuildTreeForWindow(window)); |
253 return BuildNode("root", nullptr, std::move(children)); | 253 return BuildNode("root", nullptr, std::move(children)); |
254 } | 254 } |
255 | 255 |
256 std::unique_ptr<DOM::Node> AshDevToolsDOMAgent::BuildTreeForWindow( | 256 std::unique_ptr<DOM::Node> AshDevToolsDOMAgent::BuildTreeForWindow( |
257 ash::WmWindow* window) { | 257 aura::Window* window) { |
258 DCHECK(!window_to_node_id_map_.count(window)); | 258 DCHECK(!window_to_node_id_map_.count(window)); |
259 std::unique_ptr<Array<DOM::Node>> children = Array<DOM::Node>::create(); | 259 std::unique_ptr<Array<DOM::Node>> children = Array<DOM::Node>::create(); |
260 views::Widget* widget = GetWidgetFromWmWindow(window); | 260 views::Widget* widget = GetWidgetFromWindow(window); |
261 if (widget) | 261 if (widget) |
262 children->addItem(BuildTreeForRootWidget(widget)); | 262 children->addItem(BuildTreeForRootWidget(widget)); |
263 for (ash::WmWindow* child : window->GetChildren()) { | 263 for (aura::Window* child : window->children()) { |
264 if (!IsHighlightingWindow(child)) | 264 if (!IsHighlightingWindow(child)) |
265 children->addItem(BuildTreeForWindow(child)); | 265 children->addItem(BuildTreeForWindow(child)); |
266 } | 266 } |
267 | 267 |
268 std::unique_ptr<ui::devtools::protocol::DOM::Node> node = | 268 std::unique_ptr<ui::devtools::protocol::DOM::Node> node = |
269 BuildNode("Window", GetAttributes(window), std::move(children)); | 269 BuildNode("Window", GetAttributes(window), std::move(children)); |
270 if (!window->aura_window()->HasObserver(this)) | 270 if (!window->HasObserver(this)) |
271 window->aura_window()->AddObserver(this); | 271 window->AddObserver(this); |
272 window_to_node_id_map_[window] = node->getNodeId(); | 272 window_to_node_id_map_[window] = node->getNodeId(); |
273 node_id_to_window_map_[node->getNodeId()] = window; | 273 node_id_to_window_map_[node->getNodeId()] = window; |
274 return node; | 274 return node; |
275 } | 275 } |
276 | 276 |
277 std::unique_ptr<DOM::Node> AshDevToolsDOMAgent::BuildTreeForRootWidget( | 277 std::unique_ptr<DOM::Node> AshDevToolsDOMAgent::BuildTreeForRootWidget( |
278 views::Widget* widget) { | 278 views::Widget* widget) { |
279 DCHECK(!widget_to_node_id_map_.count(widget)); | 279 DCHECK(!widget_to_node_id_map_.count(widget)); |
280 std::unique_ptr<Array<DOM::Node>> children = Array<DOM::Node>::create(); | 280 std::unique_ptr<Array<DOM::Node>> children = Array<DOM::Node>::create(); |
281 children->addItem(BuildTreeForView(widget->GetRootView())); | 281 children->addItem(BuildTreeForView(widget->GetRootView())); |
(...skipping 14 matching lines...) Expand all Loading... |
296 children->addItem(BuildTreeForView(view->child_at(i))); | 296 children->addItem(BuildTreeForView(view->child_at(i))); |
297 std::unique_ptr<ui::devtools::protocol::DOM::Node> node = | 297 std::unique_ptr<ui::devtools::protocol::DOM::Node> node = |
298 BuildNode("View", GetAttributes(view), std::move(children)); | 298 BuildNode("View", GetAttributes(view), std::move(children)); |
299 if (!view->HasObserver(this)) | 299 if (!view->HasObserver(this)) |
300 view->AddObserver(this); | 300 view->AddObserver(this); |
301 view_to_node_id_map_[view] = node->getNodeId(); | 301 view_to_node_id_map_[view] = node->getNodeId(); |
302 node_id_to_view_map_[node->getNodeId()] = view; | 302 node_id_to_view_map_[node->getNodeId()] = view; |
303 return node; | 303 return node; |
304 } | 304 } |
305 | 305 |
306 void AshDevToolsDOMAgent::AddWindowTree(WmWindow* window) { | 306 void AshDevToolsDOMAgent::AddWindowTree(aura::Window* window) { |
307 if (IsHighlightingWindow(window)) | 307 if (IsHighlightingWindow(window)) |
308 return; | 308 return; |
309 | 309 |
310 DCHECK(window_to_node_id_map_.count(window->GetParent())); | 310 DCHECK(window_to_node_id_map_.count(window->parent())); |
311 WmWindow* prev_sibling = FindPreviousSibling(window); | 311 aura::Window* prev_sibling = FindPreviousSibling(window); |
312 frontend()->childNodeInserted( | 312 frontend()->childNodeInserted( |
313 window_to_node_id_map_[window->GetParent()], | 313 window_to_node_id_map_[window->parent()], |
314 prev_sibling ? window_to_node_id_map_[prev_sibling] : 0, | 314 prev_sibling ? window_to_node_id_map_[prev_sibling] : 0, |
315 BuildTreeForWindow(window)); | 315 BuildTreeForWindow(window)); |
316 } | 316 } |
317 | 317 |
318 void AshDevToolsDOMAgent::RemoveWindowTree(WmWindow* window, | 318 void AshDevToolsDOMAgent::RemoveWindowTree(aura::Window* window, |
319 bool remove_observer) { | 319 bool remove_observer) { |
320 DCHECK(window); | 320 DCHECK(window); |
321 if (IsHighlightingWindow(window)) | 321 if (IsHighlightingWindow(window)) |
322 return; | 322 return; |
323 | 323 |
324 if (GetWidgetFromWmWindow(window)) | 324 if (GetWidgetFromWindow(window)) |
325 RemoveWidgetTree(GetWidgetFromWmWindow(window), remove_observer); | 325 RemoveWidgetTree(GetWidgetFromWindow(window), remove_observer); |
326 | 326 |
327 for (ash::WmWindow* child : window->GetChildren()) | 327 for (aura::Window* child : window->children()) |
328 RemoveWindowTree(child, remove_observer); | 328 RemoveWindowTree(child, remove_observer); |
329 | 329 |
330 RemoveWindowNode(window, remove_observer); | 330 RemoveWindowNode(window, remove_observer); |
331 } | 331 } |
332 | 332 |
333 void AshDevToolsDOMAgent::RemoveWindowNode(WmWindow* window, | 333 void AshDevToolsDOMAgent::RemoveWindowNode(aura::Window* window, |
334 bool remove_observer) { | 334 bool remove_observer) { |
335 WindowToNodeIdMap::iterator window_to_node_id_it = | 335 WindowToNodeIdMap::iterator window_to_node_id_it = |
336 window_to_node_id_map_.find(window); | 336 window_to_node_id_map_.find(window); |
337 DCHECK(window_to_node_id_it != window_to_node_id_map_.end()); | 337 DCHECK(window_to_node_id_it != window_to_node_id_map_.end()); |
338 | 338 |
339 int node_id = window_to_node_id_it->second; | 339 int node_id = window_to_node_id_it->second; |
340 int parent_id = GetNodeIdFromWindow(window->GetParent()); | 340 int parent_id = GetNodeIdFromWindow(window->parent()); |
341 | 341 |
342 NodeIdToWindowMap::iterator node_id_to_window_it = | 342 NodeIdToWindowMap::iterator node_id_to_window_it = |
343 node_id_to_window_map_.find(node_id); | 343 node_id_to_window_map_.find(node_id); |
344 DCHECK(node_id_to_window_it != node_id_to_window_map_.end()); | 344 DCHECK(node_id_to_window_it != node_id_to_window_map_.end()); |
345 | 345 |
346 if (remove_observer) | 346 if (remove_observer) |
347 window->aura_window()->RemoveObserver(this); | 347 window->RemoveObserver(this); |
348 | 348 |
349 node_id_to_window_map_.erase(node_id_to_window_it); | 349 node_id_to_window_map_.erase(node_id_to_window_it); |
350 window_to_node_id_map_.erase(window_to_node_id_it); | 350 window_to_node_id_map_.erase(window_to_node_id_it); |
351 frontend()->childNodeRemoved(parent_id, node_id); | 351 frontend()->childNodeRemoved(parent_id, node_id); |
352 } | 352 } |
353 | 353 |
354 void AshDevToolsDOMAgent::RemoveWidgetTree(views::Widget* widget, | 354 void AshDevToolsDOMAgent::RemoveWidgetTree(views::Widget* widget, |
355 bool remove_observer) { | 355 bool remove_observer) { |
356 DCHECK(widget); | 356 DCHECK(widget); |
357 if (widget->GetRootView()) | 357 if (widget->GetRootView()) |
358 RemoveViewTree(widget->GetRootView(), nullptr, remove_observer); | 358 RemoveViewTree(widget->GetRootView(), nullptr, remove_observer); |
359 RemoveWidgetNode(widget, remove_observer); | 359 RemoveWidgetNode(widget, remove_observer); |
360 } | 360 } |
361 | 361 |
362 void AshDevToolsDOMAgent::RemoveWidgetNode(views::Widget* widget, | 362 void AshDevToolsDOMAgent::RemoveWidgetNode(views::Widget* widget, |
363 bool remove_observer) { | 363 bool remove_observer) { |
364 WidgetToNodeIdMap::iterator widget_to_node_id_it = | 364 WidgetToNodeIdMap::iterator widget_to_node_id_it = |
365 widget_to_node_id_map_.find(widget); | 365 widget_to_node_id_map_.find(widget); |
366 DCHECK(widget_to_node_id_it != widget_to_node_id_map_.end()); | 366 DCHECK(widget_to_node_id_it != widget_to_node_id_map_.end()); |
367 | 367 |
368 int node_id = widget_to_node_id_it->second; | 368 int node_id = widget_to_node_id_it->second; |
369 int parent_id = GetNodeIdFromWindow(WmWindow::Get(widget->GetNativeWindow())); | 369 int parent_id = GetNodeIdFromWindow(widget->GetNativeWindow()); |
370 | 370 |
371 if (remove_observer) | 371 if (remove_observer) |
372 widget->RemoveRemovalsObserver(this); | 372 widget->RemoveRemovalsObserver(this); |
373 | 373 |
374 NodeIdToWidgetMap::iterator node_id_to_widget_it = | 374 NodeIdToWidgetMap::iterator node_id_to_widget_it = |
375 node_id_to_widget_map_.find(node_id); | 375 node_id_to_widget_map_.find(node_id); |
376 DCHECK(node_id_to_widget_it != node_id_to_widget_map_.end()); | 376 DCHECK(node_id_to_widget_it != node_id_to_widget_map_.end()); |
377 | 377 |
378 widget_to_node_id_map_.erase(widget_to_node_id_it); | 378 widget_to_node_id_map_.erase(widget_to_node_id_it); |
379 node_id_to_widget_map_.erase(node_id_to_widget_it); | 379 node_id_to_widget_map_.erase(node_id_to_widget_it); |
(...skipping 39 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
419 node_id_to_view_map_.find(node_id); | 419 node_id_to_view_map_.find(node_id); |
420 DCHECK(node_id_to_view_it != node_id_to_view_map_.end()); | 420 DCHECK(node_id_to_view_it != node_id_to_view_map_.end()); |
421 | 421 |
422 view_to_node_id_map_.erase(view_to_node_id_it); | 422 view_to_node_id_map_.erase(view_to_node_id_it); |
423 node_id_to_view_map_.erase(node_id_to_view_it); | 423 node_id_to_view_map_.erase(node_id_to_view_it); |
424 frontend()->childNodeRemoved(parent_id, node_id); | 424 frontend()->childNodeRemoved(parent_id, node_id); |
425 } | 425 } |
426 | 426 |
427 void AshDevToolsDOMAgent::RemoveObservers() { | 427 void AshDevToolsDOMAgent::RemoveObservers() { |
428 for (auto& pair : window_to_node_id_map_) | 428 for (auto& pair : window_to_node_id_map_) |
429 pair.first->aura_window()->RemoveObserver(this); | 429 pair.first->RemoveObserver(this); |
430 for (auto& pair : widget_to_node_id_map_) | 430 for (auto& pair : widget_to_node_id_map_) |
431 pair.first->RemoveRemovalsObserver(this); | 431 pair.first->RemoveRemovalsObserver(this); |
432 for (auto& pair : view_to_node_id_map_) | 432 for (auto& pair : view_to_node_id_map_) |
433 pair.first->RemoveObserver(this); | 433 pair.first->RemoveObserver(this); |
434 } | 434 } |
435 | 435 |
436 void AshDevToolsDOMAgent::Reset() { | 436 void AshDevToolsDOMAgent::Reset() { |
437 RemoveObservers(); | 437 RemoveObservers(); |
438 widget_for_highlighting_.reset(); | 438 widget_for_highlighting_.reset(); |
439 window_to_node_id_map_.clear(); | 439 window_to_node_id_map_.clear(); |
440 widget_to_node_id_map_.clear(); | 440 widget_to_node_id_map_.clear(); |
441 view_to_node_id_map_.clear(); | 441 view_to_node_id_map_.clear(); |
442 node_id_to_window_map_.clear(); | 442 node_id_to_window_map_.clear(); |
443 node_id_to_widget_map_.clear(); | 443 node_id_to_widget_map_.clear(); |
444 node_id_to_view_map_.clear(); | 444 node_id_to_view_map_.clear(); |
445 node_ids = 1; | 445 node_ids = 1; |
446 } | 446 } |
447 | 447 |
448 AshDevToolsDOMAgent::WindowAndBoundsPair | 448 AshDevToolsDOMAgent::WindowAndBoundsPair |
449 AshDevToolsDOMAgent::GetNodeWindowAndBounds(int node_id) { | 449 AshDevToolsDOMAgent::GetNodeWindowAndBounds(int node_id) { |
450 WmWindow* window = GetWindowFromNodeId(node_id); | 450 aura::Window* window = GetWindowFromNodeId(node_id); |
451 if (window) | 451 if (window) |
452 return std::make_pair(window, window->GetBoundsInScreen()); | 452 return std::make_pair(window, window->GetBoundsInScreen()); |
453 | 453 |
454 views::Widget* widget = GetWidgetFromNodeId(node_id); | 454 views::Widget* widget = GetWidgetFromNodeId(node_id); |
455 if (widget) { | 455 if (widget) { |
456 return std::make_pair(WmWindow::Get(widget->GetNativeWindow()), | 456 return std::make_pair(widget->GetNativeWindow(), |
457 widget->GetWindowBoundsInScreen()); | 457 widget->GetWindowBoundsInScreen()); |
458 } | 458 } |
459 | 459 |
460 views::View* view = GetViewFromNodeId(node_id); | 460 views::View* view = GetViewFromNodeId(node_id); |
461 if (view) { | 461 if (view) { |
462 gfx::Rect bounds = view->GetBoundsInScreen(); | 462 gfx::Rect bounds = view->GetBoundsInScreen(); |
463 return std::make_pair(WmWindow::Get(view->GetWidget()->GetNativeWindow()), | 463 return std::make_pair(view->GetWidget()->GetNativeWindow(), bounds); |
464 bounds); | |
465 } | 464 } |
466 | 465 |
467 return std::make_pair(nullptr, gfx::Rect()); | 466 return std::make_pair(nullptr, gfx::Rect()); |
468 } | 467 } |
469 | 468 |
470 void AshDevToolsDOMAgent::InitializeHighlightingWidget() { | 469 void AshDevToolsDOMAgent::InitializeHighlightingWidget() { |
471 DCHECK(!widget_for_highlighting_); | 470 DCHECK(!widget_for_highlighting_); |
472 widget_for_highlighting_.reset(new views::Widget); | 471 widget_for_highlighting_.reset(new views::Widget); |
473 views::Widget::InitParams params; | 472 views::Widget::InitParams params; |
474 params.type = views::Widget::InitParams::TYPE_WINDOW_FRAMELESS; | 473 params.type = views::Widget::InitParams::TYPE_WINDOW_FRAMELESS; |
(...skipping 12 matching lines...) Expand all Loading... |
487 | 486 |
488 void AshDevToolsDOMAgent::UpdateHighlight( | 487 void AshDevToolsDOMAgent::UpdateHighlight( |
489 const WindowAndBoundsPair& window_and_bounds, | 488 const WindowAndBoundsPair& window_and_bounds, |
490 SkColor background, | 489 SkColor background, |
491 SkColor border) { | 490 SkColor border) { |
492 constexpr int kBorderThickness = 1; | 491 constexpr int kBorderThickness = 1; |
493 views::View* root_view = widget_for_highlighting_->GetRootView(); | 492 views::View* root_view = widget_for_highlighting_->GetRootView(); |
494 root_view->SetBorder(views::CreateSolidBorder(kBorderThickness, border)); | 493 root_view->SetBorder(views::CreateSolidBorder(kBorderThickness, border)); |
495 root_view->set_background( | 494 root_view->set_background( |
496 views::Background::CreateSolidBackground(background)); | 495 views::Background::CreateSolidBackground(background)); |
497 WmWindow::Get(widget_for_highlighting_->GetNativeWindow()) | 496 display::Display display = |
498 ->SetBoundsInScreen(window_and_bounds.second, | 497 display::Screen::GetScreen()->GetDisplayNearestWindow( |
499 window_and_bounds.first->GetDisplayNearestWindow()); | 498 window_and_bounds.first); |
| 499 widget_for_highlighting_->GetNativeWindow()->SetBoundsInScreen( |
| 500 window_and_bounds.second, display); |
500 } | 501 } |
501 | 502 |
502 ui::devtools::protocol::Response AshDevToolsDOMAgent::HighlightNode( | 503 ui::devtools::protocol::Response AshDevToolsDOMAgent::HighlightNode( |
503 std::unique_ptr<ui::devtools::protocol::DOM::HighlightConfig> | 504 std::unique_ptr<ui::devtools::protocol::DOM::HighlightConfig> |
504 highlight_config, | 505 highlight_config, |
505 int node_id) { | 506 int node_id) { |
506 if (!widget_for_highlighting_) | 507 if (!widget_for_highlighting_) |
507 InitializeHighlightingWidget(); | 508 InitializeHighlightingWidget(); |
508 | 509 |
509 WindowAndBoundsPair window_and_bounds(GetNodeWindowAndBounds(node_id)); | 510 WindowAndBoundsPair window_and_bounds(GetNodeWindowAndBounds(node_id)); |
510 | 511 |
511 if (!window_and_bounds.first) | 512 if (!window_and_bounds.first) |
512 return ui::devtools::protocol::Response::Error( | 513 return ui::devtools::protocol::Response::Error( |
513 "No node found with that id"); | 514 "No node found with that id"); |
514 | 515 |
515 SkColor border_color = | 516 SkColor border_color = |
516 RGBAToSkColor(highlight_config->getBorderColor(nullptr)); | 517 RGBAToSkColor(highlight_config->getBorderColor(nullptr)); |
517 SkColor content_color = | 518 SkColor content_color = |
518 RGBAToSkColor(highlight_config->getContentColor(nullptr)); | 519 RGBAToSkColor(highlight_config->getContentColor(nullptr)); |
519 UpdateHighlight(window_and_bounds, content_color, border_color); | 520 UpdateHighlight(window_and_bounds, content_color, border_color); |
520 | 521 |
521 if (!widget_for_highlighting_->IsVisible()) | 522 if (!widget_for_highlighting_->IsVisible()) |
522 widget_for_highlighting_->Show(); | 523 widget_for_highlighting_->Show(); |
523 | 524 |
524 return ui::devtools::protocol::Response::OK(); | 525 return ui::devtools::protocol::Response::OK(); |
525 } | 526 } |
526 | 527 |
527 bool AshDevToolsDOMAgent::IsHighlightingWindow(WmWindow* window) { | 528 bool AshDevToolsDOMAgent::IsHighlightingWindow(aura::Window* window) { |
528 return widget_for_highlighting_ && | 529 return widget_for_highlighting_ && |
529 GetWidgetFromWmWindow(window) == widget_for_highlighting_.get(); | 530 GetWidgetFromWindow(window) == widget_for_highlighting_.get(); |
530 } | 531 } |
531 | 532 |
532 } // namespace devtools | 533 } // namespace devtools |
533 } // namespace ash | 534 } // namespace ash |
OLD | NEW |