Herunterladbare Schriftarten verwenden
Mit Sammlungen den Überblick behalten
Sie können Inhalte basierend auf Ihren Einstellungen speichern und kategorisieren.
Compose-Ansatz
Jetpack Compose ist das empfohlene UI-Toolkit für Android. Informationen zur Verwendung von Text in Compose
Mit der Funktion „Herunterladbare Schriftarten“ können APIs Schriftarten von einer Anbieteranwendung anfordern, anstatt Dateien in die App einzubinden oder die App Schriftarten herunterladen zu lassen. Herunterladbare Schriftarten sind auf Geräten mit Android 14 (API-Level 34) und höher über die AndroidX Core-Bibliothek verfügbar.
Die App-Größe wird reduziert, wodurch die Erfolgsrate bei der App-Installation steigt.
Die allgemeine Systemleistung wird verbessert, da mehrere Apps dieselbe Schriftart über einen
Anbieter verwenden können. Dadurch sparen Nutzer mobile Daten, Telefonspeicher und Speicherplatz. Bei diesem Modell wird die
Schriftart bei Bedarf über das Netzwerk abgerufen.
Die Beispiel-App
DownloadableFonts
bietet praktische Erfahrungen mit herunterladbaren Schriftarten.
Funktionsweise von herunterladbaren Schriftarten
Ein Schriftartenanbieter ist eine Anwendung, die Schriftarten abruft und lokal im Cache speichert, damit andere Apps Schriftarten anfordern und gemeinsam nutzen können. Die folgende Abbildung veranschaulicht den Prozess.
Abbildung 1. Prozess für herunterladbare Schriftarten
Grundlagen
Sie können die Funktion „Herunterladbare Schriftarten“ auf folgende Arten verwenden, die in späteren Abschnitten ausführlich beschrieben werden:
Herunterladbare Schriftarten mit Android Studio und Google Play-Diensten verwenden
Sie können Ihre Anwendung so einstellen, dass Schriftarten mit Android Studio 3.0 oder höher heruntergeladen werden. Der Schriftartenanbieter von Google Play-Diensten kann Ihnen den Einstieg in die Funktion „Herunterladbare Schriftarten“ erleichtern.
Wählen Sie im Layout-Editor ein TextView aus. Wählen Sie dann unter Attribute die Option fontFamily > Weitere Schriftarten aus.
Abbildung 2.Layout-Editor verwenden
Das Fenster Ressourcen wird angezeigt.
Wählen Sie im Menü Quelle die Option Google Fonts aus.
Wählen Sie im Feld Schriftarten eine Schriftart im Bereich „Herunterladbar“ aus.
Wählen Sie Herunterladbare Schriftart erstellen aus und klicken Sie auf OK.
Abbildung 3. Im Fenster Ressourcen eine Schriftart auswählen
Android Studio generiert automatisch die relevanten XML-Dateien, die erforderlich sind, um die Schriftart in Ihrer App korrekt zu rendern.
Ab Android 8.0 (API-Level 26) bietet AndroidX Core vollständige Unterstützung für herunterladbare Schriftarten. Weitere Informationen zur Verwendung der AndroidX Core-Bibliothek finden Sie auf dieser Seite im Abschnitt Herunterladbare Schriftarten mit AndroidX Core verwenden.
Wenn Sie die Funktion „Herunterladbare Schriftarten“ programmatisch verwenden möchten, interagieren Sie mit zwei wichtigen Klassen:
FontsContractCompat:
Mit dieser Klasse können Sie ein neues
Typeface Objekt basierend auf
der Schriftartanfrage erstellen.
Ihre App ruft Schriftarten vom Schriftartenanbieter über die FontsContract API ab. Jeder Anbieter hat eigene Einschränkungen hinsichtlich der unterstützten Android-Versionen und Abfragesprache. Weitere Informationen zu den Android-Versionen und zum Abfrageformat finden Sie in der Dokumentation Ihres Anbieters.
So laden Sie eine Schriftart herunter:
Erstellen Sie eine Instanz der android.graphics.fonts.FontRequest Klasse, um die
Schriftart vom Anbieter anzufordern. Übergeben Sie die folgenden Parameter, um eine Anfrage zu erstellen:
Die Zertifizierungsstelle des Schriftartenanbieters.
Das Paket des Schriftartenanbieters, um die Identität des Anbieters zu bestätigen.
Die String-Abfrage der Schriftart. Weitere Informationen zu Abfrageformaten finden Sie in der Dokumentation Ihres Schriftartenanbieters, z. B. Google Fonts.
Eine Liste mit Hashsätzen für die Zertifikate, um die Identität des Anbieters zu bestätigen.
Überschreiben Sie die
onTypefaceRetrieved()
Methode, um anzugeben, dass die Schriftartanfrage abgeschlossen ist. Geben Sie die abgerufene Schriftart als Parameter an.
Mit dieser Methode können Sie die Schriftart nach Bedarf festlegen. Sie können die Schriftart beispielsweise für ein
TextView festlegen.
Überschreiben Sie die
onTypefaceRequestFailed()
Methode, um Informationen zu Fehlern im Schriftartanfrageprozess zu erhalten. Weitere Informationen
zu Fehlercodes finden Sie in den
Konstanten für Fehlercodes.
Rufen Sie die FontsContract.requestFont() Methode auf, um die Schriftart vom Schriftartenanbieter abzurufen. Die Methode initiiert eine Prüfung, um festzustellen, ob die Schriftart im Cache vorhanden ist. Wenn
die Schriftart nicht lokal verfügbar ist, ruft sie den Schriftartenanbieter auf, ruft die Schriftart
asynchron ab und übergibt das Ergebnis an den Callback. Übergeben Sie die folgenden Parameter:
Eine Instanz der Klasse android.graphics.fonts.FontRequest
Ein Callback, um die Ergebnisse der Schriftartanfrage zu erhalten
Ein Handler zum Abrufen von Schriftarten in einem Thread
Der folgende Beispielcode veranschaulicht den gesamten Prozess für herunterladbare Schriftarten:
Kotlin
valrequest=FontRequest("com.example.fontprovider.authority","com.example.fontprovider","my font",certs)valcallback=object:FontsContract.FontRequestCallback(){overridefunonTypefaceRetrieved(typeface:Typeface){// Your code to use the font goes here....}overridefunonTypefaceRequestFailed(reason:Int){// Your code to deal with the failure goes here....}}FontsContract.requestFonts(context,request,handler,null,callback)
Java
FontRequestrequest=newFontRequest("com.example.fontprovider.authority","com.example.fontprovider","my font",certs);FontsContract.FontRequestCallbackcallback=newFontsContract.FontRequestCallback(){@OverridepublicvoidonTypefaceRetrieved(Typefacetypeface){// Your code to use the font goes here....}@OverridepublicvoidonTypefaceRequestFailed(intreason){// Your code to deal with the failure goes here....}};FontsContract.requestFonts(context,request,handler,null,callback);
Weitere Informationen zum Herunterladen einer Schriftart von einem Schriftartenanbieter finden Sie in der
Beispiel-App DownloadableFonts.
Herunterladbare Schriftarten mit AndroidX Core verwenden
AndroidX Core bietet Unterstützung für die Funktion „Herunterladbare Schriftarten“ auf Geräten mit Android 14 (API-Level 34) oder höher. Das Paket androidx.core.provider enthält die Klassen FontsContractCompat und FontRequest, um die abwärtskompatible Unterstützung für herunterladbare Schriftarten zu implementieren. Die AndroidX-Klassen enthalten Methoden, die den Framework-Methoden ähneln. Das Herunterladen von Schriftarten ähnelt dem Verfahren, das auf dieser Seite im Abschnitt Herunterladbare Schriftarten programmatisch verwenden beschrieben wird.
Wenn Sie Schriftarten mit AndroidX herunterladen möchten, importieren Sie die Klassen FontsContractCompat und FontRequest aus dem Paket androidx.core.provider. Erstellen Sie Instanzen dieser Klassen anstelle der Framework-Klassen FontsContract und android.graphics.fonts.FontRequest.
AndroidX Core-Abhängigkeit hinzufügen
Wenn Sie die Klassen FontsContractCompat und FontRequest verwenden möchten, müssen Sie die Klassenpfadabhängigkeiten Ihres App-Projekts in Ihrer Entwicklungsumgebung ändern.
Fügen Sie die folgende Abhängigkeit der Datei build.gradle Ihrer App hinzu, um AndroidX Core zu Ihrem Anwendungsprojekt hinzuzufügen:
Herunterladbare Schriftarten als Ressourcen in XML verwenden
Android 8.0 (API-Ebene 26) und AndroidX Core bieten eine schnellere und bequemere Möglichkeit, eine benutzerdefinierte Schriftart als Ressource im XML-Layout zu deklarieren. Das bedeutet, dass die Schriftart nicht als Asset gebündelt werden muss. Sie können eine benutzerdefinierte Schriftart für Ihr gesamtes Design definieren. Das verbessert die Nutzerfreundlichkeit, wenn mehrere Schriftstärken und ‑formatierungen wie fett, mittel oder hell verfügbar sind.
Erstellen Sie eine neue XML-Datei im Ordner res/font.
Fügen Sie ein <font-family>-Stammelement hinzu und legen Sie die Schriftartattribute fest, wie
in der folgenden XML-Beispieldatei gezeigt:
Verweisen Sie in der XML-Layoutdatei auf die Datei als @font/font_file_name. Sie können die Datei mit der Methode getFont() auch programmatisch abrufen, z. B. getFont(R.font.font_file_name).
Schriftarten im Manifest vorab deklarieren
Das Layout-Inflating und der Ressourcenabruf sind synchrone Aufgaben. Standardmäßig löst der erste Versuch, Schriftarten abzurufen, eine Anfrage an den Schriftartenanbieter aus und verlängert daher die Zeit für das erste Layout. Um die Verzögerung zu vermeiden, können Sie Schriftarten, die abgerufen werden müssen, im Manifest vorab deklarieren.
Nachdem das System die Schriftart vom Anbieter abgerufen hat, ist sie sofort verfügbar. Wenn der Abruf der Schriftart länger als erwartet dauert, bricht das System den Abrufprozess ab und verwendet die Standardschriftart.
So deklarieren Sie Schriftarten im Manifest vorab:
Erstellen Sie in res/values/arrays.xml ein Ressourcenarray und deklarieren Sie die Schriftarten, die Sie
vorab abrufen möchten.
Wenn ein Schriftartenanbieter nicht vorinstalliert ist oder Sie die AndroidX Core-Bibliothek verwenden, deklarieren Sie die Zertifikate, mit denen der Schriftartenanbieter signiert ist. Das System verwendet die Zertifikate, um die Identität des Schriftartenanbieters zu bestätigen.
So fügen Sie Zertifikate hinzu:
Erstellen Sie ein String-Array mit den Zertifikatsdetails. Weitere Informationen zu Zertifikats
details finden Sie in der Dokumentation Ihres Schriftartenanbieters.
Legen Sie das Attribut fontProviderCerts auf das Array fest.
android:fontProviderCerts="@array/certs"
Herunterladbare Schriftarten in Compose
Alle Inhalte und Codebeispiele auf dieser Seite unterliegen den Lizenzen wie im Abschnitt Inhaltslizenz beschrieben. Java und OpenJDK sind Marken oder eingetragene Marken von Oracle und/oder seinen Tochtergesellschaften.