| // Copyright 2016 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_WM_SCREEN_PINNING_CONTROLLER_H_ |
| #define ASH_WM_SCREEN_PINNING_CONTROLLER_H_ |
| |
| #include <memory> |
| #include <vector> |
| |
| #include "ash/ash_export.h" |
| #include "ash/display/window_tree_host_manager.h" |
| #include "base/macros.h" |
| |
| namespace aura { |
| class Window; |
| } |
| |
| namespace ash { |
| |
| class WindowDimmer; |
| |
| template <typename UserData> |
| class WindowUserData; |
| |
| // Supports "screen pinning" for ARC++ apps. From the Android docs: |
| // "Lets you temporarily restrict users from leaving your task or being |
| // interrupted by notifications. This could be used, for example, if you are |
| // developing an education app to support high stakes assessment requirements on |
| // Android, or a single-purpose or kiosk application." |
| // https://developer.android.com/about/versions/android-5.0.html#ScreenPinning |
| // See also ArcKioskAppLauncher::CheckAndPinWindow(). |
| class ASH_EXPORT ScreenPinningController |
| : public WindowTreeHostManager::Observer { |
| public: |
| ScreenPinningController(); |
| ~ScreenPinningController() override; |
| |
| // Sets a pinned window. It is not allowed to call this when there already |
| // is a pinned window. |
| void SetPinnedWindow(aura::Window* pinned_window); |
| |
| // Returns true if in pinned mode, otherwise false. |
| bool IsPinned() const; |
| |
| // Returns the pinned window if in pinned mode, or nullptr. |
| aura::Window* pinned_window() const { return pinned_window_; } |
| |
| // Called when a new window is added to the container which has the pinned |
| // window. |
| void OnWindowAddedToPinnedContainer(aura::Window* new_window); |
| |
| // Called when a window will be removed from the container which has the |
| // pinned window. |
| void OnWillRemoveWindowFromPinnedContainer(aura::Window* window); |
| |
| // Called when a window stacking is changed in the container which has the |
| // pinned window. |
| void OnPinnedContainerWindowStackingChanged(aura::Window* window); |
| |
| // Called when a new window is added to a system modal container. |
| void OnWindowAddedToSystemModalContainer(aura::Window* new_window); |
| |
| // Called when a window will be removed from a system modal container. |
| void OnWillRemoveWindowFromSystemModalContainer(aura::Window* window); |
| |
| // Called when a window stacking is changed in a system modal container. |
| void OnSystemModalContainerWindowStackingChanged(aura::Window* window); |
| |
| private: |
| class PinnedContainerWindowObserver; |
| class PinnedContainerChildWindowObserver; |
| class SystemModalContainerWindowObserver; |
| class SystemModalContainerChildWindowObserver; |
| |
| // Keeps the pinned window on top of the siblings. |
| void KeepPinnedWindowOnTop(); |
| |
| // Keeps the dim window at bottom of the container. |
| void KeepDimWindowAtBottom(aura::Window* container); |
| |
| // Creates a WindowDimmer for |container| and places it in |window_dimmers_|. |
| // Returns the window from WindowDimmer. |
| aura::Window* CreateWindowDimmer(aura::Window* container); |
| |
| // WindowTreeHostManager::Observer: |
| void OnDisplayConfigurationChanged() override; |
| |
| // Pinned window should be on top in the parent window. |
| aura::Window* pinned_window_ = nullptr; |
| |
| // Owns the WindowDimmers. There is one WindowDimmer for the parent of |
| // |pinned_window_| and one for each display other than the display |
| // |pinned_window_| is on. |
| std::unique_ptr<WindowUserData<WindowDimmer>> window_dimmers_; |
| |
| // Set true only when restacking done by this controller. |
| bool in_restacking_ = false; |
| |
| // Window observers to translate events for the window to this controller. |
| std::unique_ptr<PinnedContainerWindowObserver> |
| pinned_container_window_observer_; |
| std::unique_ptr<PinnedContainerChildWindowObserver> |
| pinned_container_child_window_observer_; |
| std::unique_ptr<SystemModalContainerWindowObserver> |
| system_modal_container_window_observer_; |
| std::unique_ptr<SystemModalContainerChildWindowObserver> |
| system_modal_container_child_window_observer_; |
| |
| DISALLOW_COPY_AND_ASSIGN(ScreenPinningController); |
| }; |
| |
| } // namespace ash |
| |
| #endif // ASH_WM_SCREEN_PINNING_CONTROLLER_H_ |