OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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 "chrome/browser/ui/ash/ash_init.h" | 5 #include "chrome/browser/ui/ash/ash_init.h" |
6 | 6 |
7 #include "ash/accelerators/accelerator_controller.h" | 7 #include "ash/accelerators/accelerator_controller.h" |
8 #include "ash/accelerometer/accelerometer_controller.h" | |
9 #include "ash/ash_switches.h" | 8 #include "ash/ash_switches.h" |
10 #include "ash/high_contrast/high_contrast_controller.h" | 9 #include "ash/high_contrast/high_contrast_controller.h" |
11 #include "ash/magnifier/magnification_controller.h" | 10 #include "ash/magnifier/magnification_controller.h" |
12 #include "ash/magnifier/partial_magnification_controller.h" | 11 #include "ash/magnifier/partial_magnification_controller.h" |
13 #include "ash/shell.h" | 12 #include "ash/shell.h" |
14 #include "ash/shell_init_params.h" | 13 #include "ash/shell_init_params.h" |
15 #include "base/command_line.h" | 14 #include "base/command_line.h" |
16 #include "chrome/browser/browser_shutdown.h" | 15 #include "chrome/browser/browser_shutdown.h" |
17 #include "chrome/browser/lifetime/application_lifetime.h" | 16 #include "chrome/browser/lifetime/application_lifetime.h" |
18 #include "chrome/browser/ui/ash/chrome_screenshot_grabber.h" | 17 #include "chrome/browser/ui/ash/chrome_screenshot_grabber.h" |
19 #include "chrome/browser/ui/ash/chrome_shell_delegate.h" | 18 #include "chrome/browser/ui/ash/chrome_shell_delegate.h" |
20 #include "chrome/common/chrome_switches.h" | 19 #include "chrome/common/chrome_switches.h" |
21 #include "content/public/browser/browser_thread.h" | 20 #include "content/public/browser/browser_thread.h" |
22 #include "content/public/browser/context_factory.h" | 21 #include "content/public/browser/context_factory.h" |
23 #include "ui/aura/env.h" | 22 #include "ui/aura/env.h" |
24 #include "ui/aura/window_tree_host.h" | 23 #include "ui/aura/window_tree_host.h" |
25 | 24 |
26 #if defined(OS_CHROMEOS) | 25 #if defined(OS_CHROMEOS) |
27 #include "base/sys_info.h" | 26 #include "base/sys_info.h" |
28 #include "chrome/browser/chromeos/accessibility/accessibility_manager.h" | 27 #include "chrome/browser/chromeos/accessibility/accessibility_manager.h" |
29 #include "chrome/browser/chromeos/accessibility/magnification_manager.h" | 28 #include "chrome/browser/chromeos/accessibility/magnification_manager.h" |
30 #include "chrome/browser/ui/ash/ime_controller_chromeos.h" | 29 #include "chrome/browser/ui/ash/ime_controller_chromeos.h" |
31 #include "chrome/browser/ui/ash/volume_controller_chromeos.h" | 30 #include "chrome/browser/ui/ash/volume_controller_chromeos.h" |
| 31 #include "chromeos/accelerometer/accelerometer_reader.h" |
32 #include "chromeos/chromeos_switches.h" | 32 #include "chromeos/chromeos_switches.h" |
33 #include "chromeos/login/login_state.h" | 33 #include "chromeos/login/login_state.h" |
34 #include "ui/base/x/x11_util.h" | 34 #include "ui/base/x/x11_util.h" |
35 #endif | 35 #endif |
36 | 36 |
37 namespace chrome { | 37 namespace chrome { |
38 | 38 |
39 void OpenAsh(gfx::AcceleratedWidget remote_window) { | 39 void OpenAsh(gfx::AcceleratedWidget remote_window) { |
40 #if defined(OS_CHROMEOS) | 40 #if defined(OS_CHROMEOS) |
41 #if defined(USE_X11) | 41 #if defined(USE_X11) |
(...skipping 14 matching lines...) Expand all Loading... |
56 // Shell takes ownership of ChromeShellDelegate. | 56 // Shell takes ownership of ChromeShellDelegate. |
57 shell_init_params.delegate = new ChromeShellDelegate; | 57 shell_init_params.delegate = new ChromeShellDelegate; |
58 shell_init_params.context_factory = content::GetContextFactory(); | 58 shell_init_params.context_factory = content::GetContextFactory(); |
59 #if defined(OS_WIN) | 59 #if defined(OS_WIN) |
60 shell_init_params.remote_hwnd = remote_window; | 60 shell_init_params.remote_hwnd = remote_window; |
61 #endif | 61 #endif |
62 | 62 |
63 ash::Shell* shell = ash::Shell::CreateInstance(shell_init_params); | 63 ash::Shell* shell = ash::Shell::CreateInstance(shell_init_params); |
64 shell->accelerator_controller()->SetScreenshotDelegate( | 64 shell->accelerator_controller()->SetScreenshotDelegate( |
65 scoped_ptr<ash::ScreenshotDelegate>(new ChromeScreenshotGrabber).Pass()); | 65 scoped_ptr<ash::ScreenshotDelegate>(new ChromeScreenshotGrabber).Pass()); |
| 66 #if defined(OS_CHROMEOS) |
66 // TODO(flackr): Investigate exposing a blocking pool task runner to chromeos. | 67 // TODO(flackr): Investigate exposing a blocking pool task runner to chromeos. |
67 shell->accelerometer_controller()->Initialize( | 68 shell->accelerometer_reader()->Initialize( |
68 content::BrowserThread::GetBlockingPool()-> | 69 content::BrowserThread::GetBlockingPool() |
69 GetTaskRunnerWithShutdownBehavior( | 70 ->GetTaskRunnerWithShutdownBehavior( |
70 base::SequencedWorkerPool::SKIP_ON_SHUTDOWN)); | 71 base::SequencedWorkerPool::SKIP_ON_SHUTDOWN)); |
71 #if defined(OS_CHROMEOS) | |
72 shell->accelerator_controller()->SetImeControlDelegate( | 72 shell->accelerator_controller()->SetImeControlDelegate( |
73 scoped_ptr<ash::ImeControlDelegate>(new ImeController).Pass()); | 73 scoped_ptr<ash::ImeControlDelegate>(new ImeController).Pass()); |
74 shell->high_contrast_controller()->SetEnabled( | 74 shell->high_contrast_controller()->SetEnabled( |
75 chromeos::AccessibilityManager::Get()->IsHighContrastEnabled()); | 75 chromeos::AccessibilityManager::Get()->IsHighContrastEnabled()); |
76 | 76 |
77 DCHECK(chromeos::MagnificationManager::Get()); | 77 DCHECK(chromeos::MagnificationManager::Get()); |
78 bool magnifier_enabled = | 78 bool magnifier_enabled = |
79 chromeos::MagnificationManager::Get()->IsMagnifierEnabled(); | 79 chromeos::MagnificationManager::Get()->IsMagnifierEnabled(); |
80 ui::MagnifierType magnifier_type = | 80 ui::MagnifierType magnifier_type = |
81 chromeos::MagnificationManager::Get()->GetMagnifierType(); | 81 chromeos::MagnificationManager::Get()->GetMagnifierType(); |
82 shell->magnification_controller()-> | 82 shell->magnification_controller()-> |
83 SetEnabled(magnifier_enabled && magnifier_type == ui::MAGNIFIER_FULL); | 83 SetEnabled(magnifier_enabled && magnifier_type == ui::MAGNIFIER_FULL); |
84 shell->partial_magnification_controller()-> | 84 shell->partial_magnification_controller()-> |
85 SetEnabled(magnifier_enabled && magnifier_type == ui::MAGNIFIER_PARTIAL); | 85 SetEnabled(magnifier_enabled && magnifier_type == ui::MAGNIFIER_PARTIAL); |
86 | 86 |
87 if (!CommandLine::ForCurrentProcess()->HasSwitch( | 87 if (!CommandLine::ForCurrentProcess()->HasSwitch( |
88 switches::kDisableZeroBrowsersOpenForTests)) { | 88 switches::kDisableZeroBrowsersOpenForTests)) { |
89 chrome::IncrementKeepAliveCount(); | 89 chrome::IncrementKeepAliveCount(); |
90 } | 90 } |
91 #endif | 91 #endif |
92 ash::Shell::GetPrimaryRootWindow()->GetHost()->Show(); | 92 ash::Shell::GetPrimaryRootWindow()->GetHost()->Show(); |
93 } | 93 } |
94 | 94 |
95 void CloseAsh() { | 95 void CloseAsh() { |
96 if (ash::Shell::HasInstance()) | 96 if (ash::Shell::HasInstance()) |
97 ash::Shell::DeleteInstance(); | 97 ash::Shell::DeleteInstance(); |
98 } | 98 } |
99 | 99 |
100 } // namespace chrome | 100 } // namespace chrome |
OLD | NEW |