Inclusive design
We all differ in our abilities to see, perceive colors, hear, control our motions, concentrate, and understand concepts. Inclusive design makes room for as many people as possible.
data:image/s3,"s3://crabby-images/cb27d/cb27dd5300daecd11aa60240b21c5a75d5d14c84" alt="Illustration of five people in profile, in conversation with each other. Blue background and highlights of yellow, gray, and blue, with circle and square shapes around each of the figures."
data:image/s3,"s3://crabby-images/7e499/7e49900b46dae84ee863e90cf54c808b5bd74520" alt="Illustration of five people in profile, in conversation with each other. Blue background and highlights of yellow, gray, and blue, with circle and square shapes around each of the figures."
Table of contents#
Inclusive design at Adobe#
Inclusive design is part of Adobe’s mission. Designers, engineers, and product builders are invested in learning how to think more broadly, seeking out more voices, and working together to make better experiences.
Spectrum also builds for the widest audience possible. Our system is designed to be clearly readable, intuitive to use, and mindful of those who use assistive technology. From how components function to
Best practices#
Assume nothing is perfect#
Provide context-sensitive help to ensure that people can be supported throughout many kinds of interactions.
Prevent error conditions wherever possible, and highlight error conditions when they exist. When an error occurs, provide clear guidance about what someone can do to resolve the error by using clear and helpful messaging.
Make room to adapt#
Provide targets large enough to see and interact with. Label and describe all objects.
Ensure that designs can be interacted with by mouse, keyboard, pen, fingertips, voice, accessibility API, or other methods.
When designing for the web, embrace responsiveness. Accommodate web page size down to 320 px.
Give people a choice#
Allow for someone to customize their experiences within a product, and respect system-wide user preferences such as captions, large fonts, and high contrast.
Ensure that every task can be completed in a logical order using only a keyboard.
Avoid distractions#
Don’t place animations near paragraphs of text. Allow users to turn off unnecessary animation.
Be consistent#
Use common components for well-defined tasks and interaction patterns, instead of new or custom-built ones.
Use common shortcuts across experiences, and especially within products that accomplish similar tasks.
Involve marginalized users#
Include people with diverse ranges of ability in user testing, and co-design whenever possible. Seek feedback from historically underinvested communities.
Checkpoints#
Structure#
Ensure that complex components — such as lists, forms, and panels — have a logical reading order. Check that the keyboard tab order has been defined in a logical progression.
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/2120d/2120d520b28818d876544a0a9b18c6fc2d23bbf1" alt="Key example of correct usage of structure, with a form in a logical reading order. 3 form fields. First form field, label Name. Help text, Enter your full name. Second form field, label Email. Help text, wilson@adobe.com. Third form field, Password. Help text, Create a password with at least 8 characters."
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/4dbb5/4dbb5e36d371c74e08112eaa26fa83b9ce2d4e76" alt="Key example of incorrect usage of structure, with a form not in a logical order. 3 form fields. First form field, label Email. Placeholder text, Type email… . Second form filed, label Password. Placeholder text, Type password… . Third form field, label Name. Placeholder text, Type name… ."
Color#
Use the
Avoid referring to objects by color (or by location) alone. Instead, refer to these by their names or by the grouping in which they belong.
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/e2731/e27312a82f747f1e8a87cdc7c5ced53ec857887c" alt="Key example of how to avoid referring to objects by color or location alone. An alert dialog describing a potentially destructive action. Title, Delete 3 documents. Description, Select Delete to delete these 3 documents. This action can’t be undone. 2 buttons, Cancel and Delete. Cancel is in the color grey and Delete is in the color red."
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/31345/313454f160dab3a346b016de0732821c32ce6171" alt="Key example of incorrectly referring to an interface object by color and location. An alert dialog describing a potentially destructive action. Title, Delete 3 documents. Description, Click the red button to the right to delete the 3 selected documents. 2 buttons, Cancel and Delete. Cancel is in the color grey and Delete is in the color red."
Animation#
Avoid making parts of a screen flash more then 3 times per second, to help prevent photo-epileptic seizures. Also, don’t create content that moves or blinks for more than a couple of seconds, to help prevent people from getting distracted.
Interactions#
Avoid “clear”/”reset” actions on forms, since someone could select these by accident and erase a lot of painstaking work. Let people save forms so that they can leave and come back.
Provide keywords before or inside of links.
Text alternatives#
Include a textual label for all elements. There may be a few exceptions, when the context is sufficient (e.g., document zoom level “100%”). Use the label element in HTML where possible. If not, use ARIA to set the label (depending on the context, “aria-label” or “aria-labelledby”).
Make sure labels are concise and have a clear association with objects. For objects in a table or a list, make sure that they can be identified by the structure around them (e.g., using a table header).
Label all images when possible, and in all cases, include
Learn more about creating text alternatives in Spectrum’s
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/34119/34119104dc61adabfe0ecdd375b1ed7b57b71514" alt="Key example of a text field that has been correctly labeled above the field, and 2 icon-only action buttons with a tooltip to show the label upon hover. Text field label, Full name. Input text, Lisa Wilson. Icon-only action buttons with icons for a piece of paper and a gear. The "gear" icon tooltip label reads "Settings.""
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/2e419/2e419f295479ea628015523080faa20e11bacfd4" alt="Key example of a text field that has been incorrectly left unlabeled. Only input text, Lisa Wilson."
Fonts and text#
Use Spectrum
Organize writing for comprehension. In layouts, left-align running text (this will be mirrored along with the UI for right-to-left languages). Fully-justified text creates text rivers, or irregular alignment of spaces that creates running gaps throughout the text; this makes it more difficult for readers with dyslexia. Avoid switching alignments in a single view.
Whenever possible, provide options for people to adjust font size, color themes, and contrast, either manually, in-app, or through operating system preferences.
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/6a26a/6a26a82df8e699618bc937d7f582283b9c766eb3" alt="Key example of a block of text that is left aligned to ensure proper readability. Title, For everyone. Body text, We believe in building for the widest audience possible. Spectrum is designed to be clearly readable, intuitive to use, and mindful of those who require alternative input peripherals or screen readers. Everything in our system — from color and type to interaction and language — is built to be compliant with industry standards."
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/ea163/ea1631f8c35bc203beabf14f8b1d379c6a4be07b" alt="Key example of a block of text that is incorrectly fully-justified, to create spaces between words, which diminishes readability. Title, For everyone. Body text, We believe in building for the widest audience possible. Spectrum is designed to be clearly readable, intuitive to use, and mindful of those who require alternative input peripherals or screen readers. Everything in our system — from color and type to interaction and language — is built to be compliant with industry standards."
Error prevention and correction#
Avoid the need for error messages by designing workflows that prevent an error state from even happening in the first place. When there is an error, associate it with the field or element that needs to be corrected or addressed. Make errors visually and semantically different from other messages (e.g., including icons, colors, placement), and
Use appropriate click/touch zones to leave enough space between elements. Doing this minimizes click/touch target errors.
Anticipate spelling mistakes in search queries, and accommodate multiple spellings of words in search results.
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/4408b/4408b425a48ff88cbd582b516abe14f8fd64235f" alt="Key example of a text field, correctly communicating an error with both red color, an alert icon, and an in-line text alert. Text field label, Email address. Input text, wilson@adobe. Error message, Enter a valid email address."
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/3ad94/3ad94eda4d00e512186f74e216d218e2be82b017" alt="Key example of a text field, incorrectly communicating an error with only red color and no context about the nature of the error. Text field label, Email address. Input text, wilson@adobe."