OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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/aura/accessibility/automation_manager_aura.h" | 5 #include "chrome/browser/ui/aura/accessibility/automation_manager_aura.h" |
6 | 6 |
7 #include <vector> | 7 #include <vector> |
8 | 8 |
9 #include "base/memory/singleton.h" | 9 #include "base/memory/singleton.h" |
10 #include "chrome/browser/browser_process.h" | 10 #include "chrome/browser/browser_process.h" |
11 #include "chrome/browser/extensions/api/automation_internal/automation_util.h" | 11 #include "chrome/browser/extensions/api/automation_internal/automation_event_rou
ter.h" |
12 #include "chrome/browser/profiles/profile_manager.h" | 12 #include "chrome/browser/profiles/profile_manager.h" |
| 13 #include "chrome/common/extensions/chrome_extension_messages.h" |
13 #include "content/public/browser/ax_event_notification_details.h" | 14 #include "content/public/browser/ax_event_notification_details.h" |
14 #include "content/public/browser/browser_context.h" | 15 #include "content/public/browser/browser_context.h" |
15 #include "ui/aura/window.h" | 16 #include "ui/aura/window.h" |
16 #include "ui/views/accessibility/ax_aura_obj_cache.h" | 17 #include "ui/views/accessibility/ax_aura_obj_cache.h" |
17 #include "ui/views/accessibility/ax_aura_obj_wrapper.h" | 18 #include "ui/views/accessibility/ax_aura_obj_wrapper.h" |
18 #include "ui/views/view.h" | 19 #include "ui/views/view.h" |
19 #include "ui/views/widget/widget.h" | 20 #include "ui/views/widget/widget.h" |
20 | 21 |
21 using content::BrowserContext; | 22 using content::BrowserContext; |
| 23 using extensions::AutomationEventRouter; |
22 | 24 |
23 // static | 25 // static |
24 AutomationManagerAura* AutomationManagerAura::GetInstance() { | 26 AutomationManagerAura* AutomationManagerAura::GetInstance() { |
25 return Singleton<AutomationManagerAura>::get(); | 27 return Singleton<AutomationManagerAura>::get(); |
26 } | 28 } |
27 | 29 |
28 void AutomationManagerAura::Enable(BrowserContext* context) { | 30 void AutomationManagerAura::Enable(BrowserContext* context) { |
29 enabled_ = true; | 31 enabled_ = true; |
30 if (!current_tree_.get()) | 32 if (!current_tree_.get()) |
31 current_tree_.reset(new AXTreeSourceAura()); | 33 current_tree_.reset(new AXTreeSourceAura()); |
(...skipping 25 matching lines...) Expand all Loading... |
57 if (!context && g_browser_process->profile_manager()) | 59 if (!context && g_browser_process->profile_manager()) |
58 context = g_browser_process->profile_manager()->GetLastUsedProfile(); | 60 context = g_browser_process->profile_manager()->GetLastUsedProfile(); |
59 | 61 |
60 if (!context) { | 62 if (!context) { |
61 LOG(WARNING) << "Accessibility notification but no browser context"; | 63 LOG(WARNING) << "Accessibility notification but no browser context"; |
62 return; | 64 return; |
63 } | 65 } |
64 | 66 |
65 views::AXAuraObjWrapper* aura_obj = | 67 views::AXAuraObjWrapper* aura_obj = |
66 views::AXAuraObjCache::GetInstance()->GetOrCreate(view); | 68 views::AXAuraObjCache::GetInstance()->GetOrCreate(view); |
67 | |
68 if (processing_events_) { | |
69 pending_events_.push_back(std::make_pair(aura_obj, event_type)); | |
70 return; | |
71 } | |
72 | |
73 processing_events_ = true; | |
74 SendEvent(context, aura_obj, event_type); | 69 SendEvent(context, aura_obj, event_type); |
75 | |
76 for (size_t i = 0; i < pending_events_.size(); ++i) | |
77 SendEvent(context, pending_events_[i].first, pending_events_[i].second); | |
78 | |
79 processing_events_ = false; | |
80 pending_events_.clear(); | |
81 } | 70 } |
82 | 71 |
83 void AutomationManagerAura::HandleAlert(content::BrowserContext* context, | 72 void AutomationManagerAura::HandleAlert(content::BrowserContext* context, |
84 const std::string& text) { | 73 const std::string& text) { |
85 if (!enabled_) | 74 if (!enabled_) |
86 return; | 75 return; |
87 | 76 |
88 views::AXAuraObjWrapper* obj = | 77 views::AXAuraObjWrapper* obj = |
89 static_cast<AXRootObjWrapper*>(current_tree_->GetRoot()) | 78 static_cast<AXRootObjWrapper*>(current_tree_->GetRoot()) |
90 ->GetAlertForText(text); | 79 ->GetAlertForText(text); |
(...skipping 34 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
125 } | 114 } |
126 | 115 |
127 void AutomationManagerAura::ResetSerializer() { | 116 void AutomationManagerAura::ResetSerializer() { |
128 current_tree_serializer_.reset( | 117 current_tree_serializer_.reset( |
129 new ui::AXTreeSerializer<views::AXAuraObjWrapper*>(current_tree_.get())); | 118 new ui::AXTreeSerializer<views::AXAuraObjWrapper*>(current_tree_.get())); |
130 } | 119 } |
131 | 120 |
132 void AutomationManagerAura::SendEvent(BrowserContext* context, | 121 void AutomationManagerAura::SendEvent(BrowserContext* context, |
133 views::AXAuraObjWrapper* aura_obj, | 122 views::AXAuraObjWrapper* aura_obj, |
134 ui::AXEvent event_type) { | 123 ui::AXEvent event_type) { |
135 ui::AXTreeUpdate update; | 124 if (processing_events_) { |
136 current_tree_serializer_->SerializeChanges(aura_obj, &update); | 125 pending_events_.push_back(std::make_pair(aura_obj, event_type)); |
| 126 return; |
| 127 } |
| 128 processing_events_ = true; |
137 | 129 |
138 // Route this event to special process/routing ids recognized by the | 130 ExtensionMsg_AccessibilityEventParams params; |
139 // Automation API as the desktop tree. | 131 current_tree_serializer_->SerializeChanges(aura_obj, ¶ms.update); |
140 // TODO(dtseng): Would idealy define these special desktop constants in idl. | 132 params.tree_id = 0; |
141 content::AXEventNotificationDetails detail( | 133 params.id = aura_obj->GetID(); |
142 update.node_id_to_clear, update.nodes, event_type, aura_obj->GetID(), | 134 params.event_type = event_type; |
143 std::map<int32, int>(), | 135 AutomationEventRouter* router = AutomationEventRouter::GetInstance(); |
144 0, /* process_id */ | 136 router->DispatchAccessibilityEvent(params); |
145 0 /* routing_id */); | 137 |
146 std::vector<content::AXEventNotificationDetails> details; | 138 processing_events_ = false; |
147 details.push_back(detail); | 139 auto pending_events_copy = pending_events_; |
148 extensions::automation_util::DispatchAccessibilityEventsToAutomation( | 140 pending_events_.clear(); |
149 details, context, gfx::Vector2d()); | 141 for (size_t i = 0; i < pending_events_copy.size(); ++i) { |
| 142 SendEvent(context, |
| 143 pending_events_copy[i].first, |
| 144 pending_events_copy[i].second); |
| 145 } |
150 } | 146 } |
151 | 147 |
152 void AutomationManagerAura::OnNativeFocusChanged(aura::Window* focused_now) { | 148 void AutomationManagerAura::OnNativeFocusChanged(aura::Window* focused_now) { |
153 focused_window_ = focused_now; | 149 focused_window_ = focused_now; |
154 if (focused_now && !focused_now->HasObserver(this)) | 150 if (focused_now && !focused_now->HasObserver(this)) |
155 focused_now->AddObserver(this); | 151 focused_now->AddObserver(this); |
156 } | 152 } |
157 | 153 |
158 void AutomationManagerAura::OnWindowDestroying(aura::Window* window) { | 154 void AutomationManagerAura::OnWindowDestroying(aura::Window* window) { |
159 if (focused_window_ == window) { | 155 if (focused_window_ == window) { |
160 window->RemoveObserver(this); | 156 window->RemoveObserver(this); |
161 focused_window_ = nullptr; | 157 focused_window_ = nullptr; |
162 } | 158 } |
163 } | 159 } |
OLD | NEW |