ADC Home > Reference Library > Reference > User Experience > Accessibility > Accessibility (ApplicationServices/HIServices) Reference

 


AXRoleConstants.h

Overview

Every role offers a variety of attributes. There are some attributes that must be supported by every element, regardless of role. Other attributes will be supported by an element if/when appropriate data is supplied by the application. These attributes' meanings and values are generally obvious. In order to save space, the following attributes are not listed in the role documentation unless the role handles them in a special fashion:

		
		AXRole
		AXRoleDescription
		AXDescription
		AXHelp
		AXParent
		AXChildren
		AXWindow
		AXTopLevelUIElement
		AXEnabled
		AXSize
		AXPosition
		
		

Every attribute supported by a given role may have one or more symbols after its name:

		
		w means the attribute is writable.
		o means it is an optional attribute that doesn't necessarily need to be
			supported by all elements with that role.
		
		


Groups

Standard

Roles

Group members:

kAXApplicationRole
kAXBrowserRole
kAXButtonRole
kAXCheckBoxRole
kAXColumnRole
kAXDrawerRole
kAXGrowAreaRole
kAXImageRole
kAXMenuButtonRole
kAXOutlineRole
kAXPopUpButtonRole
kAXRadioButtonRole
kAXRowRole
kAXSheetRole
kAXSystemWideRole
kAXTabGroupRole
kAXTableRole
kAXUnknownRole
kAXWindowRole

#defines


kAXApplicationRole


#define kAXApplicationRole CFSTR("AXApplication") 


kAXBrowserRole


#define kAXBrowserRole CFSTR("AXBrowser") 
Discussion

An element that contains columns of hierarchical data. Examples include the column view in Finder windows and Open/Save dialogs. Carbon's Data Browser in column view mode represents itself as an AXBrowser. Cocoa's NSBrowser represents itself as an AXBrowser.

Browser elements are expected to have a particular hierarchy of sub-elements within it. In particular, the child of an AXBrowser must be an AXScrollArea that manages the horizontal scrolling. The horizontal AXScrollArea must include a child for each column the interface displays. Columns can be any role that makes sense. Typically, columns are vertical AXScrollAreas with AXList children. Here's a hierarchy for a typical browser:

		
		AXBrowser
			AXScrollArea (manages the horizontal scrolling)
				AXScrollBar (horizontal scroll bar)
				AXScrollArea (first column)
					AXScrollBar (column's vertical scroll bar)
					AXList (column content is typically a list, but it could be another role)
						<Varies> (cell)
						...
						<Varies> (cell)
				AXScrollArea (second column)
					...
				AXScrollArea (third column)
					...
				AXGroup (preview column)
					...
	
	Attributes:
		AXFocused (w)
		AXColumns - Array of the grandchild column elements, which are typically
			of the AXScrollArea role.
		AXVisibleColumns - Array of the subset of elements in the AXColumns array
			that are currently visible.
		AXColumnTitles (o)
		AXHorizontalScrollBar - The horizontal AXScrollBar of the browser's child
			AXScrollArea.


kAXButtonRole


#define kAXButtonRole CFSTR("AXButton") 


kAXCheckBoxRole


#define kAXCheckBoxRole CFSTR("AXCheckBox") 


kAXColumnRole


#define kAXColumnRole CFSTR("AXColumn") 


kAXDrawerRole


#define kAXDrawerRole CFSTR("AXDrawer") 


kAXGrowAreaRole


#define kAXGrowAreaRole CFSTR("AXGrowArea") 


kAXImageRole


#define kAXImageRole CFSTR("AXImage") 


kAXMenuButtonRole


#define kAXMenuButtonRole CFSTR("AXMenuButton") 


kAXOutlineRole


Attributes:

AXFocused

(w)

AXRows

Array of subset of AXChildren that are rows

AXVisibleRows

Array of subset of AXRows that are visible

AXSelectedRows

(w) Array of subset of AXRows that are selected

AXColumns

Array of subset of children that are columns

AXVisibleColumns

Array of subset of columns that are visible

AXSelectedColumns

(o) Array of subset of columns that are selected

AXHeader

(o) The AXGroup element that contains the header buttons
#define kAXOutlineRole CFSTR("AXOutline") 
Discussion

An element that contains row-based data. It may use disclosure triangles to manage the display of hierarchies within the data. It may arrange each row's data into columns and offer a header button above each column. The best example is the list view in a Finder window or Open/Save dialog.

Outlines are typically children of AXScrollAreas, which manages the horizontal and/or vertical scrolling for the outline. Outlines are expected to follow certain conventions with respect to their hierarchy of sub-elements. In particular, if the outline uses columns, the data should be accessible via either rows or columns. Thus, the data in a given cell will be represented as two diffrent elements. Here's a hierarchy for a typical outline:

		
		AXScrollArea (parent of the outline)
			AXScrollBar (if necessary, horizontal)
			AXScrollBar (if necessary, vertical)
			AXOutline
				AXGroup (header buttons, optional)
					AXButton, AXMenuButton, or <Varies> (header button)
					...
				AXRow (first row)
					AXStaticText (just one possible example)
					AXButton (just another possible example)
					AXTextField (ditto)
					AXCheckBox (ditto)
				AXRow (as above)
				...
				AXColumn (first column)
					AXStaticText (assumes the first column displays text)
					AXStaticText
					...
				AXColumn (second column)
					AXButton (assumes the second column displays buttons)
					AXButton
					...
				...
		
		


kAXPopUpButtonRole


#define kAXPopUpButtonRole CFSTR("AXPopUpButton") 


kAXRadioButtonRole


#define kAXRadioButtonRole CFSTR("AXRadioButton") 


kAXRowRole


#define kAXRowRole CFSTR("AXRow") 


kAXSheetRole


#define kAXSheetRole CFSTR("AXSheet") 


kAXSystemWideRole


#define kAXSystemWideRole CFSTR("AXSystemWide") 


kAXTabGroupRole


#define kAXTabGroupRole CFSTR("AXTabGroup") 


kAXTableRole


#define kAXTableRole CFSTR("AXTable") 


kAXUnknownRole


#define kAXUnknownRole CFSTR("AXUnknown") 


kAXWindowRole


#define kAXWindowRole CFSTR("AXWindow") 


Did this document help you?
Yes: Tell us what works for you.
It’s good, but: Report typos, inaccuracies, and so forth.
It wasn’t helpful: Tell us what would have helped.

 

Last Updated: 2008-08-07