Leistung für Bilder optimieren

Wenn Sie nicht vorsichtig sind, können beim Arbeiten mit Bildern schnell Leistungsprobleme auftreten. Bei der Arbeit mit großen Bitmaps kann es leicht zu einem OutOfMemoryError kommen. Mit diesen Best Practices können Sie die Leistung Ihrer App optimieren.

Nur die benötigte Größe der Bitmap laden

Die meisten Smartphones haben Kameras mit hoher Auflösung, die große Bilddateien erzeugen. Wenn Sie ein Bild auf dem Bildschirm anzeigen, müssen Sie entweder die Auflösung des Bildes reduzieren oder das Bild nur bis zur Größe des Bildcontainers laden. Das ständige Laden von Bildern, die größer als nötig sind, kann die GPU-Caches erschöpfen und zu einem weniger leistungsfähigen UI-Rendering führen.

So verwalten Sie die Bildgrößen:

  • Skalieren Sie Ihre Bilddateien so klein wie möglich, ohne das Ausgabebild zu beeinträchtigen.
  • Sie können Ihre Bilder in das WEBP-Format konvertieren, anstatt sie als JPEG- oder PNG-Dateien zu speichern.
  • Stellen Sie kleinere Bilder für unterschiedliche Bildschirmauflösungen bereit (siehe Tipp 3).
  • Verwenden Sie eine Bibliothek zum Laden von Bildern, die das Bild so skaliert, dass es zur Größe der Ansicht auf dem Bildschirm passt. Dadurch kann die Ladeleistung Ihres Bildschirms verbessert werden.

Nach Möglichkeit Vektoren anstelle von Bitmaps verwenden

Wenn Sie etwas visuell auf dem Bildschirm darstellen, müssen Sie entscheiden, ob es als Vektor dargestellt werden kann oder nicht. Verwenden Sie Vektorbilder anstelle von Bitmaps, da sie nicht zu Pixeln werden, wenn Sie sie auf unterschiedliche Größen skalieren. Nicht alles kann jedoch als Vektor dargestellt werden. Bilder, die mit einer Kamera aufgenommen wurden, können nicht in einen Vektor umgewandelt werden.

Stellen Sie alternative Ressourcen für unterschiedliche Bildschirmgrößen bereit

Wenn Sie mit Ihrer App Bilder versenden, sollten Sie Assets unterschiedlicher Größe für unterschiedliche Geräteauflösungen bereitstellen. So lässt sich die Downloadgröße Ihrer App auf Geräten reduzieren und die Leistung verbessern, da auf einem Gerät mit niedriger Auflösung ein Bild mit niedrigerer Auflösung geladen wird. Weitere Informationen zum Bereitstellen alternativer Bitmaps für verschiedene Gerätegrößen finden Sie in der Dokumentation zu alternativen Bitmaps.

Bei Verwendung von ImageBitmap prepareToDraw vor dem Zeichnen aufrufen

Wenn Sie ImageBitmap verwenden, müssen Sie ImageBitmap#prepareToDraw() aufrufen, bevor Sie die Textur auf die GPU hochladen, um mit dem Zeichnen zu beginnen. So kann die GPU die Textur vorbereiten und die Leistung der Darstellung eines visuellen Elements auf dem Bildschirm verbessern. Die meisten Bibliotheken zum Laden von Bildern führen diese Optimierung bereits durch. Wenn Sie jedoch selbst mit der Klasse ImageBitmap arbeiten, sollten Sie dies beachten.

Übergeben Sie stattdessen Int, DrawableRes oder eine URL als Parameter an das Composeable anstelle von Painter.

Aufgrund der Komplexität der Bildverarbeitung (z. B. wäre das Schreiben einer Gleichheitsfunktion für Bitmaps rechenintensiv) ist die Painter API ausdrücklich nicht als Stable-Klasse gekennzeichnet. Instabile Klassen können zu unnötigen Neuzusammensetzungen führen, da der Compiler nicht einfach ableiten kann, ob sich die Daten geändert haben.

Daher ist es besser, eine URL oder eine Drawable-Ressourcen-ID als Parameter an die zusammensetzbare Funktion zu übergeben, anstatt Painter als Parameter zu übergeben.

// Prefer this:
@Composable
fun MyImage(url: String) {

}
// Over this:
@Composable
fun MyImage(painter: Painter) {

}

Eine Bitmap nicht länger im Arbeitsspeicher speichern, als es erforderlich ist

Je mehr Bitmaps Sie in den Arbeitsspeicher laden, desto wahrscheinlicher ist es, dass der Arbeitsspeicher des Geräts aufgebraucht wird. Wenn Sie beispielsweise eine große Liste von Bildkompositionen auf dem Bildschirm laden, können Sie mit LazyColumn oder LazyRow dafür sorgen, dass beim Scrollen durch eine große Liste Arbeitsspeicher freigegeben wird.

Große Bilder nicht mit der AAB-/APK-Datei verpacken

Eine der Hauptursachen für eine große Downloadgröße von Apps sind Grafiken, die in der AAB- oder APK-Datei verpackt sind. Verwenden Sie das Tool APK-Analysator, um sicherzustellen, dass Sie keine größeren als die erforderlichen Bilddateien verpacken. Verringern Sie die Größe oder platzieren Sie die Bilder auf einem Server und laden Sie sie nur bei Bedarf herunter.