Android design - General navigation
Have sufficiently large click areas #
Target : everyone and in particular for people with motor disabilities.
When : from the design phase and during development.
Description :
Insufficient size for a clickable element can make it difficult to interact with. Each clickable element of the application must be of sufficient size.
However, there are some exceptions:
- If the proposed action has an equivalent in the screen that respects the required size
- If the clickable element is part of a zone or a text block (which is often the case for links).
To be verified :
- The click zone has a minimum size of 48 dp.
- The click zone has a margin around the element of at least 8 dp
- Click errors can be undone by moving your finger out of the clickable area before releasing.
Tool :
You can directly test your applications on certain accessibility criteria and in particular the size of the click zones with the AccessibilityScanner application. Available from Android 6.
Valid example :
In the examples below, the frame with border corresponds to the size of the interactive area.
Invalid example :
WCAG reference:
Have an application that can be used in any orientation #
Target : everyone and in particular people with visual or motor impairments.
When : during design and development.
Description :
Content access of an application should not depend on the screen orientation (portrait and landscape).
To be verified :
- The use of standard graphic components that support both modes (fragments...), or define a specific design for each orientation.
- The application is not locked in one orientation (portrait or landscape).
Valid example :
The application can be used in both portrait and landscape mode.
WCAG reference:
Propose an alternative to gestural actions #
Target : everyone and in particular people with visual and/or motor impairments.
When : from the design phase and during development.
Description :
Navigating between several pages using a horizontal swipe (especially with ViewPagers) can become complex for people with motor or visual impairments. It is essential to add an alternative, using "Next" and "Previous" buttons for example.
To be verified :
- The actions triggered by a user gesture or a movement of the device has an alternative.
Valid example :
Invalid example :
WCAG reference:
Have readable texts #
Target : everyone and in particular people with visual impairments and dyslexics.
When : from the design phase and during development.
Description :
The text can cause readability problems when it is too small or the font has impasto : a minimum text size of 14sp is recommended.
Android natively offers the Roboto font which has 16 variants, including many sans serif that are perfectly adapted to the readability need : roboto regular, roboto thin, roboto medium, etc... Serif fonts, such as the popular Times New Roman or Georgia, are not suitable.
To be verified :
- The font is sans-serif
- The texts are large enough to be read comfortably.
- There is no italics used
WCAG reference:
Use native components #
Target : everyone.
When : from the design phase and during development.
Description :
Native components integrate accessibility (most of the time). Navigation in a standard interface is more comfortable since the behaviors of the different elements are usual.
Make maximum use of native components: if no standard component can meet the need, create a dedicated component based on a standard component while maintaining navigation consistency and accessibility.
Make adaptable the time limits causing a change of context #
Target : everyone and in particular people with visual and/or motor impairments.
When : from the design phase and during development.
Description :
In some applications, the context may change after a timeout. For example, with video players: control buttons associated with the video disappear after about ten seconds without interaction.
This automatic UI update is an issue for accessibility, cause a user could need more time to interact with the elements. This timeout must be adaptable according to the needs of each user.
An accessibility option named "Time to take action" exists since Android 10, and allows to define its own timeout. By calling this option from the application, it is possible to adapt its interfaces with timeout to the user.
However, not all phones use a recent version of Android, it is recommended to propose directly within the application a setting of this delay.
To be verified :
- A timeout has a configurable delay.
WCAG reference: