| OLD | NEW |
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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/mus/window_manager.h" | 5 #include "ash/mus/window_manager.h" |
| 6 | 6 |
| 7 #include <stdint.h> | 7 #include <stdint.h> |
| 8 | 8 |
| 9 #include <utility> | 9 #include <utility> |
| 10 | 10 |
| (...skipping 467 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 478 if (root_window_controller_ptr->GetHost() == window_tree_host) { | 478 if (root_window_controller_ptr->GetHost() == window_tree_host) { |
| 479 const bool in_shutdown = false; | 479 const bool in_shutdown = false; |
| 480 DestroyRootWindowController(root_window_controller_ptr.get(), | 480 DestroyRootWindowController(root_window_controller_ptr.get(), |
| 481 in_shutdown); | 481 in_shutdown); |
| 482 break; | 482 break; |
| 483 } | 483 } |
| 484 } | 484 } |
| 485 } | 485 } |
| 486 | 486 |
| 487 void WindowManager::OnWmDisplayModified(const display::Display& display) { | 487 void WindowManager::OnWmDisplayModified(const display::Display& display) { |
| 488 screen_->display_list().UpdateDisplay(display); | 488 // Ash relies on the Display being updated, then the WindowTreeHost's window, |
| 489 // and finally DisplayObservers. |
| 490 display::DisplayList& display_list = screen_->display_list(); |
| 491 std::unique_ptr<display::DisplayListObserverLock> display_lock = |
| 492 display_list.SuspendObserverUpdates(); |
| 493 const bool is_primary = display_list.FindDisplayById(display.id()) == |
| 494 display_list.GetPrimaryDisplayIterator(); |
| 495 uint32_t display_changed_values = display_list.UpdateDisplay( |
| 496 display, is_primary ? display::DisplayList::Type::PRIMARY |
| 497 : display::DisplayList::Type::NOT_PRIMARY); |
| 498 RootWindowController* root_window_controller = |
| 499 WmShellMus::Get()->GetRootWindowControllerWithDisplayId(display.id()); |
| 500 DCHECK(root_window_controller); |
| 501 root_window_controller->GetRootWindow()->GetHost()->SetBoundsInPixels( |
| 502 display.bounds()); |
| 503 display_lock.reset(); |
| 504 for (display::DisplayObserver& observer : *(display_list.observers())) |
| 505 observer.OnDisplayMetricsChanged(display, display_changed_values); |
| 489 } | 506 } |
| 490 | 507 |
| 491 void WindowManager::OnWmPerformMoveLoop( | 508 void WindowManager::OnWmPerformMoveLoop( |
| 492 aura::Window* window, | 509 aura::Window* window, |
| 493 ui::mojom::MoveLoopSource source, | 510 ui::mojom::MoveLoopSource source, |
| 494 const gfx::Point& cursor_location, | 511 const gfx::Point& cursor_location, |
| 495 const base::Callback<void(bool)>& on_done) { | 512 const base::Callback<void(bool)>& on_done) { |
| 496 WmWindow* child_window = WmWindow::Get(window); | 513 WmWindow* child_window = WmWindow::Get(window); |
| 497 MoveEventHandler* handler = MoveEventHandler::GetForWindow(child_window); | 514 MoveEventHandler* handler = MoveEventHandler::GetForWindow(child_window); |
| 498 if (!handler) { | 515 if (!handler) { |
| (...skipping 41 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 540 bool WindowManager::IsWindowActive(aura::Window* window) { | 557 bool WindowManager::IsWindowActive(aura::Window* window) { |
| 541 return Shell::GetInstance()->activation_client()->GetActiveWindow() == window; | 558 return Shell::GetInstance()->activation_client()->GetActiveWindow() == window; |
| 542 } | 559 } |
| 543 | 560 |
| 544 void WindowManager::OnWmDeactivateWindow(aura::Window* window) { | 561 void WindowManager::OnWmDeactivateWindow(aura::Window* window) { |
| 545 Shell::GetInstance()->activation_client()->DeactivateWindow(window); | 562 Shell::GetInstance()->activation_client()->DeactivateWindow(window); |
| 546 } | 563 } |
| 547 | 564 |
| 548 } // namespace mus | 565 } // namespace mus |
| 549 } // namespace ash | 566 } // namespace ash |
| OLD | NEW |