| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419 | 
							- /////////////////////////////////////////////////////////////////////////////
 
- // Name:        access.h
 
- // Purpose:     interface of wxAccessible
 
- // Author:      wxWidgets team
 
- // Licence:     wxWindows licence
 
- /////////////////////////////////////////////////////////////////////////////
 
- /**
 
-     wxAccessible functions return a wxAccStatus error code,
 
-     which may be one of this enum's values.
 
- */
 
- typedef enum
 
- {
 
-     wxACC_FAIL,            //!< The function failed.
 
-     wxACC_FALSE,           //!< The function returned false.
 
-     wxACC_OK,              //!< The function completed successfully.
 
-     wxACC_NOT_IMPLEMENTED, //!< The function is not implemented.
 
-     wxACC_NOT_SUPPORTED    //!< The function is not supported.
 
- } wxAccStatus;
 
- /**
 
-     Directions of navigation are represented by this enum.
 
- */
 
- typedef enum
 
- {
 
-     wxNAVDIR_DOWN,
 
-     wxNAVDIR_FIRSTCHILD,
 
-     wxNAVDIR_LASTCHILD,
 
-     wxNAVDIR_LEFT,
 
-     wxNAVDIR_NEXT,
 
-     wxNAVDIR_PREVIOUS,
 
-     wxNAVDIR_RIGHT,
 
-     wxNAVDIR_UP
 
- } wxNavDir;
 
- /**
 
-     The role of a user interface element is represented by the values of this enum.
 
- */
 
- typedef enum {
 
-     wxROLE_NONE,
 
-     wxROLE_SYSTEM_ALERT,
 
-     wxROLE_SYSTEM_ANIMATION,
 
-     wxROLE_SYSTEM_APPLICATION,
 
-     wxROLE_SYSTEM_BORDER,
 
-     wxROLE_SYSTEM_BUTTONDROPDOWN,
 
-     wxROLE_SYSTEM_BUTTONDROPDOWNGRID,
 
-     wxROLE_SYSTEM_BUTTONMENU,
 
-     wxROLE_SYSTEM_CARET,
 
-     wxROLE_SYSTEM_CELL,
 
-     wxROLE_SYSTEM_CHARACTER,
 
-     wxROLE_SYSTEM_CHART,
 
-     wxROLE_SYSTEM_CHECKBUTTON,
 
-     wxROLE_SYSTEM_CLIENT,
 
-     wxROLE_SYSTEM_CLOCK,
 
-     wxROLE_SYSTEM_COLUMN,
 
-     wxROLE_SYSTEM_COLUMNHEADER,
 
-     wxROLE_SYSTEM_COMBOBOX,
 
-     wxROLE_SYSTEM_CURSOR,
 
-     wxROLE_SYSTEM_DIAGRAM,
 
-     wxROLE_SYSTEM_DIAL,
 
-     wxROLE_SYSTEM_DIALOG,
 
-     wxROLE_SYSTEM_DOCUMENT,
 
-     wxROLE_SYSTEM_DROPLIST,
 
-     wxROLE_SYSTEM_EQUATION,
 
-     wxROLE_SYSTEM_GRAPHIC,
 
-     wxROLE_SYSTEM_GRIP,
 
-     wxROLE_SYSTEM_GROUPING,
 
-     wxROLE_SYSTEM_HELPBALLOON,
 
-     wxROLE_SYSTEM_HOTKEYFIELD,
 
-     wxROLE_SYSTEM_INDICATOR,
 
-     wxROLE_SYSTEM_LINK,
 
-     wxROLE_SYSTEM_LIST,
 
-     wxROLE_SYSTEM_LISTITEM,
 
-     wxROLE_SYSTEM_MENUBAR,
 
-     wxROLE_SYSTEM_MENUITEM,
 
-     wxROLE_SYSTEM_MENUPOPUP,
 
-     wxROLE_SYSTEM_OUTLINE,
 
-     wxROLE_SYSTEM_OUTLINEITEM,
 
-     wxROLE_SYSTEM_PAGETAB,
 
-     wxROLE_SYSTEM_PAGETABLIST,
 
-     wxROLE_SYSTEM_PANE,
 
-     wxROLE_SYSTEM_PROGRESSBAR,
 
-     wxROLE_SYSTEM_PROPERTYPAGE,
 
-     wxROLE_SYSTEM_PUSHBUTTON,
 
-     wxROLE_SYSTEM_RADIOBUTTON,
 
-     wxROLE_SYSTEM_ROW,
 
-     wxROLE_SYSTEM_ROWHEADER,
 
-     wxROLE_SYSTEM_SCROLLBAR,
 
-     wxROLE_SYSTEM_SEPARATOR,
 
-     wxROLE_SYSTEM_SLIDER,
 
-     wxROLE_SYSTEM_SOUND,
 
-     wxROLE_SYSTEM_SPINBUTTON,
 
-     wxROLE_SYSTEM_STATICTEXT,
 
-     wxROLE_SYSTEM_STATUSBAR,
 
-     wxROLE_SYSTEM_TABLE,
 
-     wxROLE_SYSTEM_TEXT,
 
-     wxROLE_SYSTEM_TITLEBAR,
 
-     wxROLE_SYSTEM_TOOLBAR,
 
-     wxROLE_SYSTEM_TOOLTIP,
 
-     wxROLE_SYSTEM_WHITESPACE,
 
-     wxROLE_SYSTEM_WINDOW
 
- } wxAccRole;
 
- /**
 
-     Objects are represented by a wxAccObject enum value.
 
- */
 
- typedef enum {
 
-     wxOBJID_WINDOW =    0x00000000,
 
-     wxOBJID_SYSMENU =   0xFFFFFFFF,
 
-     wxOBJID_TITLEBAR =  0xFFFFFFFE,
 
-     wxOBJID_MENU =      0xFFFFFFFD,
 
-     wxOBJID_CLIENT =    0xFFFFFFFC,
 
-     wxOBJID_VSCROLL =   0xFFFFFFFB,
 
-     wxOBJID_HSCROLL =   0xFFFFFFFA,
 
-     wxOBJID_SIZEGRIP =  0xFFFFFFF9,
 
-     wxOBJID_CARET =     0xFFFFFFF8,
 
-     wxOBJID_CURSOR =    0xFFFFFFF7,
 
-     wxOBJID_ALERT =     0xFFFFFFF6,
 
-     wxOBJID_SOUND =     0xFFFFFFF5
 
- } wxAccObject;
 
- /**
 
-     Selection actions are identified by the wxAccSelectionFlags values.
 
- */
 
- typedef enum
 
- {
 
-     wxACC_SEL_NONE            = 0,
 
-     wxACC_SEL_TAKEFOCUS       = 1,
 
-     wxACC_SEL_TAKESELECTION   = 2,
 
-     wxACC_SEL_EXTENDSELECTION = 4,
 
-     wxACC_SEL_ADDSELECTION    = 8,
 
-     wxACC_SEL_REMOVESELECTION = 16
 
- } wxAccSelectionFlags;
 
- //@{
 
- /**
 
-     Represents a status of the system.
 
- */
 
- #define wxACC_STATE_SYSTEM_ALERT_HIGH       0x00000001
 
- #define wxACC_STATE_SYSTEM_ALERT_MEDIUM     0x00000002
 
- #define wxACC_STATE_SYSTEM_ALERT_LOW        0x00000004
 
- #define wxACC_STATE_SYSTEM_ANIMATED         0x00000008
 
- #define wxACC_STATE_SYSTEM_BUSY             0x00000010
 
- #define wxACC_STATE_SYSTEM_CHECKED          0x00000020
 
- #define wxACC_STATE_SYSTEM_COLLAPSED        0x00000040
 
- #define wxACC_STATE_SYSTEM_DEFAULT          0x00000080
 
- #define wxACC_STATE_SYSTEM_EXPANDED         0x00000100
 
- #define wxACC_STATE_SYSTEM_EXTSELECTABLE    0x00000200
 
- #define wxACC_STATE_SYSTEM_FLOATING         0x00000400
 
- #define wxACC_STATE_SYSTEM_FOCUSABLE        0x00000800
 
- #define wxACC_STATE_SYSTEM_FOCUSED          0x00001000
 
- #define wxACC_STATE_SYSTEM_HOTTRACKED       0x00002000
 
- #define wxACC_STATE_SYSTEM_INVISIBLE        0x00004000
 
- #define wxACC_STATE_SYSTEM_MARQUEED         0x00008000
 
- #define wxACC_STATE_SYSTEM_MIXED            0x00010000
 
- #define wxACC_STATE_SYSTEM_MULTISELECTABLE  0x00020000
 
- #define wxACC_STATE_SYSTEM_OFFSCREEN        0x00040000
 
- #define wxACC_STATE_SYSTEM_PRESSED          0x00080000
 
- #define wxACC_STATE_SYSTEM_PROTECTED        0x00100000
 
- #define wxACC_STATE_SYSTEM_READONLY         0x00200000
 
- #define wxACC_STATE_SYSTEM_SELECTABLE       0x00400000
 
- #define wxACC_STATE_SYSTEM_SELECTED         0x00800000
 
- #define wxACC_STATE_SYSTEM_SELFVOICING      0x01000000
 
- #define wxACC_STATE_SYSTEM_UNAVAILABLE      0x02000000
 
- //@}
 
- //@{
 
- /**
 
-     An event identifier that can be sent via wxAccessible::NotifyEvent.
 
- */
 
- #define wxACC_EVENT_SYSTEM_SOUND              0x0001
 
- #define wxACC_EVENT_SYSTEM_ALERT              0x0002
 
- #define wxACC_EVENT_SYSTEM_FOREGROUND         0x0003
 
- #define wxACC_EVENT_SYSTEM_MENUSTART          0x0004
 
- #define wxACC_EVENT_SYSTEM_MENUEND            0x0005
 
- #define wxACC_EVENT_SYSTEM_MENUPOPUPSTART     0x0006
 
- #define wxACC_EVENT_SYSTEM_MENUPOPUPEND       0x0007
 
- #define wxACC_EVENT_SYSTEM_CAPTURESTART       0x0008
 
- #define wxACC_EVENT_SYSTEM_CAPTUREEND         0x0009
 
- #define wxACC_EVENT_SYSTEM_MOVESIZESTART      0x000A
 
- #define wxACC_EVENT_SYSTEM_MOVESIZEEND        0x000B
 
- #define wxACC_EVENT_SYSTEM_CONTEXTHELPSTART   0x000C
 
- #define wxACC_EVENT_SYSTEM_CONTEXTHELPEND     0x000D
 
- #define wxACC_EVENT_SYSTEM_DRAGDROPSTART      0x000E
 
- #define wxACC_EVENT_SYSTEM_DRAGDROPEND        0x000F
 
- #define wxACC_EVENT_SYSTEM_DIALOGSTART        0x0010
 
- #define wxACC_EVENT_SYSTEM_DIALOGEND          0x0011
 
- #define wxACC_EVENT_SYSTEM_SCROLLINGSTART     0x0012
 
- #define wxACC_EVENT_SYSTEM_SCROLLINGEND       0x0013
 
- #define wxACC_EVENT_SYSTEM_SWITCHSTART        0x0014
 
- #define wxACC_EVENT_SYSTEM_SWITCHEND          0x0015
 
- #define wxACC_EVENT_SYSTEM_MINIMIZESTART      0x0016
 
- #define wxACC_EVENT_SYSTEM_MINIMIZEEND        0x0017
 
- #define wxACC_EVENT_OBJECT_CREATE                 0x8000
 
- #define wxACC_EVENT_OBJECT_DESTROY                0x8001
 
- #define wxACC_EVENT_OBJECT_SHOW                   0x8002
 
- #define wxACC_EVENT_OBJECT_HIDE                   0x8003
 
- #define wxACC_EVENT_OBJECT_REORDER                0x8004
 
- #define wxACC_EVENT_OBJECT_FOCUS                  0x8005
 
- #define wxACC_EVENT_OBJECT_SELECTION              0x8006
 
- #define wxACC_EVENT_OBJECT_SELECTIONADD           0x8007
 
- #define wxACC_EVENT_OBJECT_SELECTIONREMOVE        0x8008
 
- #define wxACC_EVENT_OBJECT_SELECTIONWITHIN        0x8009
 
- #define wxACC_EVENT_OBJECT_STATECHANGE            0x800A
 
- #define wxACC_EVENT_OBJECT_LOCATIONCHANGE         0x800B
 
- #define wxACC_EVENT_OBJECT_NAMECHANGE             0x800C
 
- #define wxACC_EVENT_OBJECT_DESCRIPTIONCHANGE      0x800D
 
- #define wxACC_EVENT_OBJECT_VALUECHANGE            0x800E
 
- #define wxACC_EVENT_OBJECT_PARENTCHANGE           0x800F
 
- #define wxACC_EVENT_OBJECT_HELPCHANGE             0x8010
 
- #define wxACC_EVENT_OBJECT_DEFACTIONCHANGE        0x8011
 
- #define wxACC_EVENT_OBJECT_ACCELERATORCHANGE      0x8012
 
- //@}
 
- /**
 
-     @class wxAccessible
 
-     The wxAccessible class allows wxWidgets applications, and wxWidgets itself,
 
-     to return extended information about user interface elements to client
 
-     applications such as screen readers. This is the main way in which wxWidgets
 
-     implements accessibility features.
 
-     At present, only Microsoft Active Accessibility is supported by this class.
 
-     To use this class, derive from wxAccessible, implement appropriate
 
-     functions, and associate an object of the class with a window using
 
-     wxWindow::SetAccessible.
 
-     All functions return an indication of success, failure, or not implemented
 
-     using values of the wxAccStatus enum type.
 
-     If you return @c wxACC_NOT_IMPLEMENTED from any function, the system will try
 
-     to implement the appropriate functionality. However this will not work with
 
-     all functions.
 
-     Most functions work with an object @e id, which can be zero to refer to
 
-     'this' UI element, or greater than zero to refer to the nth child element.
 
-     This allows you to specify elements that don't have a corresponding wxWindow or
 
-     wxAccessible; for example, the sash of a splitter window.
 
-     For details on the semantics of functions and types, please refer to the
 
-     Microsoft Active Accessibility 1.2 documentation.
 
-     This class is compiled into wxWidgets only if the wxUSE_ACCESSIBILITY setup
 
-     symbol is set to 1.
 
-     @onlyfor{wxmsw}
 
-     @library{wxcore}
 
-     @category{misc}
 
-     @see @sample{access}
 
- */
 
- class wxAccessible : public wxObject
 
- {
 
- public:
 
-     /**
 
-         Constructor, taking an optional window. The object can be associated with
 
-         a window later.
 
-     */
 
-     wxAccessible(wxWindow* win = NULL);
 
-     /**
 
-         Destructor.
 
-     */
 
-     ~wxAccessible();
 
-     /**
 
-         Performs the default action for the object.
 
-         @a childId is 0 (the action for this object) or greater than 0 (the action
 
-         for a child).
 
-         @return wxACC_NOT_SUPPORTED if there is no default action for this
 
-                 window (e.g. an edit control).
 
-     */
 
-     virtual wxAccStatus DoDefaultAction(int childId);
 
-     /**
 
-         Gets the specified child (starting from 1). If @a child is @NULL and the return
 
-         value is wxACC_OK, this means that the child is a simple element and not an
 
-         accessible object.
 
-     */
 
-     virtual wxAccStatus GetChild(int childId, wxAccessible** child);
 
-     /**
 
-         Returns the number of children in @a childCount.
 
-     */
 
-     virtual wxAccStatus GetChildCount(int* childCount);
 
-     /**
 
-         Gets the default action for this object (0) or a child (greater than 0).
 
-         Return wxACC_OK even if there is no action. @a actionName is the action, or the
 
-         empty string if there is no action. The retrieved string describes the action that is
 
-         performed on an object, not what the object does as a result. For example, a toolbar
 
-         button that prints a document has a default action of "Press" rather than "Prints
 
-         the current document."
 
-     */
 
-     virtual wxAccStatus GetDefaultAction(int childId,
 
-                                          wxString* actionName);
 
-     /**
 
-         Returns the description for this object or a child.
 
-     */
 
-     virtual wxAccStatus GetDescription(int childId,
 
-                                        wxString* description);
 
-     /**
 
-         Gets the window with the keyboard focus. If childId is 0 and child is @NULL, no
 
-         object in this subhierarchy has the focus. If this object has the focus, child
 
-         should be 'this'.
 
-     */
 
-     virtual wxAccStatus GetFocus(int* childId, wxAccessible** child);
 
-     /**
 
-         Returns help text for this object or a child, similar to tooltip text.
 
-     */
 
-     virtual wxAccStatus GetHelpText(int childId, wxString* helpText);
 
-     /**
 
-         Returns the keyboard shortcut for this object or child.
 
-         Returns e.g. ALT+K.
 
-     */
 
-     virtual wxAccStatus GetKeyboardShortcut(int childId,
 
-                                             wxString* shortcut);
 
-     /**
 
-         Returns the rectangle for this object (id is 0) or a child element (id is
 
-         greater than 0).
 
-         @a rect is in screen coordinates.
 
-     */
 
-     virtual wxAccStatus GetLocation(wxRect& rect, int elementId);
 
-     /**
 
-         Gets the name of the specified object.
 
-     */
 
-     virtual wxAccStatus GetName(int childId, wxString* name);
 
-     /**
 
-         Returns the parent of this object, or @NULL.
 
-     */
 
-     virtual wxAccStatus GetParent(wxAccessible** parent);
 
-     /**
 
-         Returns a role constant describing this object. See wxAccRole for a list
 
-         of these roles.
 
-     */
 
-     virtual wxAccStatus GetRole(int childId, wxAccRole* role);
 
-     /**
 
-         Gets a variant representing the selected children of this object.
 
-         Acceptable values are:
 
-         @li a null variant (IsNull() returns @true)
 
-         @li a list variant (GetType() == "list")
 
-         @li an integer representing the selected child element,
 
-             or 0 if this object is selected (GetType() == "long")
 
-         @li a "void*" pointer to a wxAccessible child object
 
-     */
 
-     virtual wxAccStatus GetSelections(wxVariant* selections);
 
-     /**
 
-         Returns a state constant. See wxAccStatus for a list of these states.
 
-     */
 
-     virtual wxAccStatus GetState(int childId, long* state);
 
-     /**
 
-         Returns a localized string representing the value for the object
 
-         or child.
 
-     */
 
-     virtual wxAccStatus GetValue(int childId, wxString* strValue);
 
-     /**
 
-         Returns the window associated with this object.
 
-     */
 
-     wxWindow* GetWindow();
 
-     /**
 
-         Returns a status value and object id to indicate whether the given point
 
-         was on this or a child object. Can return either a child object, or an
 
-         integer representing the child element, starting from 1.
 
-         @a pt is in screen coordinates.
 
-     */
 
-     virtual wxAccStatus HitTest(const wxPoint& pt, int* childId,
 
-                                 wxAccessible** childObject);
 
-     /**
 
-         Navigates from @a fromId to @a toId or to @a toObject.
 
-     */
 
-     virtual wxAccStatus Navigate(wxNavDir navDir, int fromId,
 
-                                  int* toId,
 
-                                  wxAccessible** toObject);
 
-     /**
 
-         Allows the application to send an event when something changes in
 
-         an accessible object.
 
-     */
 
-     static void NotifyEvent(int eventType, wxWindow* window,
 
-                             wxAccObject objectType,
 
-                             int objectType);
 
-     /**
 
-         Selects the object or child. See wxAccSelectionFlags for a list
 
-         of the selection actions.
 
-     */
 
-     virtual wxAccStatus Select(int childId,
 
-                                wxAccSelectionFlags selectFlags);
 
-     /**
 
-         Sets the window associated with this object.
 
-     */
 
-     void SetWindow(wxWindow* window);
 
- };
 
 
  |