[] [contents of this page] [full techniques contents] [next chapter: evaluation techniques]

W3C

Techniques for Authoring Tool Accessibility Guidelines 1.0

Working Draft 24 November 2001

Section 7: Implementation techniques for guideline 7

This version:
http://www.w3.org/WAI/AU/WD-ATAG10-TECHS-20011124/imp7
Latest version:
http://www.w3.org/WAI/AU/ATAG10-TECHS/imp7
Previous version:
http://www.w3.org/WAI/AU/WD-ATAG10-TECHS-20010801/imp7
editor of this chapter:

Charles McCathieNevile

Jan Richards

Gregory Rosmaita


Brief table of contents


7.1 Use all applicable operating system and accessibility standards and conventions (Priority 1 for standards and conventions that are essential to accessibility; Priority 2 for those that are important to accessibility; Priority 3 for those that are beneficial to accessibility).

The techniques for this checkpoint include references to checklists and guidelines for a number of platforms and to general guidelines for accessible applications.Checkpoint 7.1

Markup tools technique Multimedia tools technique Content tools technique Programming tools technique The techniques for this checkpoint include references to checklists and guidelines for a number of platforms and to general guidelines for accessible applications. This list does not cover all requirements for all platforms, and items may not apply to some software. In addition, not all of the guidelines and checklists for application accessibility are prioritized according to their impact on accessibility. For instance, the priorities in "The Microsoft Windows Guidelines for Accessible Software Design" [MS-SOFTWARE] are partially determined by a logo requirement program. Therefore, developers may need to compare the documents they are using to other UAAG 1.0 [UAAG10] that has a priority system that is directly compatible with the priorities in [ATAG10]. Also, when user interfaces are built as Web content, they should follow the Web Content Accessibility Guidelines 1.0 [WCAG10]. [Required] @@

  • Following Standards
    • T0249 Draw text and objects using system conventions.
    • T0250 Make mouse, keyboard, and API activation of events consistent.
    • T0251 Provide a user interface that is "familiar" (to system standards, or across platform).
    • T0252 Use system standard indirections and APIs wherever possible.
    • T0253 Ensure all dialogs, subwindows, etc., satisfy these requirements.
    • T0254 Avoid blocking assistive technology functions (sticky/mouse keys, screenreader controls, etc.) where possible.
  • Configurability
    • T0255 Allow users to create profiles.
    • T0256 Allow control of timing, colors, sizes, input/output devices and media.
    • T0257 Allow users to reshape the user interface - customize toolbars, keyboard commands, etc.
  • Input Device Independence
    • T0258 Provide Keyboard access to all functions.
    • T0259 Document all keyboard bindings.
    • T0260 Provide customizable keyboard shortcuts for common functions.
    • T0261 Provide logical navigation order for the keyboard interface.
    • T0262 Avoid repetitive keying wherever possible.
    • T0263 Provide mouse access to functions where possible.
  • Icons, Graphics, Sounds
    • T0264 Provide graphical (text) equivalents for sound warnings.
    • T0265 Allow sounds to be turned off.
    • T0266 Provide text equivalents for images/icons.
    • T0267 Use customizable (or removable) colors/patterns.
    • T0268 Ensure high contrast is available (as default setting).
    • T0269 Provide text equivalents for all audio.
    • T0270 Use icons that are resizable or available in multiple sizes.
  • Layout
    • T0271 Do not rely on color alone for meaning. Use color for differentiation, in combination with accessible cues (text equivalents, natural language, etc.).
    • T0272 Position objects and their related text labels in a consistent and obvious manner (labels before objects is recommended).
    • T0273 Group related controls.
    • T0274 Ensure default window sizes fit in screen.
    • T0275 Allow for window resizing (very small to very large).
  • User Focus
    • T0276 Clearly identify the user focus (and expose it via API).
    • T0277 Viewing content (i.e., moving the focus to a new point) should not cause unexpected events.
    • T0278 Allow user control of timing (i.e., delays, time-dependent response, etc.)
    • T0279 Allow for navigation between as well as within windows.
  • Documentation
    • T0280 Provide documentation for all features of the tool.
    • T0281 Ensure that help functions are accessible.
References:
  • Guidelines for specific platforms include:
    • Java: "IBM Guidelines for Writing Accessible Applications Using 100% Pure Java" [JAVA-ACCESS] R. Schwerdtfeger, IBM Special Needs Systems.
    • X Windows: "An ICE Rendezvous Mechanism for X Window System Clients" [ICE-RAP], W. Walker. A description of how to use the ICE and RAP protocols for X Window clients.
    • MS Active Accessibility: "Information for Developers About Microsoft Active Accessibility" [MSAA] Microsoft Corporation.
    • X Windows: "The Inter-Client communication conventions manual" [ICCCM]. A protocol for communication between clients in the X Window system.
    • Lotus Notes: "Lotus Notes accessibility guidelines" [NOTES-ACCESS] IBM Special Needs Systems.
    • Java: "Java accessibility guidelines and checklist" [JAVA-CHECKLIST] IBM Special Needs Systems.
    • Java Swing: "The Java Tutorial. Trail: Creating a GUI with JFC/Swing" [JAVA-TUT]. An online tutorial that describes how to use the Swing Java Foundation Class to build an accessible User Interface.
    • Macintosh: "Macintosh Human Interface Guidelines" [APPLE-HI] Apple Computer Inc.
    • MS Windows: "The Microsoft Windows Guidelines for Accessible Software Design"c [MS-SOFTWARE].
  • Guidelines for specific software types include:
    • Authoring Tools: "The Three-tions of Accessibility-Aware HTML Authoring Tools" [ACCESS-AWARE], J. Richards.
    • User Agents: "User Agent Accessibility Guidelines (Working Draft)" J. Gunderson, I. Jacobs eds. (This is a work in progress) [UAAG10]
  • General guidelines for producing accessible software include:
    • Microsoft: "Accessibility for applications designers" [MS-ENABLE] Microsoft Corporation.
    • Trace: "Application Software Design Guidelines" [TRACE-REF] compiled by G. Vanderheiden. A thorough reference work.
    • Sun: "Designing for Accessibility" [SUN-DESIGN] Eric Bergman and Earl Johnson. This paper discusses specific disabilities including those related to hearing, vision, and cognitive function.
    • EITAAG: "EITAAC Desktop Software standards" [EITAAC] Electronic Information Technology Access Advisory (EITACC) Committee.
    • US Sept. of Education: "Requirements for Accessible Software Design" [ED-DEPT] US Department of Education, version 1.1 March 6, 1997.
    • IBM: "Software Accessibility" [IBM-ACCESS] IBM Special Needs Systems
    • "Towards Accessible Human-Computer Interaction" [SUN-HCI] Eric Bergman, Earl Johnson, Sun Microsytems 1995. A substantial paper, with a valuable print bibliography.
    • "What is Accessible Software" [WHAT-IS] James W. Thatcher, Ph.D., IBM, 1997. This paper gives a short example-based introduction to the difference between software that is accessible, and software that can be used by some assistive technologies.

7.2 Allow the author to change the presentation within editing views without affecting the document markup. [Priority 1]

This allows the author to edit the document according to personal requirements, without changing the way the document is rendered when published.Checkpoint 7.2

 
T0282 Markup tools technique Multimedia tools technique Content tools technique Programming tools technique For tools with editing views, the author must have the ability to change the fonts, colours, sizing, etc. within the editing view, independently of the ability to control the markup that is actually produced.
T0283 Markup tools technique For tools that display the source structure of a document using graphic representations of tags, provide the author with the option of displaying the text of the elements, instead (i.e., <html> rather than a generic marker image).
T0284 Markup tools technique Content tools technique Programming tools technique An authoring tool that offers a "rendered view" of a document, such as a browser preview mode, may provide an editing view whose presentation can be controlled independently of the rendered view.
T0285 Markup tools technique A WYSIWYG editor may allow an author to specify a local style sheet, that will override the "published" style of the document in the editing view.
T0286 Markup tools technique Allow the author to create audio style sheets using a graphical representation rather than an audio one (with accessible representation, of course).

7.3 Allow the author to edit all properties of each element and object in an accessible fashion. [Priority 1]

Checkpoint 7.3

  • T0287 Markup tools technique Allow the author to individually edit each attribute of the elements in an HTML or XML document, for example, through a menu. This must include the ability to add and edit later, values for all valid attributes. (Suggested)
  • T0288 Markup tools technique For tools that graphically represented element start and end tags, text equivalent must be provided in order to be accessible to assistive technologies that render text as Braille, speech, or large print.(Suggested)
  • T0289 Markup tools technique   An authoring tool may offer several editing views of the same document, such as a source mode that allows direct editing of all properties.(Suggested)
  • T0290 Content tools technique For a site management tool, allow the author to render a site map in text form (i.e., as a structured tree file).(Suggested)
  • T0291 Markup tools technique Allow the author to specify that alternative information (or identifiers such as a URI or filename) are rendered in place of images or other multimedia content while editing.(Suggested)
  • T0292 Markup tools technique Include attributes / properties of elements in a view of the structure.(Suggested)
  • T0293 Markup tools technique Programming tools technique Provide access to a list of properties via a "context menu" for each element.(Suggested)

7.4 Ensure that the editing view allows navigation via the structure of the document in an accessible fashion. [Priority 1]

Checkpoint 7.4

7.5 Enable editing of the structure of the document in an accessible fashion. [Priority 2]

Checkpoint 7.5

T0300 Markup tools technique Multimedia tools technique An authoring tool may offer a structured tree view of the document that allows the author to move among, select and cut, copy or paste elements of the document.(Suggested)
T0301 Markup tools technique Multimedia tools technique A WYSIWYG tool may allow elements to be selected, and copied or moved while retaining their structure.(Suggested)
Markup tools technique Multimedia tools technique A tool may allow transformation from one element type to another, such as (Suggested):
  • T0302 HTML: Paragraphs to lists and back
  • T0303 HTML: BR to P
  • T0304 SMIL: Transformations between switch, excl, and par
  • T0305 HTML: FONT (deprecated) into heuristically determined structure
  • T0306 MathML: Transformations between semantic and presentation markup
  • T0307 SVG: g to symbol
  • T0308 Lists of lists to tables and back
  • T0309 Giving a structural role to a part of an element, such as an SVG g or an HTML p element

7.6 Allow the author to search within editing views. [Priority 2]

Checkpoint 7.6

  • T0310 Markup tools technique Multimedia tools technique Content tools technique Programming tools technique Allow the user to search for a sequence of characters as a minimal measure for meeting this checkpoint.[Required] @@
  • T0311 Markup tools technique Multimedia tools technique Content tools technique Programming tools technique More powerful searches can include the ability to perform searches that are case sensitive or case-insensitive, the ability to replace a search string, the ability to repeat a previous search to find the next or previous occurrence, or to select multiple occurrences with a single search.(Suggested)
  • T0312 Markup tools technique Multimedia tools technique Content tools technique Programming tools technique The ability to search for a particular type of structure is useful in a structured document, structured image such as a complex SVG image, etc.(Suggested)
  • T0313 Multimedia tools technique In an image editor, the ability to select an area by properties (such as color, or closeness of color) is useful and common in middle range and high end image processing software.(Suggested)
  • T0314 Content tools technique The ability to search a database for particular content, or to search a collection of files at once (a simple implementation of the latter is the Unix function "grep") is an important tool in managing large collections, especially those that are dynamically converted into Web content.(Suggested)
  • T0315 Markup tools technique Multimedia tools technique Content tools technique The use of metadata (per WCAG 1.0 [WCAG10]) can allow for very complex searching of large collections, or of timed presentations. Refer also to the paper "A Comparison of Schemas for Dublin Core-based Video Metadata Representation" [SEARCHABLE] for discussion specifically addressing timed multimedia presentations.(Suggested)

[previous section] [top of this page] [full techniques contents] [next