La funzionalità Caratteri scaricabili consente alle API di richiedere caratteri da un'applicazione fornitore anziché
raggruppare i file nell'app o consentire all'app di scaricare i caratteri. I caratteri scaricabili sono disponibili sui dispositivi con versioni dell'API Android 14 e successive tramite la libreria AndroidX Core.
I caratteri scaricabili offrono i seguenti vantaggi:
Riduce le dimensioni dell'app, aumentando così il tasso di successo dell'installazione.
Migliora lo stato generale del sistema, in quanto più app possono condividere lo stesso carattere tramite un provider. In questo modo, gli utenti risparmiano dati mobili, memoria dello smartphone e spazio su disco. In questo modello, il
font viene recuperato dalla rete quando necessario.
Per un'esperienza pratica con i caratteri scaricabili, consulta l'app di esempio
DownloadableFonts.
Come funziona Downloadable Fonts?
Un fornitore di caratteri è un'applicazione che recupera i caratteri e li memorizza nella cache localmente in modo che altre app possano
richiederli e condividerli. La figura seguente illustra il processo.
Figura 1. Procedura per i caratteri scaricabili.
Nozioni di base
Puoi utilizzare la funzionalità Caratteri scaricabili nei seguenti modi, descritti in dettaglio nelle sezioni successive:
Utilizzare i caratteri scaricabili con Android Studio e Google Play Services
Puoi impostare l'applicazione per scaricare i caratteri utilizzando Android Studio 3.0 o versioni successive. Per iniziare a utilizzare le funzionalità dei caratteri scaricabili, puoi utilizzare il provider di caratteri di Google Play Services.
Nell'editor del layout, seleziona un TextView. Poi, in Attributi,
seleziona fontFamily > Altri caratteri.
Figura 2. Utilizzo dell'editor di layout.
Viene visualizzata la finestra Risorse.
Nel menu Origine, seleziona Google Fonts.
Nella casella Font, seleziona un carattere nell'area "Scaricabile".
Seleziona Crea carattere scaricabile e fai clic su Ok.
Figura 3. Selezionando un carattere dalla finestra Risorse.
Android Studio genera automaticamente i file XML pertinenti necessari per eseguire il rendering del carattere
correttamente nella tua app.
Figura 4. Visualizzazione dell'anteprima del file del carattere.
Utilizzare i caratteri scaricabili in modo programmatico
A partire da Android 8.0 (livello API 26), AndroidX Core fornisce il supporto completo per i caratteri scaricabili. Per
maggiori informazioni sull'utilizzo della libreria AndroidX Core, consulta la
sezione Libreria AndroidX Core per i caratteri scaricabili in questa pagina.
Per utilizzare la funzionalità Caratteri scaricabili in modo programmatico, interagisci con due classi chiave:
FontsContractCompat:
questa classe consente di creare un nuovo
oggetto Typeface in base
alla richiesta di carattere.
La tua app recupera i caratteri dal fornitore di caratteri utilizzando l'API FontsContract. Ogni
fornitore ha il proprio insieme di limitazioni relative alle versioni di Android e al linguaggio di query supportato. Per
ulteriori informazioni sulle versioni di Android e sul formato delle query, consulta la
documentazione del tuo provider.
Per scaricare un carattere:
Crea un'istanza della classe android.graphics.fonts.FontRequest per richiedere il
carattere al fornitore. Per creare una richiesta, trasmetti i seguenti parametri:
L'autorità del fornitore di caratteri.
Il pacchetto del fornitore di caratteri per verificare la sua identità.
La stringa di query del carattere. Per ulteriori informazioni sui formati delle query, consulta la documentazione del tuo fornitore di caratteri, ad esempio Google Fonts.
Un elenco di set di hash per i certificati per verificare l'identità del fornitore.
Esegui l'override del
metodo onTypefaceRetrieved()
per indicare che la richiesta di carattere è stata completata. Fornisci il carattere recuperato come parametro.
Puoi utilizzare questo metodo per impostare il carattere in base alle tue esigenze. Ad esempio, puoi impostare il carattere su un
TextView.
Esegui l'override del metodo
onTypefaceRequestFailed()
per ricevere informazioni sugli errori nella procedura di richiesta dei caratteri. Per saperne di più
sui codici di errore, consulta le
costanti dei codici di errore.
Chiama il metodo FontsContract.requestFont() per recuperare il carattere dal fornitore di caratteri. Il metodo avvia un controllo per determinare se il carattere esiste nella cache. Se
il carattere non è disponibile localmente, chiama il fornitore del carattere, lo recupera
in modo asincrono e passa il risultato al callback. Trasmetti i seguenti parametri:
Un'istanza della classe android.graphics.fonts.FontRequest
Una richiamata per ricevere i risultati della richiesta di carattere
Un gestore per recuperare i caratteri in un thread
Il seguente codice di esempio illustra la procedura generale per i caratteri scaricabili:
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);
Per saperne di più su come scaricare un carattere da un fornitore, consulta l'app di esempio
DownloadableFonts.
Utilizzare i caratteri scaricabili con AndroidX Core
AndroidX Core fornisce il supporto per la funzionalità Caratteri scaricabili sui dispositivi con versioni API Android 14 o successive. Il pacchetto
androidx.core.provider
contiene le classi FontsContractCompat e FontRequest per implementare
il supporto della funzionalità Caratteri scaricabili compatibile con le versioni precedenti. Le classi AndroidX contengono metodi
simili a quelli del framework e la procedura per scaricare i caratteri è simile a quella
descritta nella sezione di questa pagina relativa all'utilizzo dei caratteri scaricabili a livello di programmazione.
Per scaricare i caratteri utilizzando AndroidX, importa le classi FontsContractCompat e
FontRequest dal pacchetto androidx.core.provider. Crea
istanze di queste classi anziché
classi framework FontsContract e
android.graphics.fonts.FontRequest.
Aggiungi la dipendenza AndroidX Core
Per utilizzare le classi FontsContractCompat e FontRequest, devi modificare
le dipendenze del classpath del progetto dell'app all'interno del tuo ambiente di sviluppo.
Per aggiungere AndroidX Core al progetto dell'applicazione, aggiungi la seguente dipendenza al file
build.gradle dell'app:
Utilizzare i caratteri scaricabili come risorse in XML
Android 8.0 (livello API 26) e AndroidX Core offrono un modo più rapido e pratico per dichiarare un
carattere personalizzato come risorsa nel layout XML. Ciò significa che non è necessario raggruppare il carattere come asset. Puoi definire un carattere personalizzato per l'intero tema, il che accelera l'usabilità per
più pesi e stili, come grassetto, medio o chiaro, se forniti.
Crea un nuovo file XML nella cartella res/font.
Aggiungi un elemento principale <font-family> e imposta gli attributi relativi al carattere, come
mostrato nel seguente file XML di esempio:
Fai riferimento al file come @font/font_file_name nel file XML del layout. Puoi anche
utilizzare il
metodo getFont()
per recuperare il file in modo programmatico, ad esempio
getFont(R.font.font_file_name).
Dichiarare in anticipo i caratteri nel manifest
L'espansione del layout e il recupero delle risorse sono attività sincrone. Per impostazione predefinita, il primo tentativo di recupero dei caratteri attiva una richiesta al fornitore di caratteri e quindi aumenta il tempo del primo layout. Per evitare il ritardo, puoi pre-dichiarare nel manifest i caratteri che devono essere recuperati.
Dopo che il sistema recupera il carattere dal provider, questo è disponibile immediatamente. Se il recupero
del carattere richiede più tempo del previsto, il sistema interrompe il processo di recupero e utilizza il carattere
predefinito.
Per dichiarare in anticipo i caratteri nel manifest, completa i seguenti passaggi:
Crea un array di risorse in res/values/arrays.xml e dichiara i caratteri che
vuoi precaricare.
Quando un fornitore di caratteri non è preinstallato o se utilizzi la libreria AndroidX Core, dichiara
i certificati con cui è firmato il fornitore di caratteri. Il sistema utilizza i certificati per verificare l'identità
del fornitore di caratteri.
Per aggiungere certificati, segui questi passaggi:
Crea un array di stringhe con i dettagli del certificato. Per maggiori informazioni sui dettagli del certificato, consulta la documentazione del fornitore di caratteri.
I campioni di contenuti e codice in questa pagina sono soggetti alle licenze descritte nella Licenza per i contenuti. Java e OpenJDK sono marchi o marchi registrati di Oracle e/o delle sue società consociate.