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

Side by Side Diff: ash/devtools/ash_devtools_dom_agent.cc

Issue 2821213002: chromeos: converts ash devtools to aura::Window (Closed)
Patch Set: fix cast Created 3 years, 8 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
OLDNEW
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
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
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
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
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
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
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
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698