| OLD | NEW |
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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/display/virtual_keyboard_window_controller.h" | 5 #include "ash/display/virtual_keyboard_window_controller.h" |
| 6 | 6 |
| 7 #include "ash/display/display_controller.h" | 7 #include "ash/display/display_controller.h" |
| 8 #include "ash/display/display_info.h" | 8 #include "ash/display/display_info.h" |
| 9 #include "ash/display/display_manager.h" | 9 #include "ash/display/display_manager.h" |
| 10 #include "ash/host/root_window_host_factory.h" | 10 #include "ash/host/root_window_host_factory.h" |
| 11 #include "ash/root_window_controller.h" | 11 #include "ash/root_window_controller.h" |
| 12 #include "ash/root_window_settings.h" | 12 #include "ash/root_window_settings.h" |
| 13 #include "ash/shell.h" | 13 #include "ash/shell.h" |
| 14 #include "ash/shell_window_ids.h" | 14 #include "ash/shell_window_ids.h" |
| 15 #include "base/strings/stringprintf.h" | 15 #include "base/strings/stringprintf.h" |
| 16 #include "base/strings/utf_string_conversions.h" | 16 #include "base/strings/utf_string_conversions.h" |
| 17 #include "ui/aura/env.h" | 17 #include "ui/aura/env.h" |
| 18 #include "ui/aura/root_window.h" | 18 #include "ui/aura/root_window.h" |
| 19 #include "ui/keyboard/keyboard_controller.h" | |
| 20 | 19 |
| 21 namespace ash { | 20 namespace ash { |
| 22 namespace internal { | 21 namespace internal { |
| 23 | 22 |
| 24 VirtualKeyboardWindowController::VirtualKeyboardWindowController() { | 23 VirtualKeyboardWindowController::VirtualKeyboardWindowController() { |
| 25 } | 24 } |
| 26 | 25 |
| 27 VirtualKeyboardWindowController::~VirtualKeyboardWindowController() { | 26 VirtualKeyboardWindowController::~VirtualKeyboardWindowController() { |
| 28 // Make sure the root window gets deleted before cursor_window_delegate. | 27 // Make sure the root window gets deleted before cursor_window_delegate. |
| 29 Close(); | 28 Close(); |
| 30 } | 29 } |
| 31 | 30 |
| 32 void VirtualKeyboardWindowController::ActivateKeyboard( | |
| 33 keyboard::KeyboardController* keyboard_controller) { | |
| 34 root_window_controller_->ActivateKeyboard(keyboard_controller); | |
| 35 } | |
| 36 | |
| 37 void VirtualKeyboardWindowController::UpdateWindow( | 31 void VirtualKeyboardWindowController::UpdateWindow( |
| 38 const DisplayInfo& display_info) { | 32 const DisplayInfo& display_info) { |
| 39 static int virtual_keyboard_root_window_count = 0; | 33 static int virtual_keyboard_root_window_count = 0; |
| 40 if (!root_window_controller_.get()) { | 34 if (!root_window_controller_.get()) { |
| 41 const gfx::Rect& bounds_in_native = display_info.bounds_in_native(); | 35 const gfx::Rect& bounds_in_native = display_info.bounds_in_native(); |
| 42 aura::RootWindow::CreateParams params(bounds_in_native); | 36 aura::RootWindow::CreateParams params(bounds_in_native); |
| 43 params.host = Shell::GetInstance()->root_window_host_factory()-> | 37 params.host = Shell::GetInstance()->root_window_host_factory()-> |
| 44 CreateRootWindowHost(bounds_in_native); | 38 CreateRootWindowHost(bounds_in_native); |
| 45 aura::RootWindow* root_window = new aura::RootWindow(params); | 39 aura::RootWindow* root_window = new aura::RootWindow(params); |
| 46 | 40 |
| 47 root_window->window()->SetName( | 41 root_window->window()->SetName( |
| 48 base::StringPrintf("VirtualKeyboardRootWindow-%d", | 42 base::StringPrintf("VirtualKeyboardRootWindow-%d", |
| 49 virtual_keyboard_root_window_count++)); | 43 virtual_keyboard_root_window_count++)); |
| 50 | 44 |
| 51 // No need to remove RootWindowObserver because | 45 // No need to remove RootWindowObserver because |
| 52 // the DisplayController object outlives RootWindow objects. | 46 // the DisplayController object outlives RootWindow objects. |
| 53 root_window->AddRootWindowObserver( | 47 root_window->AddRootWindowObserver( |
| 54 Shell::GetInstance()->display_controller()); | 48 Shell::GetInstance()->display_controller()); |
| 55 InitRootWindowSettings(root_window->window())->display_id = | 49 InitRootWindowSettings(root_window->window())->display_id = |
| 56 display_info.id(); | 50 display_info.id(); |
| 57 root_window->Init(); | 51 root_window->Init(); |
| 58 RootWindowController::CreateForVirtualKeyboardDisplay(root_window); | 52 RootWindowController::CreateForVirtualKeyboardDisplay(root_window); |
| 59 root_window_controller_.reset(GetRootWindowController( | 53 root_window_controller_.reset(GetRootWindowController( |
| 60 root_window->window())); | 54 root_window->window())); |
| 61 root_window_controller_->dispatcher()->host()->Show(); | 55 root_window_controller_->dispatcher()->host()->Show(); |
| 62 root_window_controller_->ActivateKeyboard( | |
| 63 Shell::GetInstance()->keyboard_controller()); | |
| 64 } else { | 56 } else { |
| 65 aura::RootWindow* root_window = root_window_controller_->dispatcher(); | 57 aura::RootWindow* root_window = root_window_controller_->dispatcher(); |
| 66 GetRootWindowSettings(root_window->window())->display_id = | 58 GetRootWindowSettings(root_window->window())->display_id = |
| 67 display_info.id(); | 59 display_info.id(); |
| 68 root_window->SetHostBounds(display_info.bounds_in_native()); | 60 root_window->SetHostBounds(display_info.bounds_in_native()); |
| 69 } | 61 } |
| 70 } | 62 } |
| 71 | 63 |
| 72 void VirtualKeyboardWindowController::Close() { | 64 void VirtualKeyboardWindowController::Close() { |
| 73 if (root_window_controller_.get()) { | 65 if (root_window_controller_.get()) { |
| 74 root_window_controller_->dispatcher()->RemoveRootWindowObserver( | 66 root_window_controller_->dispatcher()->RemoveRootWindowObserver( |
| 75 Shell::GetInstance()->display_controller()); | 67 Shell::GetInstance()->display_controller()); |
| 76 root_window_controller_->Shutdown(); | 68 root_window_controller_->Shutdown(); |
| 77 root_window_controller_.reset(); | 69 root_window_controller_.reset(); |
| 78 } | 70 } |
| 79 } | 71 } |
| 80 | 72 |
| 81 } // namespace internal | 73 } // namespace internal |
| 82 } // namespace ash | 74 } // namespace ash |
| OLD | NEW |