|  | // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 
|  | // Use of this source code is governed by a BSD-style license that can be | 
|  | // found in the LICENSE file. | 
|  |  | 
|  | #ifndef ASH_DISPLAY_DISPLAY_CONTROLLER_H_ | 
|  | #define ASH_DISPLAY_DISPLAY_CONTROLLER_H_ | 
|  |  | 
|  | #include <stdint.h> | 
|  |  | 
|  | #include <map> | 
|  | #include <memory> | 
|  | #include <vector> | 
|  |  | 
|  | #include "ash/ash_export.h" | 
|  | #include "ash/display/display_manager.h" | 
|  | #include "base/compiler_specific.h" | 
|  | #include "base/gtest_prod_util.h" | 
|  | #include "base/macros.h" | 
|  | #include "base/memory/weak_ptr.h" | 
|  | #include "base/observer_list.h" | 
|  | #include "base/time/time.h" | 
|  | #include "ui/aura/window.h" | 
|  | #include "ui/aura/window_tree_host_observer.h" | 
|  | #include "ui/base/ime/input_method.h" | 
|  | #include "ui/base/ime/input_method_delegate.h" | 
|  | #include "ui/display/display_observer.h" | 
|  | #include "ui/gfx/geometry/point.h" | 
|  |  | 
|  | namespace aura { | 
|  | class WindowTreeHost; | 
|  | } | 
|  |  | 
|  | namespace base { | 
|  | class Value; | 
|  | template <typename T> | 
|  | class JSONValueConverter; | 
|  | } | 
|  |  | 
|  | namespace gfx { | 
|  | class Insets; | 
|  | } | 
|  |  | 
|  | namespace ash { | 
|  | class AshWindowTreeHost; | 
|  | struct AshWindowTreeHostInitParams; | 
|  | class CursorWindowController; | 
|  | class DisplayManager; | 
|  | class FocusActivationStore; | 
|  | class InputMethodEventHandler; | 
|  | class MirrorWindowController; | 
|  | class RootWindowController; | 
|  |  | 
|  | // WindowTreeHostManager owns and maintains RootWindows for each attached | 
|  | // display, keeping them in sync with display configuration changes. | 
|  | class ASH_EXPORT WindowTreeHostManager | 
|  | : public display::DisplayObserver, | 
|  | public aura::WindowTreeHostObserver, | 
|  | public DisplayManager::Delegate, | 
|  | public ui::internal::InputMethodDelegate { | 
|  | public: | 
|  | // TODO(oshima): Consider moving this to display::DisplayObserver. | 
|  | class ASH_EXPORT Observer { | 
|  | public: | 
|  | // Invoked only once after all displays are initialized | 
|  | // after startup. | 
|  | virtual void OnDisplaysInitialized() {} | 
|  |  | 
|  | // Invoked when the display configuration change is requested, | 
|  | // but before the change is applied to aura/ash. | 
|  | virtual void OnDisplayConfigurationChanging() {} | 
|  |  | 
|  | // Invoked when the all display configuration changes | 
|  | // have been applied. | 
|  | virtual void OnDisplayConfigurationChanged() {} | 
|  |  | 
|  | // Invoked in WindowTreeHostManager::Shutdown(). | 
|  | virtual void OnWindowTreeHostManagerShutdown() {} | 
|  |  | 
|  | protected: | 
|  | virtual ~Observer() {} | 
|  | }; | 
|  |  | 
|  | WindowTreeHostManager(); | 
|  | ~WindowTreeHostManager() override; | 
|  |  | 
|  | void Start(); | 
|  | void Shutdown(); | 
|  |  | 
|  | // Returns primary display's ID. | 
|  | // TODO(oshima): Move this out from WindowTreeHostManager; | 
|  | static int64_t GetPrimaryDisplayId(); | 
|  |  | 
|  | CursorWindowController* cursor_window_controller() { | 
|  | return cursor_window_controller_.get(); | 
|  | } | 
|  |  | 
|  | MirrorWindowController* mirror_window_controller() { | 
|  | return mirror_window_controller_.get(); | 
|  | } | 
|  |  | 
|  | // Create a WindowTreeHost for the primary display. This replaces | 
|  | // |initial_bounds| in |init_params|. | 
|  | void CreatePrimaryHost(const AshWindowTreeHostInitParams& init_params); | 
|  |  | 
|  | // Initializes all WindowTreeHosts. | 
|  | void InitHosts(); | 
|  |  | 
|  | // Add/Remove observers. | 
|  | void AddObserver(Observer* observer); | 
|  | void RemoveObserver(Observer* observer); | 
|  |  | 
|  | // Returns the root window for primary display. | 
|  | aura::Window* GetPrimaryRootWindow(); | 
|  |  | 
|  | // Returns the root window for |display_id|. | 
|  | aura::Window* GetRootWindowForDisplayId(int64_t id); | 
|  |  | 
|  | // Returns AshWTH for given display |id|. Call results in CHECK failure | 
|  | // if the WTH does not exist. | 
|  | AshWindowTreeHost* GetAshWindowTreeHostForDisplayId(int64_t id); | 
|  |  | 
|  | // Sets the primary display by display id. This re-assigns the current primary | 
|  | // root window host to to new primary display. | 
|  | void SetPrimaryDisplayId(int64_t id); | 
|  |  | 
|  | // Closes all child windows in the all root windows. | 
|  | void CloseChildWindows(); | 
|  |  | 
|  | // Returns all root windows. In non extended desktop mode, this | 
|  | // returns the primary root window only. | 
|  | aura::Window::Windows GetAllRootWindows(); | 
|  |  | 
|  | // Returns all oot window controllers. In non extended desktop | 
|  | // mode, this return a RootWindowController for the primary root window only. | 
|  | std::vector<RootWindowController*> GetAllRootWindowControllers(); | 
|  |  | 
|  | // Gets/Sets/Clears the overscan insets for the specified |display_id|. See | 
|  | // display_manager.h for the details. | 
|  | gfx::Insets GetOverscanInsets(int64_t display_id) const; | 
|  | void SetOverscanInsets(int64_t display_id, const gfx::Insets& insets_in_dip); | 
|  |  | 
|  | // Checks if the mouse pointer is on one of displays, and moves to | 
|  | // the center of the nearest display if it's outside of all displays. | 
|  | void UpdateMouseLocationAfterDisplayChange(); | 
|  |  | 
|  | // Sets the work area's |insets| to the display assigned to |window|. | 
|  | bool UpdateWorkAreaOfDisplayNearestWindow(const aura::Window* window, | 
|  | const gfx::Insets& insets); | 
|  |  | 
|  | ui::InputMethod* input_method() { return input_method_.get(); } | 
|  |  | 
|  | // display::DisplayObserver overrides: | 
|  | void OnDisplayAdded(const display::Display& display) override; | 
|  | void OnDisplayRemoved(const display::Display& display) override; | 
|  | void OnDisplayMetricsChanged(const display::Display& display, | 
|  | uint32_t metrics) override; | 
|  |  | 
|  | // aura::WindowTreeHostObserver overrides: | 
|  | void OnHostResized(const aura::WindowTreeHost* host) override; | 
|  |  | 
|  | // aura::DisplayManager::Delegate overrides: | 
|  | void CreateOrUpdateMirroringDisplay( | 
|  | const DisplayInfoList& info_list) override; | 
|  | void CloseMirroringDisplayIfNotNecessary() override; | 
|  | void PreDisplayConfigurationChange(bool clear_focus) override; | 
|  | void PostDisplayConfigurationChange() override; | 
|  |  | 
|  | // ui::internal::InputMethodDelegate overrides: | 
|  | ui::EventDispatchDetails DispatchKeyEventPostIME( | 
|  | ui::KeyEvent* event) override; | 
|  |  | 
|  | InputMethodEventHandler* input_method_event_handler() { | 
|  | return input_method_event_handler_.get(); | 
|  | } | 
|  |  | 
|  | private: | 
|  | FRIEND_TEST_ALL_PREFIXES(WindowTreeHostManagerTest, BoundsUpdated); | 
|  | FRIEND_TEST_ALL_PREFIXES(WindowTreeHostManagerTest, SecondaryDisplayLayout); | 
|  | friend class DisplayManager; | 
|  | friend class MirrorWindowController; | 
|  |  | 
|  | // Creates a WindowTreeHost for |display| and stores it in the | 
|  | // |window_tree_hosts_| map. | 
|  | AshWindowTreeHost* AddWindowTreeHostForDisplay( | 
|  | const display::Display& display, | 
|  | const AshWindowTreeHostInitParams& params); | 
|  |  | 
|  | // Delete the AsWindowTreeHost. This does not remove the entry from | 
|  | // |window_tree_hosts_|. Caller has to explicitly remove it. | 
|  | void DeleteHost(AshWindowTreeHost* host_to_delete); | 
|  |  | 
|  | typedef std::map<int64_t, AshWindowTreeHost*> WindowTreeHostMap; | 
|  | // The mapping from display ID to its window tree host. | 
|  | WindowTreeHostMap window_tree_hosts_; | 
|  |  | 
|  | base::ObserverList<Observer, true> observers_; | 
|  |  | 
|  | // Store the primary window tree host temporarily while replacing | 
|  | // display. | 
|  | AshWindowTreeHost* primary_tree_host_for_replace_; | 
|  |  | 
|  | std::unique_ptr<FocusActivationStore> focus_activation_store_; | 
|  |  | 
|  | std::unique_ptr<CursorWindowController> cursor_window_controller_; | 
|  | std::unique_ptr<MirrorWindowController> mirror_window_controller_; | 
|  |  | 
|  | std::unique_ptr<ui::InputMethod> input_method_; | 
|  | std::unique_ptr<InputMethodEventHandler> input_method_event_handler_; | 
|  |  | 
|  | // Stores the current cursor location (in native coordinates and screen | 
|  | // coordinates respectively). The locations are used to restore the cursor | 
|  | // location when the display configuration changes and to determine whether | 
|  | // the mouse should be moved after a display configuration change. | 
|  | gfx::Point cursor_location_in_native_coords_for_restore_; | 
|  | gfx::Point cursor_location_in_screen_coords_for_restore_; | 
|  |  | 
|  | // Stores the cursor's display. The id is used to determine whether the mouse | 
|  | // should be moved after a display configuration change. | 
|  | int64_t cursor_display_id_for_restore_; | 
|  |  | 
|  | base::WeakPtrFactory<WindowTreeHostManager> weak_ptr_factory_; | 
|  |  | 
|  | DISALLOW_COPY_AND_ASSIGN(WindowTreeHostManager); | 
|  | }; | 
|  |  | 
|  | }  // namespace ash | 
|  |  | 
|  | #endif  // ASH_DISPLAY_DISPLAY_CONTROLLER_H_ |