Android develop - 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 the application. 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.

Valid examples:

Classic example:

<Button 
    android:text="Click"
    android:layout_width="48dp"
    android:layout_height="48dp"
    android:margin="8dp"
/>

// With Jetpack Compose
Button(
        onClick = {
            println("Click")
        },
        modifier = Modifier
            .padding(8.dp) //margin
            .border(1.dp, Color.Black)
            .width(48.dp)
            .height(48.dp)
    ) {
        Text(text = "Click!")
    }

Padding example:

<Button 
    android:text="Click"
    android:layout_width="40dp"
    android:layout_height="40dp"
    android:padding="4dp"
    android:margin="8dp"
/>

// With Jetpack Compose
Button(
        onClick = {
            println("Click")
        },
        modifier = Modifier
            .padding(8.dp) //margin
            .border(1.dp, Color.Black)
            .padding(4.dp) //padding
            .width(40.dp)
            .height(40.dp)
    ) {
        Text(text = "Click!")
    }

Invalid examples:

<Button 
    android:text="Click"
    android:layout_width="48dp"
    android:layout_height="48dp"
    android:margin="4dp"
/>
<Button 
    android:text="Click"
    android:layout_width="40dp"
    android:layout_height="40dp"
    android:margin="8dp"
/>

// With Jetpack Compose
Button(
        onClick = {
            println("Click")
        },
        modifier = Modifier
            .padding(8.dp) //margin
            .border(1.dp, Color.Black)
            .width(40.dp)
            .height(40.dp)
    ) {
        Text(text = "Click!")
    }

WCAG reference:



Provide readable text #

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 serif: a minimum text size of 14sp is recommended.

Android natively offers the Roboto font which has 16 variants, including many sans serif that are 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.

Valid example:

<TextView
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:fontFamily="sans-serif" 
    android:textSize="14sp"
    android:text="Exemple"
/>

// With Jetpack Compose
Text(
        text = "Exemple",
	fontFamily = FontFamily.SansSerif,
        fontSize = 14.sp
    )


Unvalid example:

<TextView
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:fontFamily="sans-serif" 
    android:textStyle="italic" 
    android:textSize="14sp"
    android:text="Exemple"
/>
<TextView
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:fontFamily="sans-serif" 
    android:textSize="10sp"
    android:text="Exemple"
/>

// With Jetpack Compose
Text(
        text = "Exemple",
        fontSize = 14.sp,
        fontStyle = FontStyle.Italic,
	fontFamily = FontFamily.SansSerif
    )


WCAG reference:



Make adaptable the time limits that cause 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, because a user may 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" was introduced with Android 10, and allows to define its own timeout. By calling this option from the application, it is possible to adapt its interfaces according to timeout to the user.

It is possible to exploit this option through the getRecommendedTimeoutMillis() function. This method supports user-defined timeouts for interactive and non-interactive user interface elements. The return value is influenced by both user preferences (Time to take action) and accessibility service APIs.

However, as 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:

Accessibility events & custom views #

Target: everyone and in particular people with visual and/or motor impairments.
When: during development.

Description:
There are a lot of events related to the Accessibility API in Android. You can manipulate these events in the same way as other events. It is important to know that these events exist, allow to overload the vocalization of a component, and to enrich custom components that are not sufficiently accessible.

For more information, look at the links below.

Links:

To be verified:

  • Custom views respond appropriately to accessibility



WebView #

Target: everyone and in particular people with visual and/or motor impairments.
When: during development.

Description:
WebView have a special treatment under Android. If you want a accessible web view, the HTML content must be accessible, i.e compliant with international standards on the subject: the WCAG2. To know these rules and learn the development techniques for an accessible web, visit the section of our site dedicated to the subject: accessibility recommendations for the web.

Make sure that the WebView allows JavaScript: mWebView.getSettings().setJavaScriptEnabled(true);.
Under these conditions, the page displayed through the WebView reacts properly to the Accessibility API.

To be verified:

  • WebViews respond appropriately to accessibility