Chromium Code Reviews| 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 "content/browser/accessibility/browser_accessibility_manager_mac.h" | 5 #include "content/browser/accessibility/browser_accessibility_manager_mac.h" |
| 6 | 6 |
| 7 #import "base/logging.h" | 7 #import "base/logging.h" |
| 8 #import "content/browser/accessibility/browser_accessibility_cocoa.h" | 8 #import "content/browser/accessibility/browser_accessibility_cocoa.h" |
| 9 #import "content/browser/accessibility/browser_accessibility_mac.h" | 9 #import "content/browser/accessibility/browser_accessibility_mac.h" |
| 10 #include "content/common/accessibility_messages.h" | 10 #include "content/common/accessibility_messages.h" |
| (...skipping 26 matching lines...) Expand all Loading... | |
| 37 empty_document.role = ui::AX_ROLE_ROOT_WEB_AREA; | 37 empty_document.role = ui::AX_ROLE_ROOT_WEB_AREA; |
| 38 empty_document.state = | 38 empty_document.state = |
| 39 1 << ui::AX_STATE_READ_ONLY; | 39 1 << ui::AX_STATE_READ_ONLY; |
| 40 ui::AXTreeUpdate update; | 40 ui::AXTreeUpdate update; |
| 41 update.nodes.push_back(empty_document); | 41 update.nodes.push_back(empty_document); |
| 42 return update; | 42 return update; |
| 43 } | 43 } |
| 44 | 44 |
| 45 BrowserAccessibility* BrowserAccessibilityManagerMac::GetFocus( | 45 BrowserAccessibility* BrowserAccessibilityManagerMac::GetFocus( |
| 46 BrowserAccessibility* root) { | 46 BrowserAccessibility* root) { |
| 47 BrowserAccessibility* node = GetActiveDescendantFocus(root); | 47 // On Mac, list boxes should always get focus on the whole list, otherwise |
| 48 return node; | 48 // information about the number of selected items will never be reported. |
| 49 BrowserAccessibility* node = BrowserAccessibilityManager::GetFocus(root); | |
| 50 if (node && node->GetRole() == ui::AX_ROLE_LIST_BOX) | |
| 51 return node; | |
| 52 | |
| 53 // For other roles, follow the active descendant. | |
| 54 return GetActiveDescendantFocus(root); | |
| 49 } | 55 } |
| 50 | 56 |
| 51 void BrowserAccessibilityManagerMac::NotifyAccessibilityEvent( | 57 void BrowserAccessibilityManagerMac::NotifyAccessibilityEvent( |
| 52 ui::AXEvent event_type, | 58 ui::AXEvent event_type, |
| 53 BrowserAccessibility* node) { | 59 BrowserAccessibility* node) { |
| 54 if (!node->IsNative()) | 60 if (!node->IsNative()) |
| 55 return; | 61 return; |
| 56 | 62 |
| 63 if (event_type == ui::AX_EVENT_FOCUS && | |
| 64 node->GetRole() == ui::AX_ROLE_LIST_BOX_OPTION && | |
| 65 node->GetParent() && | |
| 66 node->GetParent()->GetRole() == ui::AX_ROLE_LIST_BOX) { | |
|
je_julie(Not used)
2015/04/06 10:31:48
For this condition, how about extending IsListBoxO
| |
| 67 node = node->GetParent(); | |
| 68 SetFocus(node, false); | |
| 69 } | |
| 70 | |
| 57 // Refer to AXObjectCache.mm (webkit). | 71 // Refer to AXObjectCache.mm (webkit). |
| 58 NSString* event_id = @""; | 72 NSString* event_id = @""; |
| 59 switch (event_type) { | 73 switch (event_type) { |
| 60 case ui::AX_EVENT_ACTIVEDESCENDANTCHANGED: | 74 case ui::AX_EVENT_ACTIVEDESCENDANTCHANGED: |
| 61 if (node->GetRole() == ui::AX_ROLE_TREE) { | 75 if (node->GetRole() == ui::AX_ROLE_TREE) { |
| 62 event_id = NSAccessibilitySelectedRowsChangedNotification; | 76 event_id = NSAccessibilitySelectedRowsChangedNotification; |
| 63 } else { | 77 } else { |
| 64 event_id = NSAccessibilityFocusedUIElementChangedNotification; | 78 event_id = NSAccessibilityFocusedUIElementChangedNotification; |
| 65 BrowserAccessibility* active_descendant_focus = | 79 BrowserAccessibility* active_descendant_focus = |
| 66 GetActiveDescendantFocus(GetRoot()); | 80 GetActiveDescendantFocus(GetRoot()); |
| (...skipping 65 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 132 case ui::AX_EVENT_MENU_LIST_ITEM_SELECTED: | 146 case ui::AX_EVENT_MENU_LIST_ITEM_SELECTED: |
| 133 // Not used on Mac. | 147 // Not used on Mac. |
| 134 return; | 148 return; |
| 135 case ui::AX_EVENT_TEXT_CHANGED: | 149 case ui::AX_EVENT_TEXT_CHANGED: |
| 136 // Not used on Mac. | 150 // Not used on Mac. |
| 137 return; | 151 return; |
| 138 default: | 152 default: |
| 139 LOG(WARNING) << "Unknown accessibility event: " << event_type; | 153 LOG(WARNING) << "Unknown accessibility event: " << event_type; |
| 140 return; | 154 return; |
| 141 } | 155 } |
| 156 | |
| 142 BrowserAccessibilityCocoa* native_node = node->ToBrowserAccessibilityCocoa(); | 157 BrowserAccessibilityCocoa* native_node = node->ToBrowserAccessibilityCocoa(); |
| 143 DCHECK(native_node); | 158 DCHECK(native_node); |
| 144 NSAccessibilityPostNotification(native_node, event_id); | 159 NSAccessibilityPostNotification(native_node, event_id); |
| 145 } | 160 } |
| 146 | 161 |
| 147 void BrowserAccessibilityManagerMac::OnAtomicUpdateFinished( | 162 void BrowserAccessibilityManagerMac::OnAtomicUpdateFinished( |
| 148 bool root_changed, const std::vector<ui::AXTreeDelegate::Change>& changes) { | 163 bool root_changed, const std::vector<ui::AXTreeDelegate::Change>& changes) { |
| 149 BrowserAccessibilityManager::OnAtomicUpdateFinished(root_changed, changes); | 164 BrowserAccessibilityManager::OnAtomicUpdateFinished(root_changed, changes); |
| 150 | 165 |
| 151 bool created_live_region = false; | 166 bool created_live_region = false; |
| (...skipping 15 matching lines...) Expand all Loading... | |
| 167 // page for live regions once. By recreating the NSAccessibility | 182 // page for live regions once. By recreating the NSAccessibility |
| 168 // object for the root of the tree, we force VoiceOver to clear out its | 183 // object for the root of the tree, we force VoiceOver to clear out its |
| 169 // internal state and find newly-added live regions this time. | 184 // internal state and find newly-added live regions this time. |
| 170 BrowserAccessibilityMac* root = | 185 BrowserAccessibilityMac* root = |
| 171 static_cast<BrowserAccessibilityMac*>(GetRoot()); | 186 static_cast<BrowserAccessibilityMac*>(GetRoot()); |
| 172 root->RecreateNativeObject(); | 187 root->RecreateNativeObject(); |
| 173 NotifyAccessibilityEvent(ui::AX_EVENT_CHILDREN_CHANGED, root); | 188 NotifyAccessibilityEvent(ui::AX_EVENT_CHILDREN_CHANGED, root); |
| 174 } | 189 } |
| 175 | 190 |
| 176 } // namespace content | 191 } // namespace content |
| OLD | NEW |