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/chromeos/accessibility/accessibility_util.h" | 5 #include "chrome/browser/chromeos/accessibility/accessibility_util.h" |
6 | 6 |
7 #include <queue> | 7 #include <queue> |
8 | 8 |
9 #include "ash/high_contrast/high_contrast_controller.h" | 9 #include "ash/high_contrast/high_contrast_controller.h" |
10 #include "ash/magnifier/magnification_controller.h" | 10 #include "ash/magnifier/magnification_controller.h" |
| 11 #include "ash/magnifier/partial_magnification_controller.h" |
11 #include "ash/shell.h" | 12 #include "ash/shell.h" |
12 #include "base/bind.h" | 13 #include "base/bind.h" |
13 #include "base/bind_helpers.h" | 14 #include "base/bind_helpers.h" |
14 #include "base/logging.h" | 15 #include "base/logging.h" |
15 #include "chrome/browser/accessibility/accessibility_extension_api.h" | 16 #include "chrome/browser/accessibility/accessibility_extension_api.h" |
16 #include "chrome/browser/browser_process.h" | 17 #include "chrome/browser/browser_process.h" |
17 #include "chrome/browser/extensions/component_loader.h" | 18 #include "chrome/browser/extensions/component_loader.h" |
18 #include "chrome/browser/extensions/extension_service.h" | 19 #include "chrome/browser/extensions/extension_service.h" |
19 #include "chrome/browser/extensions/file_reader.h" | 20 #include "chrome/browser/extensions/file_reader.h" |
20 #include "chrome/browser/prefs/pref_service.h" | 21 #include "chrome/browser/prefs/pref_service.h" |
(...skipping 147 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
168 void EnableHighContrast(bool enabled) { | 169 void EnableHighContrast(bool enabled) { |
169 PrefService* pref_service = g_browser_process->local_state(); | 170 PrefService* pref_service = g_browser_process->local_state(); |
170 pref_service->SetBoolean(prefs::kHighContrastEnabled, enabled); | 171 pref_service->SetBoolean(prefs::kHighContrastEnabled, enabled); |
171 pref_service->CommitPendingWrite(); | 172 pref_service->CommitPendingWrite(); |
172 | 173 |
173 #if defined(USE_ASH) | 174 #if defined(USE_ASH) |
174 ash::Shell::GetInstance()->high_contrast_controller()->SetEnabled(enabled); | 175 ash::Shell::GetInstance()->high_contrast_controller()->SetEnabled(enabled); |
175 #endif | 176 #endif |
176 } | 177 } |
177 | 178 |
178 void EnableScreenMagnifier(bool enabled) { | 179 void SetScreenMagnifier(ScreenMagnifierType type) { |
179 PrefService* pref_service = g_browser_process->local_state(); | 180 PrefService* pref_service = g_browser_process->local_state(); |
180 pref_service->SetBoolean(prefs::kScreenMagnifierEnabled, enabled); | 181 pref_service->SetBoolean(prefs::kScreenMagnifierEnabled, |
| 182 type == MagnifierFull); |
| 183 pref_service->SetBoolean(prefs::kPartialScreenMagnifierEnabled, |
| 184 type == MagnifierPartial); |
181 pref_service->CommitPendingWrite(); | 185 pref_service->CommitPendingWrite(); |
182 | 186 |
183 #if defined(USE_ASH) | 187 #if defined(USE_ASH) |
184 ash::Shell::GetInstance()->magnification_controller()->SetEnabled(enabled); | 188 ash::Shell::GetInstance()->magnification_controller()->SetEnabled( |
| 189 type == MagnifierFull); |
| 190 ash::Shell::GetInstance()->partial_magnification_controller()->SetEnabled( |
| 191 type == MagnifierPartial); |
185 #endif | 192 #endif |
186 } | 193 } |
187 | 194 |
188 void EnableVirtualKeyboard(bool enabled) { | 195 void EnableVirtualKeyboard(bool enabled) { |
189 PrefService* pref_service = g_browser_process->local_state(); | 196 PrefService* pref_service = g_browser_process->local_state(); |
190 pref_service->SetBoolean(prefs::kVirtualKeyboardEnabled, enabled); | 197 pref_service->SetBoolean(prefs::kVirtualKeyboardEnabled, enabled); |
191 pref_service->CommitPendingWrite(); | 198 pref_service->CommitPendingWrite(); |
192 } | 199 } |
193 | 200 |
194 void ToggleSpokenFeedback(content::WebUI* login_web_ui) { | 201 void ToggleSpokenFeedback(content::WebUI* login_web_ui) { |
(...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
227 bool IsHighContrastEnabled() { | 234 bool IsHighContrastEnabled() { |
228 if (!g_browser_process) { | 235 if (!g_browser_process) { |
229 return false; | 236 return false; |
230 } | 237 } |
231 PrefService* prefs = g_browser_process->local_state(); | 238 PrefService* prefs = g_browser_process->local_state(); |
232 bool high_contrast_enabled = prefs && | 239 bool high_contrast_enabled = prefs && |
233 prefs->GetBoolean(prefs::kHighContrastEnabled); | 240 prefs->GetBoolean(prefs::kHighContrastEnabled); |
234 return high_contrast_enabled; | 241 return high_contrast_enabled; |
235 } | 242 } |
236 | 243 |
237 bool IsScreenMagnifierEnabled() { | 244 ScreenMagnifierType GetScreenMagnifierType() { |
238 if (!g_browser_process) { | 245 if (!g_browser_process) |
239 return false; | 246 return MagnifierNone; |
240 } | 247 |
241 PrefService* prefs = g_browser_process->local_state(); | 248 PrefService* prefs = g_browser_process->local_state(); |
242 bool enabled = prefs && prefs->GetBoolean(prefs::kScreenMagnifierEnabled); | 249 if (!prefs) |
243 return enabled; | 250 return MagnifierNone; |
| 251 |
| 252 if (prefs->GetBoolean(prefs::kScreenMagnifierEnabled)) |
| 253 return MagnifierFull; |
| 254 else if (prefs->GetBoolean(prefs::kPartialScreenMagnifierEnabled)) |
| 255 return MagnifierPartial; |
| 256 else |
| 257 return MagnifierNone; |
244 } | 258 } |
245 | 259 |
246 void MaybeSpeak(const std::string& utterance) { | 260 void MaybeSpeak(const std::string& utterance) { |
247 if (IsSpokenFeedbackEnabled()) | 261 if (IsSpokenFeedbackEnabled()) |
248 Speak(utterance); | 262 Speak(utterance); |
249 } | 263 } |
250 | 264 |
251 } // namespace accessibility | 265 } // namespace accessibility |
252 } // namespace chromeos | 266 } // namespace chromeos |
OLD | NEW |