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.h" | 5 #include "content/browser/accessibility/browser_accessibility_manager.h" |
6 | 6 |
7 #include <stddef.h> | 7 #include <stddef.h> |
8 | 8 |
9 #include "base/logging.h" | 9 #include "base/logging.h" |
10 #include "build/build_config.h" | 10 #include "build/build_config.h" |
(...skipping 365 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
376 // Find the node corresponding to the id that's the target of the | 376 // Find the node corresponding to the id that's the target of the |
377 // event (which may not be the root of the update tree). | 377 // event (which may not be the root of the update tree). |
378 ui::AXNode* node = tree_->GetFromId(detail.id); | 378 ui::AXNode* node = tree_->GetFromId(detail.id); |
379 if (!node) | 379 if (!node) |
380 continue; | 380 continue; |
381 | 381 |
382 ui::AXEvent event_type = detail.event_type; | 382 ui::AXEvent event_type = detail.event_type; |
383 if (event_type == ui::AX_EVENT_FOCUS || | 383 if (event_type == ui::AX_EVENT_FOCUS || |
384 event_type == ui::AX_EVENT_BLUR) { | 384 event_type == ui::AX_EVENT_BLUR) { |
385 if (osk_state_ != OSK_DISALLOWED_BECAUSE_TAB_HIDDEN && | 385 if (osk_state_ != OSK_DISALLOWED_BECAUSE_TAB_HIDDEN && |
386 osk_state_ != OSK_DISALLOWED_BECAUSE_TAB_JUST_APPEARED) | 386 osk_state_ != OSK_DISALLOWED_BECAUSE_TAB_JUST_APPEARED) { |
387 osk_state_ = OSK_ALLOWED; | 387 osk_state_ = OSK_ALLOWED; |
| 388 } |
388 | 389 |
389 bool is_menu_list_option = | 390 // We already handled all focus events above. |
390 node->data().role == ui::AX_ROLE_MENU_LIST_OPTION; | 391 continue; |
391 | |
392 // Skip all focus events other than ones on menu list options; | |
393 // we've already handled them, above. Menu list options are a weird | |
394 // exception because the menu list itself has focus but we need to fire | |
395 // focus events on the individual options. | |
396 if (!is_menu_list_option) | |
397 continue; | |
398 } | 392 } |
399 | 393 |
400 // Fire the native event. | 394 // Fire the native event. |
401 NotifyAccessibilityEvent(event_type, GetFromAXNode(node)); | 395 NotifyAccessibilityEvent(event_type, GetFromAXNode(node)); |
402 } | 396 } |
403 } | 397 } |
404 | 398 |
405 void BrowserAccessibilityManager::OnLocationChanges( | 399 void BrowserAccessibilityManager::OnLocationChanges( |
406 const std::vector<AccessibilityHostMsg_LocationChangeParams>& params) { | 400 const std::vector<AccessibilityHostMsg_LocationChangeParams>& params) { |
407 for (size_t i = 0; i < params.size(); ++i) { | 401 for (size_t i = 0; i < params.size(); ++i) { |
(...skipping 64 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
472 } | 466 } |
473 | 467 |
474 // The "scrolled to anchor" notification is a great way to get a | 468 // The "scrolled to anchor" notification is a great way to get a |
475 // screen reader to jump directly to a specific location in a document. | 469 // screen reader to jump directly to a specific location in a document. |
476 NotifyAccessibilityEvent(ui::AX_EVENT_SCROLLED_TO_ANCHOR, node); | 470 NotifyAccessibilityEvent(ui::AX_EVENT_SCROLLED_TO_ANCHOR, node); |
477 } | 471 } |
478 | 472 |
479 BrowserAccessibility* BrowserAccessibilityManager::GetActiveDescendantFocus( | 473 BrowserAccessibility* BrowserAccessibilityManager::GetActiveDescendantFocus( |
480 BrowserAccessibility* focus) { | 474 BrowserAccessibility* focus) { |
481 if (!focus) | 475 if (!focus) |
482 return NULL; | 476 return nullptr; |
483 | 477 |
484 int active_descendant_id; | 478 int32_t active_descendant_id; |
485 if (focus->GetIntAttribute(ui::AX_ATTR_ACTIVEDESCENDANT_ID, | 479 if (focus->GetIntAttribute(ui::AX_ATTR_ACTIVEDESCENDANT_ID, |
486 &active_descendant_id)) { | 480 &active_descendant_id)) { |
487 BrowserAccessibility* active_descendant = | 481 BrowserAccessibility* active_descendant = |
488 focus->manager()->GetFromID(active_descendant_id); | 482 focus->manager()->GetFromID(active_descendant_id); |
489 if (active_descendant) | 483 if (active_descendant) |
490 return active_descendant; | 484 return active_descendant; |
491 } | 485 } |
492 return focus; | 486 return focus; |
493 } | 487 } |
494 | 488 |
(...skipping 381 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
876 tree_source(tree_->CreateTreeSource()); | 870 tree_source(tree_->CreateTreeSource()); |
877 ui::AXTreeSerializer<const ui::AXNode*, | 871 ui::AXTreeSerializer<const ui::AXNode*, |
878 ui::AXNodeData, | 872 ui::AXNodeData, |
879 ui::AXTreeData> serializer(tree_source.get()); | 873 ui::AXTreeData> serializer(tree_source.get()); |
880 ui::AXTreeUpdate update; | 874 ui::AXTreeUpdate update; |
881 serializer.SerializeChanges(tree_->root(), &update); | 875 serializer.SerializeChanges(tree_->root(), &update); |
882 return update; | 876 return update; |
883 } | 877 } |
884 | 878 |
885 } // namespace content | 879 } // namespace content |
OLD | NEW |