OLD | NEW |
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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_android.h" | 5 #include "content/browser/accessibility/browser_accessibility_android.h" |
6 | 6 |
7 #include "base/i18n/break_iterator.h" | 7 #include "base/i18n/break_iterator.h" |
8 #include "base/strings/string_number_conversions.h" | 8 #include "base/strings/string_number_conversions.h" |
9 #include "base/strings/string_util.h" | 9 #include "base/strings/string_util.h" |
10 #include "base/strings/stringprintf.h" | 10 #include "base/strings/stringprintf.h" |
(...skipping 126 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
137 bool is_aria_pressed_defined; | 137 bool is_aria_pressed_defined; |
138 bool is_mixed; | 138 bool is_mixed; |
139 GetAriaTristate("aria-pressed", &is_aria_pressed_defined, &is_mixed); | 139 GetAriaTristate("aria-pressed", &is_aria_pressed_defined, &is_mixed); |
140 if (GetRole() == ui::AX_ROLE_CHECK_BOX || | 140 if (GetRole() == ui::AX_ROLE_CHECK_BOX || |
141 GetRole() == ui::AX_ROLE_RADIO_BUTTON || | 141 GetRole() == ui::AX_ROLE_RADIO_BUTTON || |
142 GetRole() == ui::AX_ROLE_MENU_ITEM_CHECK_BOX || | 142 GetRole() == ui::AX_ROLE_MENU_ITEM_CHECK_BOX || |
143 GetRole() == ui::AX_ROLE_MENU_ITEM_RADIO || | 143 GetRole() == ui::AX_ROLE_MENU_ITEM_RADIO || |
144 is_aria_pressed_defined) { | 144 is_aria_pressed_defined) { |
145 checkable = true; | 145 checkable = true; |
146 } | 146 } |
147 if (HasState(ui::AX_STATE_CHECKED)) | 147 // TODO Why do we need this? |
| 148 if (HasIntAttribute(ui::AX_ATTR_CHECKED_STATE)) |
148 checkable = true; | 149 checkable = true; |
149 return checkable; | 150 return checkable; |
150 } | 151 } |
151 | 152 |
152 bool BrowserAccessibilityAndroid::IsChecked() const { | 153 bool BrowserAccessibilityAndroid::IsChecked() const { |
153 return (HasState(ui::AX_STATE_CHECKED) || HasState(ui::AX_STATE_PRESSED)); | 154 const int checkedState = GetIntAttribute(ui::AX_ATTR_CHECKED_STATE); |
| 155 return (checkedState == ui::AX_CHECKED_STATE_TRUE || |
| 156 checkedState == ui::AX_CHECKED_STATE_MIXED || |
| 157 HasState(ui::AX_STATE_PRESSED)); |
154 } | 158 } |
155 | 159 |
156 bool BrowserAccessibilityAndroid::IsClickable() const { | 160 bool BrowserAccessibilityAndroid::IsClickable() const { |
157 // If it has a default action, it's definitely clickable. | 161 // If it has a default action, it's definitely clickable. |
158 if (HasIntAttribute(ui::AX_ATTR_ACTION)) | 162 if (HasIntAttribute(ui::AX_ATTR_ACTION)) |
159 return true; | 163 return true; |
160 | 164 |
161 // Otherwise return true if it's focusable, but skip web areas and iframes. | 165 // Otherwise return true if it's focusable, but skip web areas and iframes. |
162 if (IsIframe() || (GetRole() == ui::AX_ROLE_ROOT_WEB_AREA)) | 166 if (IsIframe() || (GetRole() == ui::AX_ROLE_ROOT_WEB_AREA)) |
163 return false; | 167 return false; |
(...skipping 1334 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1498 int BrowserAccessibilityAndroid::CountChildrenWithRole(ui::AXRole role) const { | 1502 int BrowserAccessibilityAndroid::CountChildrenWithRole(ui::AXRole role) const { |
1499 int count = 0; | 1503 int count = 0; |
1500 for (uint32_t i = 0; i < PlatformChildCount(); i++) { | 1504 for (uint32_t i = 0; i < PlatformChildCount(); i++) { |
1501 if (PlatformGetChild(i)->GetRole() == role) | 1505 if (PlatformGetChild(i)->GetRole() == role) |
1502 count++; | 1506 count++; |
1503 } | 1507 } |
1504 return count; | 1508 return count; |
1505 } | 1509 } |
1506 | 1510 |
1507 } // namespace content | 1511 } // namespace content |
OLD | NEW |