diff options
author | hshi@chromium.org <hshi@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2014-03-05 18:39:52 +0000 |
---|---|---|
committer | hshi@chromium.org <hshi@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2014-03-05 18:39:52 +0000 |
commit | b2da9b606286f651cf45d9312fa5ed8e2ca9c401 (patch) | |
tree | 4c7b561c712ee3247e94402b42476d9d3825cfb2 /ash | |
parent | e82abea5720382429c29c2691d4d17e0719185da (diff) | |
download | chromium_src-b2da9b606286f651cf45d9312fa5ed8e2ca9c401.zip chromium_src-b2da9b606286f651cf45d9312fa5ed8e2ca9c401.tar.gz chromium_src-b2da9b606286f651cf45d9312fa5ed8e2ca9c401.tar.bz2 |
Make Chrome OS virtual keyboard to work with cursor compositing.
Explicitly define container IDs for the parent container of the virtual keyboard,
as well as the mouse cursor container.
This is to ensure the correct ordering in which containers are stacked together.
Specifically the virtual keyboard parent container should be above all non-lock screen,
lock screen and lock screen related containers, but below the mouse cursor container,
which sits immediately below the power animation container.
BUG=347304
TEST=trybots and manual verification.
R=kevers@chromium.org, oshima@chromium.org
Review URL: https://codereview.chromium.org/186673008
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@255096 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'ash')
-rw-r--r-- | ash/display/cursor_window_controller.cc | 2 | ||||
-rw-r--r-- | ash/root_window_controller.cc | 25 | ||||
-rw-r--r-- | ash/shell_unittest.cc | 6 | ||||
-rw-r--r-- | ash/shell_window_ids.h | 10 |
4 files changed, 38 insertions, 5 deletions
diff --git a/ash/display/cursor_window_controller.cc b/ash/display/cursor_window_controller.cc index 05f242d..6fb1a08 100644 --- a/ash/display/cursor_window_controller.cc +++ b/ash/display/cursor_window_controller.cc @@ -137,7 +137,7 @@ void CursorWindowController::SetDisplay(const gfx::Display& display) { return; SetContainer(GetRootWindowController(root_window)->GetContainer( - kShellWindowId_OverlayContainer)); + kShellWindowId_MouseCursorContainer)); SetBoundsInScreen(display.bounds()); } diff --git a/ash/root_window_controller.cc b/ash/root_window_controller.cc index 06687e4..55196b4 100644 --- a/ash/root_window_controller.cc +++ b/ash/root_window_controller.cc @@ -617,7 +617,9 @@ void RootWindowController::ActivateKeyboard( keyboard_controller->AddObserver(panel_layout_manager_); keyboard_controller->AddObserver(docked_layout_manager_); } - aura::Window* parent = root_window(); + aura::Window* parent = GetContainer( + kShellWindowId_VirtualKeyboardParentContainer); + DCHECK(parent); aura::Window* keyboard_container = keyboard_controller->GetContainerWindow(); keyboard_container->set_id(kShellWindowId_VirtualKeyboardContainer); @@ -636,7 +638,10 @@ void RootWindowController::DeactivateKeyboard( aura::Window* keyboard_container = keyboard_controller->GetContainerWindow(); if (keyboard_container->GetRootWindow() == root_window()) { - root_window()->RemoveChild(keyboard_container); + aura::Window* parent = GetContainer( + kShellWindowId_VirtualKeyboardParentContainer); + DCHECK(parent); + parent->RemoveChild(keyboard_container); if (!keyboard::IsKeyboardUsabilityExperimentEnabled()) { // Virtual keyboard may be deactivated while still showing, notify all // observers that keyboard bounds changed to 0 before remove them. @@ -966,8 +971,22 @@ void RootWindowController::CreateContainersInRootWindow( lock_screen_related_containers); SetUsesScreenCoordinates(overlay_container); + aura::Window* virtual_keyboard_parent_container = CreateContainer( + kShellWindowId_VirtualKeyboardParentContainer, + "VirtualKeyboardParentContainer", + root_window); + SetUsesScreenCoordinates(virtual_keyboard_parent_container); + +#if defined(OS_CHROMEOS) + aura::Window* mouse_cursor_container = CreateContainer( + kShellWindowId_MouseCursorContainer, + "MouseCursorContainer", + root_window); + SetUsesScreenCoordinates(mouse_cursor_container); +#endif + CreateContainer(kShellWindowId_PowerButtonAnimationContainer, - "PowerButtonAnimationContainer", root_window) ; + "PowerButtonAnimationContainer", root_window); } void RootWindowController::EnableTouchHudProjection() { diff --git a/ash/shell_unittest.cc b/ash/shell_unittest.cc index 7dd9246..160d6b4 100644 --- a/ash/shell_unittest.cc +++ b/ash/shell_unittest.cc @@ -87,6 +87,12 @@ void ExpectAllContainers() { root_window, internal::kShellWindowId_SettingBubbleContainer)); EXPECT_TRUE(Shell::GetContainer( root_window, internal::kShellWindowId_OverlayContainer)); + EXPECT_TRUE(Shell::GetContainer( + root_window, internal::kShellWindowId_VirtualKeyboardParentContainer)); +#if defined(OS_CHROMEOS) + EXPECT_TRUE(Shell::GetContainer( + root_window, internal::kShellWindowId_MouseCursorContainer)); +#endif } class ModalWindow : public views::WidgetDelegateView { diff --git a/ash/shell_window_ids.h b/ash/shell_window_ids.h index ab5fd23..aedc8b5 100644 --- a/ash/shell_window_ids.h +++ b/ash/shell_window_ids.h @@ -99,8 +99,16 @@ const int kShellWindowId_OverlayContainer = 22; // ID of the window created by PhantomWindowController or DragWindowController. const int kShellWindowId_PhantomWindow = 23; +// A parent container that holds the virtual keyboard container. This is to +// ensure that the virtual keyboard is stacked above most containers but below +// the mouse cursor and the power off animation. +const int kShellWindowId_VirtualKeyboardParentContainer = 24; + +// The container for mouse cursor. +const int kShellWindowId_MouseCursorContainer = 25; + // The topmost container, used for power off animation. -const int kShellWindowId_PowerButtonAnimationContainer = 24; +const int kShellWindowId_PowerButtonAnimationContainer = 26; } // namespace internal |