Eingabekompatibilität auf großen Bildschirmen

Auf Geräten mit großem Bildschirm interagieren Nutzer häufig mit Apps über eine Tastatur, Maus, ein Touchpad, einen Eingabestift oder ein Gamepad. So aktivieren Sie, dass Ihre App Eingaben von externen Geräten akzeptiert:

  • Testen Sie die grundlegende Tastaturunterstützung, z. B. Strg + Z zum Rückgängigmachen, Strg + C zum Kopieren und Strg + S zum Speichern. Eine Liste der standardmäßigen Tastenkombinationen finden Sie unter Tastaturaktionen verarbeiten.
  • Testen Sie die erweiterte Tastaturunterstützung, z. B. die Navigation per Tabulatortaste und Pfeiltasten, die Bestätigung der Texteingabe per Eingabetaste und die Wiedergabe und Pause in Medien-Apps per Leertaste.
  • Testen Sie grundlegende Mausinteraktionen, einschließlich Rechtsklicks für das Kontextmenü, Symboländerungen beim Bewegen des Mauszeigers und Mausrad- oder Touchpad-Scrollereignisse für benutzerdefinierte Komponenten.
  • App-spezifische Eingabegeräte testen, z. B. Eingabestifte, Gamecontroller und MIDI-Controller für Musik-Apps
  • Berücksichtigen Sie erweiterte Eingabemethoden, mit denen sich Ihre App in Desktopumgebungen abheben kann, z. B. ein Touchpad als Cross-Fader für DJ-Apps, die Mauserfassung für Spiele und Tastenkürzel für Nutzer, die hauptsächlich die Tastatur verwenden.

Tastatur

Die Art und Weise, wie Ihre App auf die Tastatureingabe reagiert, trägt zur Nutzerfreundlichkeit auf dem großen Bildschirm bei. Es gibt drei Arten von Tastatureingaben: Navigation, Tastenanschlag und Tastenkürzel.

Die Tastaturnavigation wird in Touch-orientierten Apps selten implementiert, aber Nutzer erwarten sie, wenn sie eine App verwenden und eine Tastatur zur Hand haben. Die Tastaturnavigation kann für Nutzer mit Beeinträchtigungen auf Smartphones, Tablets, faltbaren Geräten und Computern unerlässlich sein.

Bei vielen Apps werden die Navigation mit den Richtungspfeilen und die Tabulatornavigation automatisch vom Android-Framework verarbeitet. Beispielsweise kann ein Button standardmäßig fokussiert werden und die Tastaturnavigation sollte im Allgemeinen ohne zusätzlichen Code funktionieren. Wenn Sie die Tastaturnavigation für Ansichten aktivieren möchten, die standardmäßig nicht fokussierbar sind, müssen Sie sie als fokussierbar markieren. Das kann programmatisch oder in XML erfolgen:

Kotlin

yourView.isFocusable = true

Java

yourView.setFocusable(true);

Alternativ können Sie das Attribut focusable in Ihrer Layoutdatei festlegen:

android:focusable="true"

Weitere Informationen finden Sie unter Fokusverwaltung.

Wenn der Fokus aktiviert ist, erstellt das Android-Framework eine Navigationszuordnung für alle fokussierbaren Ansichten basierend auf ihrer Position. Das funktioniert in der Regel wie erwartet und es ist keine weitere Entwicklung erforderlich. Wenn die Standardzuordnung für die Anforderungen einer App nicht korrekt ist, kann sie so überschrieben werden:

Kotlin

// Arrow keys
yourView.nextFocusLeftId = R.id.view_to_left
yourView.nextFocusRightId = R.id.view_to_right
yourView.nextFocusTopId = R.id.view_above
yourView.nextFocusBottomId = R.id.view_below
// Tab key
yourView.nextFocusForwardId = R.id.next_view

Java

// Arrow keys
yourView.setNextFocusLeftId(R.id.view_to_left);
yourView.setNextFocusRightId(R.id.view_to_left);
yourView.setNextFocusTopId(R.id.view_to_left);
yourView.setNextFocusBottomId(R.id.view_to_left);
// Tab key
yourView.setNextFocusForwardId(R.id.next_view);

Testen Sie den Zugriff auf alle UI-Elemente Ihrer App nur mit der Tastatur. Häufig verwendete Elemente sollten ohne Maus oder Touchbedienung zugänglich sein.

Denken Sie daran, dass die Tastaturunterstützung für Nutzer mit Beeinträchtigungen möglicherweise unerlässlich ist.

Tastenanschläge

Bei der Texteingabe, die von einer virtuellen Bildschirmtastatur (IME) verarbeitet wird, z. B. fürEditText, sollten Apps auf Geräten mit großem Display ohne zusätzliche Entwicklungsarbeit wie erwartet funktionieren. Bei Tastendrücken, die vom Framework nicht vorhergesehen werden können, müssen Apps das Verhalten selbst steuern. Das gilt insbesondere für Apps mit benutzerdefinierten Ansichten.

Beispiele hierfür sind Chat-Apps, in denen mit der Eingabetaste eine Nachricht gesendet wird, Medien-Apps, in denen die Wiedergabe mit der Leertaste gestartet und angehalten wird, und Spiele, in denen die Bewegung mit den Tasten w, a, s und d gesteuert wird.

Die meisten Apps überschreiben den onKeyUp()-Callback und fügen für jeden empfangenen Tastencode das erwartete Verhalten hinzu:

Kotlin

override fun onKeyUp(keyCode: Int, event: KeyEvent): Boolean {
    return when (keyCode) {
        KeyEvent.KEYCODE_ENTER -> {
            sendChatMessage()
            true
        }
        KeyEvent.KEYCODE_SPACE -> {
            playOrPauseMedia()
            true
        }
        else -> super.onKeyUp(keyCode, event)
    }
}

Java

@Override
public boolean onKeyUp(int keyCode, KeyEvent event) {
    if (keyCode == KeyEvent.KEYCODE_ENTER) {
        sendMessage();
        return true;
    } else if (KeyEvent.KEYCODE_SPACE){
        playOrPauseMedia();
        return true;
    } else {
        return super.onKeyUp(keyCode, event);
    }
}

Ein onKeyUp-Ereignis tritt auf, wenn eine Taste losgelassen wird. Wenn Sie den Rückruf verwenden, müssen Apps nicht mehrere onKeyDown-Ereignisse verarbeiten, wenn eine Taste gedrückt gehalten oder langsam losgelassen wird. Spiele und Apps, die erkennen müssen, wann eine Taste gedrückt wird oder ob der Nutzer eine Taste gedrückt hält, können auf das onKeyDown-Ereignis warten und wiederholte onKeyDown-Ereignisse selbst verarbeiten.

Weitere Informationen finden Sie unter Tastaturaktionen verarbeiten.

Verknüpfungen

Gängige Tastenkombinationen, die die Tasten Strg, Alt, Umschalt und Meta enthalten, sind bei der Verwendung einer Hardwaretastatur zu erwarten. Wenn eine App keine Tastenkürzel implementiert, kann das für Nutzer frustrierend sein. Fortgeschrittene Nutzer schätzen auch Tastenkürzel für häufig verwendete appspezifische Aufgaben. Mithilfe von Tastenkürzeln lässt sich die Bedienung einer App vereinfachen und sie unterscheidet sich von Apps ohne Tastenkürzel.

Zu den gängigen Tastenkombinationen gehören Strg + S (speichern), Strg + Z (rückgängig machen) und Strg + Umschalt + Z (wiederholen). Eine Liste der Standard-Tastenkürzel finden Sie unter Tastaturaktionen verarbeiten.

Tastenkombinationen können aktiviert werden, indem dispatchKeyShortcutEvent() implementiert wird, um alle Tastenkombinationen (Alt, Strg, Umschalt und Meta) für einen bestimmten Tastencode abzufangen. So prüfen Sie, ob eine bestimmte Modifikatortaste gedrückt ist:

Kotlin

override fun dispatchKeyShortcutEvent(event: KeyEvent): Boolean {
  return when (event.keyCode) {
    KeyEvent.KEYCODE_O -> {
      openFile() // Ctrl+O, Shift+O, Alt+O
      true
    }
    KeyEvent.KEYCODE_Z-> {
      if (event.isCtrlPressed) {
        if (event.isShiftPressed) {
          redoLastAction() // Ctrl+Shift+Z pressed
          true
        } else {
          undoLastAction() // Ctrl+Z pressed
          true
        }
      }
    }
    else -> {
      return super.dispatchKeyShortcutEvent(event)
    }
  }
}

Java

@Override
public boolean dispatchKeyShortcutEvent(KeyEvent event) {
  if (event.getKeyCode() == KeyEvent.KEYCODE_O) {
      openFile(); // Ctrl+O, Shift+O, Alt+O
      return true;
  } else if(event.getKeyCode() == KeyEvent.KEYCODE_Z) {
      if (event.isCtrlPressed()) {
          if (event.isShiftPressed()) {
              redoLastAction();
              return true;
          }
          else {
              undoLastAction();
              return true;
          }
      }
  }
  return super.dispatchKeyShortcutEvent(event);
}

Wenn Sie den Tastenkürzelcode von der Verarbeitung anderer Tastenanschläge (z. B. onKeyUp() und onKeyDown()) trennen, werden standardmäßig Modifikatortasten akzeptiert, ohne dass Sie in jedem Fall manuelle Prüfungen für Modifikatortasten implementieren müssen. Wenn alle Tastenkombinationen mit Modifikatortasten zulässig sind, ist das auch für Nutzer praktisch, die an andere Tastaturlayouts und Betriebssysteme gewöhnt sind.

Sie können Tastenkürzel aber auch in onKeyUp() implementieren, indem Sie nach KeyEvent.isCtrlPressed(), KeyEvent.isShiftPressed() oder KeyEvent.isAltPressed() suchen. Das kann die Wartung vereinfachen, wenn das geänderte Tastenverhalten eher eine Änderung am App-Verhalten als ein Tastenkürzel ist. Beispiel: In Spielen bedeutet W „vorwärts gehen“ und Umschalttaste + W „vorwärts laufen“.

Kotlin

override fun onKeyUp(keyCode: Int, event: KeyEvent): Boolean {
  return when(keyCode) {
    KeyEvent.KEYCODE_W-> {
      if (event.isShiftPressed) {
        if (event.isCtrlPressed) {
          flyForward() // Ctrl+Shift+W pressed
          true
        } else {
          runForward() // Shift+W pressed
          true
        }
      } else {
        walkForward() // W pressed
        true
      }
    }
    else -> super.onKeyUp(keyCode, event)
  }
}

Java

@Override
public boolean onKeyUp(int keyCode, KeyEvent event) {
    if (keyCode == KeyEvent.KEYCODE_W) {
        if (event.isShiftPressed()) {
            if (event.isCtrlPressed()) {
                flyForward(); // Ctrl+Shift+W pressed
                return true;
            } else {
                runForward(); // Shift+W pressed
                return true;
            }
        } else {
            walkForward();
            return true;
        }
    }
    return super.onKeyUp(keyCode, event);
}

Weitere Informationen finden Sie unter Hilfe zu Tastenkombinationen.

Eingabestift

Viele Geräte mit großem Display werden mit einem Eingabestift geliefert. Android-Apps behandeln Eingabestifte als Eingabe über den Touchscreen. Einige Geräte haben möglicherweise auch ein USB- oder Bluetooth-Zeichentablet, z. B. das Wacom Intuos. Android-Apps können Bluetooth-Eingabe, aber keine USB-Eingabe empfangen.

Ein Eingabestiftereignis wird von View#onTouchEvent() oder View#onGenericMotionEvent() als Touchscreen-Ereignis erfasst und enthält ein MotionEvent#getSource() vom Typ SOURCE_STYLUS.

Das MotionEvent-Objekt enthält Informationen zum Ereignis:

Bisherige Punkte

Android fasst Eingabeereignisse in Batches zusammen und sendet sie einmal pro Frame. Ein Eingabestift kann Ereignisse viel häufiger als das Display melden. Wenn Sie Zeichen-Apps erstellen, können Sie mithilfe der getHistorical APIs nach Ereignissen in der jüngeren Vergangenheit suchen:

Ablehnung der Hand

Wenn Nutzer mit einem Eingabestift zeichnen, schreiben oder mit Ihrer App interagieren, berühren sie manchmal den Bildschirm mit der Handfläche. Das Touch-Ereignis (auf ACTION_DOWN oder ACTION_POINTER_DOWN festgelegt) kann an Ihre App gemeldet werden, bevor das System die unbeabsichtigte Berührung mit der Handfläche erkennt und ignoriert.

Android sendet ein MotionEvent, um Palm-Touch-Ereignisse abzubrechen. Wenn Ihre App ACTION_CANCEL empfängt, brechen Sie die Geste ab. Wenn Ihre App ACTION_POINTER_UP empfängt, prüfen Sie, ob FLAG_CANCELED festgelegt ist. Falls ja, brechen Sie die Geste ab.

Prüfen Sie nicht nur FLAG_CANCELED. Unter Android 13 (API-Level 33) und höher setzt das System FLAG_CANCELED für ACTION_CANCEL-Ereignisse. Unter niedrigeren Android-Versionen wird das Flag jedoch nicht gesetzt.

Android 12

Unter Android 12 (API-Level 32) und niedriger ist die Erkennung der Handflächenabwehr nur für Touch-Ereignisse mit einem einzelnen Touch-Punkt möglich. Wenn ein Touch mit der Handfläche der einzige Zeiger ist, bricht das System das Ereignis ab, indem es ACTION_CANCEL auf das Bewegungsereignisobjekt setzt. Wenn andere Touchstifte nicht aktiv sind, setzt das System ACTION_POINTER_UP. Das ist nicht ausreichend, um die Ablehnung der Handerkennung zu erkennen.

Android 13

Unter Android 13 (API-Level 33) und höher bricht das System das Ereignis ab, wenn ein Touch mit der Handfläche der einzige Zeiger ist, indem es ACTION_CANCEL und FLAG_CANCELED für das Bewegungsereignisobjekt festlegt. Wenn andere Zeiger unten sind, setzt das System ACTION_POINTER_UP und FLAG_CANCELED.

Wenn Ihre App ein Bewegungsereignis mit ACTION_POINTER_UP empfängt, prüfen Sie, ob FLAG_CANCELED vorhanden ist, um festzustellen, ob das Ereignis auf eine Ablehnung der Handfläche oder eine andere Ereignisannullierung hinweist.

Notizen-Apps

ChromeOS hat eine spezielle Intent-Funktion, mit der registrierte Notizen-Apps für Nutzer angezeigt werden. Wenn Sie eine App als Notiz-App registrieren möchten, fügen Sie Ihrem App-Manifest Folgendes hinzu:

<intent-filter>
    <action android:name="org.chromium.arc.intent.action.CREATE_NOTE" />
    <category android:name="android.intent.category.DEFAULT" />
</intent-filter>

Wenn eine App beim System registriert ist, kann der Nutzer sie als Standard-App zum Erstellen von Notizen auswählen. Wenn eine neue Notiz angefordert wird, sollte die App eine leere Notiz erstellen, die für die Eingabe per Eingabestift bereit ist. Wenn der Nutzer ein Bild (z. B. einen Screenshot oder ein heruntergeladenes Bild) mit Anmerkungen versehen möchte, wird die App mit ClipData gestartet, die ein oder mehrere Elemente mit content://-URIs enthält. Die App sollte eine Notiz erstellen, bei der das erste angehängte Bild als Hintergrundbild verwendet wird, und in einen Modus wechseln, in dem der Nutzer mit einem Eingabestift auf dem Display zeichnen kann.

Absichten zum Erstellen von Notizen ohne Eingabestift testen

[TBD remove section.]

Wenn Sie testen möchten, ob eine App ohne aktiven Eingabestift richtig auf Notizen-Intents reagiert, können Sie die Notizenoptionen auf ChromeOS so anzeigen:

  1. In den Entwicklermodus wechseln und das Gerät beschreibbar machen
  2. Drücken Sie Strg + Alt + F2, um ein Terminal zu öffnen.
  3. Führen Sie den Befehl sudo vi /etc/chrome_dev.conf aus.
  4. Drücken Sie die Taste i, um die Datei zu bearbeiten und --ash-enable-palette in eine neue Zeile am Ende der Datei einzufügen.
  5. Speichern Sie die Datei, indem Sie die Esc-Taste drücken und dann :, w, q und die Eingabetaste drücken.
  6. Drücken Sie Strg + Alt + F1, um zur normalen ChromeOS-Benutzeroberfläche zurückzukehren.
  7. Melden Sie sich ab und dann wieder an.

Im Bereich „Zubehör“ sollte jetzt ein Menü für Eingabestifte angezeigt werden:

  • Tippen Sie im Bereich „Favoriten“ auf die Stifttaste und wählen Sie Neue Notiz aus. Daraufhin sollte eine leere Notiz geöffnet werden.
  • Machen Sie einen Screenshot. Wählen Sie im Bereich „Steuerfeld“ die Schaltfläche für den Eingabestift > Bildschirm erfassen aus oder laden Sie ein Bild herunter. In der Benachrichtigung sollte die Option Bild annotieren angezeigt werden. Dadurch wird die App gestartet und das Bild kann mit Anmerkungen versehen werden.

Unterstützung für Maus und Touchpad

Die meisten Apps müssen in der Regel nur drei Ereignisse für große Bildschirme verarbeiten: Rechtsklick, Bewegung des Mauszeigers und Ziehen und Droppen.

Rechtsklick

Alle Aktionen, die dazu führen, dass in einer App ein Kontextmenü angezeigt wird, z. B. das Berühren und Halten eines Listenelements, sollten auch auf Rechtsklicke reagieren.

Um Rechtsklick-Ereignisse zu verarbeiten, sollten Apps einen View.OnContextClickListener registrieren:

Kotlin

yourView.setOnContextClickListener {
    showContextMenu()
    true
}

Java

yourView.setOnContextClickListener(v -> {
    showContextMenu();
    return true;
});

Weitere Informationen zum Erstellen von Kontextmenüs finden Sie unter Kontextmenü erstellen.

Mauszeiger hierher bewegen

Mit Hover-Ereignissen können Sie Ihre App-Layouts ansprechender und nutzerfreundlicher gestalten. Das gilt besonders für benutzerdefinierte Aufrufe:

Kotlin

// Change the icon to a "hand" pointer on hover.
// Highlight the view by changing the background.
yourView.setOnHoverListener { view, _ ->
    addVisualHighlighting(true)
    view.pointerIcon =
        PointerIcon.getSystemIcon(view.context, PointerIcon.TYPE_HAND)
    true // Listener consumes the event.
}

Java

// Change the icon to a "hand" pointer on hover.
// Highlight the view by changing the background.
yourView.setOnHoverListener((view, event) -> {
    addVisualHighlighting(true);
    view.setPointerIcon(
        PointerIcon.getSystemIcon(view.getContext(), PointerIcon.TYPE_HAND)
    );
    return true; // Listener consumes the event.
});

Die beiden häufigsten Beispiele hierfür sind:

  • Nutzer durch Ändern des Mauszeigersymbols darauf hinweisen, ob ein Element interaktiv ist, z. B. anklickbar oder bearbeitbar
  • Visuelles Feedback für Elemente in einer großen Liste oder einem großen Raster hinzufügen, wenn der Mauszeiger darauf bewegt wird

Drag-and-Drop

In einer Umgebung mit mehreren Fenstern erwarten Nutzer, dass sie Elemente per Drag-and-drop zwischen Apps verschieben können. Das gilt für Computer sowie für Tablets, Smartphones und faltbare Geräte im Splitscreen-Modus.

Überlegen Sie, ob Nutzer wahrscheinlich Elemente in Ihre App ziehen werden. Beispielsweise sollten Bildeditoren Fotos, Audioplayer Audiodateien und Zeichenprogramme Fotos empfangen können.

Informationen zum Hinzufügen der Drag-and-drop-Unterstützung finden Sie unter Drag-and-drop aktivieren sowie im Blogpost Android on ChromeOS – Implementing Drag & Drop.

Besondere Hinweise für ChromeOS

  • Denken Sie daran, mit requestDragAndDropPermissions() die Berechtigung zum Zugriff auf Elemente anzufordern, die von außerhalb der App hereingezogen wurden.
  • Ein Element muss das Flag View.DRAG_FLAG_GLOBAL haben, damit es in andere Anwendungen gezogen werden kann.

Erweiterte Unterstützung für den Cursor

Apps, die die Maus- und Touchpad-Eingabe erweitert verarbeiten, sollten einen View#onGenericMotionEvent() und [MotionEvent.getSource()][], um zwischen SOURCE_MOUSE und SOURCE_TOUCHSCREEN zu unterscheiden.

Prüfen Sie das MotionEvent-Objekt, um das erforderliche Verhalten zu implementieren:

  • Durch Bewegung werden ACTION_HOVER_MOVE Ereignisse generiert.
  • Schaltflächen generieren ACTION_BUTTON_PRESS- und ACTION_BUTTON_RELEASE-Ereignisse. Sie können den aktuellen Status aller Maus- und Touchpad-Schaltflächen auch mit getButtonState() prüfen.
  • Beim Scrollen mit dem Mausrad werden ACTION_SCROLL-Ereignisse generiert.

Controller

Einige Android-Geräte mit großem Display unterstützen bis zu vier Gamecontroller. Verwenden Sie die standardmäßigen Android-Gamecontroller-APIs, um Gamecontroller zu steuern (siehe Gamecontroller unterstützen).

Die Tasten des Gamepads werden gemäß einer gängigen Zuordnung gängigen Werten zugeordnet. Allerdings folgen nicht alle Gamecontroller-Hersteller denselben Zuordnungskonventionen. Sie können die Nutzerfreundlichkeit erheblich verbessern, wenn Sie Nutzern die Auswahl verschiedener gängiger Controller-Belegungen ermöglichen. Weitere Informationen finden Sie unter Gamepad-Tastendrücke verarbeiten.

Übersetzungsmodus für die Eingabe

In ChromeOS ist standardmäßig ein Eingabeübersetzungsmodus aktiviert. Bei den meisten Android-Apps sorgt dieser Modus dafür, dass Apps in einer Desktopumgebung wie erwartet funktionieren. Beispiele hierfür sind das automatische Aktivieren des Zwei-Finger-Scrollens auf dem Touchpad, das Scrollen mit dem Mausrad und das Zuordnen von Rohdisplaykoordinaten zu Fensterkoordinaten. Im Allgemeinen müssen App-Entwickler diese Funktionen nicht selbst implementieren.

Wenn eine App ein benutzerdefiniertes Eingabeverhalten implementiert, z. B. eine benutzerdefinierte Touchpad-Pinch-Aktion mit zwei Fingern, oder diese Eingabeübersetzungen nicht die von der App erwarteten Eingabeereignisse liefern, können Sie den Modus für die Eingabeübersetzung deaktivieren, indem Sie dem Android-Manifest das folgende Tag hinzufügen:

<uses-feature
    android:name="android.hardware.type.pc"
    android:required="false" />

Weitere Informationen