Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(354)

Side by Side Diff: chrome/browser/chromeos/login/wizard_accessibility_helper.cc

Issue 3442011: Enabling access notifications for login wizard (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src/
Patch Set: '' Created 10 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2010 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/login/wizard_accessibility_helper.h" 5 #include "chrome/browser/chromeos/login/wizard_accessibility_helper.h"
6 6
7 #include "base/logging.h" 7 #include "base/logging.h"
8 #include "base/stl_util-inl.h"
8 #include "chrome/browser/browser_process.h" 9 #include "chrome/browser/browser_process.h"
9 #include "chrome/browser/extensions/extension_accessibility_api.h" 10 #include "chrome/browser/extensions/extension_accessibility_api.h"
10 #include "chrome/browser/prefs/pref_service.h" 11 #include "chrome/browser/prefs/pref_service.h"
11 #include "chrome/browser/profile.h" 12 #include "chrome/browser/profile.h"
12 #include "chrome/browser/profile_manager.h" 13 #include "chrome/browser/profile_manager.h"
13 #include "chrome/common/notification_registrar.h" 14 #include "chrome/common/notification_registrar.h"
14 #include "chrome/common/notification_service.h" 15 #include "chrome/common/notification_service.h"
15 #include "chrome/common/pref_names.h" 16 #include "chrome/common/pref_names.h"
17 #include "views/accelerator.h"
18 #include "views/view.h"
19
20 scoped_ptr<views::Accelerator> WizardAccessibilityHelper::accelerator_;
21
22 // static
23 views::Accelerator WizardAccessibilityHelper::GetAccelerator() {
24 if (!WizardAccessibilityHelper::accelerator_.get())
25 WizardAccessibilityHelper::accelerator_.reset(
26 new views::Accelerator(app::VKEY_Z, false, true, true));
27 return *(WizardAccessibilityHelper::accelerator_.get());
Nico 2011/11/21 04:13:47 Why not just return views::Accelerator(app:VKEY
28 }
16 29
17 // static 30 // static
18 WizardAccessibilityHelper* WizardAccessibilityHelper::GetInstance() { 31 WizardAccessibilityHelper* WizardAccessibilityHelper::GetInstance() {
19 return Singleton<WizardAccessibilityHelper>::get(); 32 return Singleton<WizardAccessibilityHelper>::get();
20 } 33 }
21 34
22 WizardAccessibilityHelper::WizardAccessibilityHelper() { 35 WizardAccessibilityHelper::WizardAccessibilityHelper() {
23 accessibility_handler_.reset(new WizardAccessibilityHandler()); 36 accessibility_handler_.reset(new WizardAccessibilityHandler());
37 profile_ = ProfileManager::GetDefaultProfile();
24 registrar_.Add(accessibility_handler_.get(), 38 registrar_.Add(accessibility_handler_.get(),
25 NotificationType::ACCESSIBILITY_CONTROL_FOCUSED, 39 NotificationType::ACCESSIBILITY_CONTROL_FOCUSED,
26 NotificationService::AllSources()); 40 NotificationService::AllSources());
27 registrar_.Add(accessibility_handler_.get(), 41 registrar_.Add(accessibility_handler_.get(),
28 NotificationType::ACCESSIBILITY_CONTROL_ACTION, 42 NotificationType::ACCESSIBILITY_CONTROL_ACTION,
29 NotificationService::AllSources()); 43 NotificationService::AllSources());
30 registrar_.Add(accessibility_handler_.get(), 44 registrar_.Add(accessibility_handler_.get(),
31 NotificationType::ACCESSIBILITY_TEXT_CHANGED, 45 NotificationType::ACCESSIBILITY_TEXT_CHANGED,
32 NotificationService::AllSources()); 46 NotificationService::AllSources());
33 registrar_.Add(accessibility_handler_.get(), 47 registrar_.Add(accessibility_handler_.get(),
34 NotificationType::ACCESSIBILITY_MENU_OPENED, 48 NotificationType::ACCESSIBILITY_MENU_OPENED,
35 NotificationService::AllSources()); 49 NotificationService::AllSources());
36 registrar_.Add(accessibility_handler_.get(), 50 registrar_.Add(accessibility_handler_.get(),
37 NotificationType::ACCESSIBILITY_MENU_CLOSED, 51 NotificationType::ACCESSIBILITY_MENU_CLOSED,
38 NotificationService::AllSources()); 52 NotificationService::AllSources());
39 } 53 }
40 54
41 void WizardAccessibilityHelper::MaybeEnableAccessibility( 55 void WizardAccessibilityHelper::MaybeEnableAccessibility(
42 views::View* view_tree, Profile* profile) { 56 views::View* view_tree) {
43 if (g_browser_process != NULL && 57 if (g_browser_process &&
44 g_browser_process->local_state()->GetBoolean( 58 g_browser_process->local_state()->GetBoolean(
45 prefs::kAccessibilityEnabled)) { 59 prefs::kAccessibilityEnabled)) {
46 EnableAccessibility(view_tree, profile); 60 EnableAccessibility(view_tree);
61 } else {
62 AddViewToBuffer(view_tree);
47 } 63 }
48 } 64 }
49 65
50 void WizardAccessibilityHelper::EnableAccessibility( 66 void WizardAccessibilityHelper::MaybeSpeak(const char* str, bool queue,
51 views::View* view_tree, Profile* profile) { 67 bool interruptible) {
68 if (g_browser_process &&
69 g_browser_process->local_state()->GetBoolean(
70 prefs::kAccessibilityEnabled)) {
71 accessibility_handler_->Speak(str, queue, interruptible);
72 }
73 }
74
75 void WizardAccessibilityHelper::EnableAccessibility(views::View* view_tree) {
52 LOG(INFO) << "Enabling accessibility."; 76 LOG(INFO) << "Enabling accessibility.";
53 if (g_browser_process != NULL) { 77 if (g_browser_process) {
54 PrefService* prefService = g_browser_process->local_state(); 78 PrefService* prefService = g_browser_process->local_state();
55 if (!prefService->GetBoolean(prefs::kAccessibilityEnabled)) { 79 if (!prefService->GetBoolean(prefs::kAccessibilityEnabled)) {
56 prefService->SetBoolean(prefs::kAccessibilityEnabled, true); 80 prefService->SetBoolean(prefs::kAccessibilityEnabled, true);
57 prefService->ScheduleSavePersistentPrefs(); 81 prefService->ScheduleSavePersistentPrefs();
58 } 82 }
59 } 83 }
60 ExtensionAccessibilityEventRouter::GetInstance()-> 84 ExtensionAccessibilityEventRouter::GetInstance()->
61 SetAccessibilityEnabled(true); 85 SetAccessibilityEnabled(true);
62 accessible_view_helper_.reset(new AccessibleViewHelper( 86 AddViewToBuffer(view_tree);
63 view_tree, profile)); 87 // If accessibility pref is set, enable accessibility for all views in
88 // the buffer for which access is not yet enabled.
89 for (std::map<views::View*, bool>::iterator iter =
90 views_buffer_.begin();
91 iter != views_buffer_.end(); ++iter) {
92 if (!(*iter).second) {
93 AccessibleViewHelper *helper = new AccessibleViewHelper((*iter).first,
94 profile_);
95 accessible_view_helpers_.push_back(helper);
96 (*iter).second = true;
97 }
98 }
64 } 99 }
100
101 void WizardAccessibilityHelper::AddViewToBuffer(views::View* view_tree) {
102 if (!view_tree->GetWidget())
103 return;
104 bool view_exists = false;
105 // Check if the view is already queued for enabling accessibility.
106 // Prevent adding the same view in the buffer twice.
107 for (std::map<views::View*, bool>::iterator iter = views_buffer_.begin();
108 iter != views_buffer_.end(); ++iter) {
109 if ((*iter).first == view_tree) {
110 view_exists = true;
111 break;
112 }
113 }
114 if (!view_exists)
115 views_buffer_[view_tree] = false;
116 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698