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

Side by Side Diff: chrome/browser/browser_accessibility_win.cc

Issue 3380017: Support additional webkit accessibility notifications and states. (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/
Patch Set: Adding missig file. 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/browser_accessibility_win.h" 5 #include "chrome/browser/browser_accessibility_win.h"
6 6
7 #include "base/logging.h" 7 #include "base/logging.h"
8 #include "base/string_util.h" 8 #include "base/string_util.h"
9 #include "base/utf_string_conversions.h" 9 #include "base/utf_string_conversions.h"
10 #include "chrome/browser/browser_accessibility_manager_win.h" 10 #include "chrome/browser/browser_accessibility_manager_win.h"
(...skipping 1074 matching lines...) Expand 10 before | Expand all | Expand 10 after
1085 return UTF8ToUTF16(EscapeNonASCII(UTF16ToUTF8(str))); 1085 return UTF8ToUTF16(EscapeNonASCII(UTF16ToUTF8(str)));
1086 } 1086 }
1087 1087
1088 void BrowserAccessibility::InitRoleAndState(LONG web_role, 1088 void BrowserAccessibility::InitRoleAndState(LONG web_role,
1089 LONG web_state) { 1089 LONG web_state) {
1090 state_ = 0; 1090 state_ = 0;
1091 ia2_state_ = IA2_STATE_OPAQUE; 1091 ia2_state_ = IA2_STATE_OPAQUE;
1092 1092
1093 if ((web_state >> WebAccessibility::STATE_CHECKED) & 1) 1093 if ((web_state >> WebAccessibility::STATE_CHECKED) & 1)
1094 state_ |= STATE_SYSTEM_CHECKED; 1094 state_ |= STATE_SYSTEM_CHECKED;
1095 if ((web_state >> WebAccessibility::STATE_COLLAPSED) & 1)
1096 state_ |= STATE_SYSTEM_COLLAPSED;
1097 if ((web_state >> WebAccessibility::STATE_EXPANDED) & 1)
1098 state_ |= STATE_SYSTEM_EXPANDED;
1095 if ((web_state >> WebAccessibility::STATE_FOCUSABLE) & 1) 1099 if ((web_state >> WebAccessibility::STATE_FOCUSABLE) & 1)
1096 state_ |= STATE_SYSTEM_FOCUSABLE; 1100 state_ |= STATE_SYSTEM_FOCUSABLE;
1101 if ((web_state >> WebAccessibility::STATE_HASPOPUP) & 1)
1102 state_ |= STATE_SYSTEM_HASPOPUP;
1097 if ((web_state >> WebAccessibility::STATE_HOTTRACKED) & 1) 1103 if ((web_state >> WebAccessibility::STATE_HOTTRACKED) & 1)
1098 state_ |= STATE_SYSTEM_HOTTRACKED; 1104 state_ |= STATE_SYSTEM_HOTTRACKED;
1099 if ((web_state >> WebAccessibility::STATE_INDETERMINATE) & 1) 1105 if ((web_state >> WebAccessibility::STATE_INDETERMINATE) & 1)
1100 state_ |= STATE_SYSTEM_INDETERMINATE; 1106 state_ |= STATE_SYSTEM_INDETERMINATE;
1107 if ((web_state >> WebAccessibility::STATE_INVISIBLE) & 1)
1108 state_ |= STATE_SYSTEM_INVISIBLE;
1101 if ((web_state >> WebAccessibility::STATE_LINKED) & 1) 1109 if ((web_state >> WebAccessibility::STATE_LINKED) & 1)
1102 state_ |= STATE_SYSTEM_LINKED; 1110 state_ |= STATE_SYSTEM_LINKED;
1103 if ((web_state >> WebAccessibility::STATE_MULTISELECTABLE) & 1) 1111 if ((web_state >> WebAccessibility::STATE_MULTISELECTABLE) & 1)
1104 state_ |= STATE_SYSTEM_MULTISELECTABLE; 1112 state_ |= STATE_SYSTEM_MULTISELECTABLE;
1113 // TODO(ctguil): Support STATE_SYSTEM_EXTSELECTABLE/accSelect.
1105 if ((web_state >> WebAccessibility::STATE_OFFSCREEN) & 1) 1114 if ((web_state >> WebAccessibility::STATE_OFFSCREEN) & 1)
1106 state_ |= STATE_SYSTEM_OFFSCREEN; 1115 state_ |= STATE_SYSTEM_OFFSCREEN;
1107 if ((web_state >> WebAccessibility::STATE_PRESSED) & 1) 1116 if ((web_state >> WebAccessibility::STATE_PRESSED) & 1)
1108 state_ |= STATE_SYSTEM_PRESSED; 1117 state_ |= STATE_SYSTEM_PRESSED;
1109 if ((web_state >> WebAccessibility::STATE_PROTECTED) & 1) 1118 if ((web_state >> WebAccessibility::STATE_PROTECTED) & 1)
1110 state_ |= STATE_SYSTEM_PROTECTED; 1119 state_ |= STATE_SYSTEM_PROTECTED;
1120 if ((web_state >> WebAccessibility::STATE_SELECTABLE) & 1)
1121 state_ |= STATE_SYSTEM_SELECTABLE;
1122 if ((web_state >> WebAccessibility::STATE_SELECTED) & 1)
1123 state_ |= STATE_SYSTEM_SELECTED;
1111 if ((web_state >> WebAccessibility::STATE_READONLY) & 1) 1124 if ((web_state >> WebAccessibility::STATE_READONLY) & 1)
1112 state_ |= STATE_SYSTEM_READONLY; 1125 state_ |= STATE_SYSTEM_READONLY;
1113 if ((web_state >> WebAccessibility::STATE_TRAVERSED) & 1) 1126 if ((web_state >> WebAccessibility::STATE_TRAVERSED) & 1)
1114 state_ |= STATE_SYSTEM_TRAVERSED; 1127 state_ |= STATE_SYSTEM_TRAVERSED;
1115 if ((web_state >> WebAccessibility::STATE_BUSY) & 1) 1128 if ((web_state >> WebAccessibility::STATE_BUSY) & 1)
1116 state_ |= STATE_SYSTEM_BUSY; 1129 state_ |= STATE_SYSTEM_BUSY;
1117 if ((web_state >> WebAccessibility::STATE_UNAVAILABLE) & 1) 1130 if ((web_state >> WebAccessibility::STATE_UNAVAILABLE) & 1)
1118 state_ |= STATE_SYSTEM_UNAVAILABLE; 1131 state_ |= STATE_SYSTEM_UNAVAILABLE;
1119 1132
1120 role_ = 0; 1133 role_ = 0;
(...skipping 243 matching lines...) Expand 10 before | Expand all | Expand 10 after
1364 } 1377 }
1365 1378
1366 // The role should always be set. 1379 // The role should always be set.
1367 DCHECK(!role_name_.empty() || role_); 1380 DCHECK(!role_name_.empty() || role_);
1368 1381
1369 // If we didn't explicitly set the IAccessible2 role, make it the same 1382 // If we didn't explicitly set the IAccessible2 role, make it the same
1370 // as the MSAA role. 1383 // as the MSAA role.
1371 if (!ia2_role_) 1384 if (!ia2_role_)
1372 ia2_role_ = role_; 1385 ia2_role_ = role_;
1373 } 1386 }
OLDNEW
« no previous file with comments | « chrome/browser/browser_accessibility_manager_win.cc ('k') | chrome/browser/renderer_host/browser_render_process_host.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698