Questa pagina descrive come impostare i caratteri nella tua app Compose.
Impostare il carattere
Text ha un parametro fontFamily per consentire l'impostazione del carattere utilizzato nel composable. Per impostazione predefinita, le famiglie di caratteri serif, sans-serif, monospace e corsivo
sono incluse:
@Composable fun DifferentFonts() { Column { Text("Hello World", fontFamily = FontFamily.Serif) Text("Hello World", fontFamily = FontFamily.SansSerif) } }
Puoi utilizzare l'attributo fontFamily per lavorare con caratteri e tipi di carattere personalizzati definiti nella cartella res/font:
Questo esempio mostra come definire un fontFamily in base a questi file di caratteri
e utilizzando la funzione Font:
val firaSansFamily = FontFamily( Font(R.font.firasans_light, FontWeight.Light), Font(R.font.firasans_regular, FontWeight.Normal), Font(R.font.firasans_italic, FontWeight.Normal, FontStyle.Italic), Font(R.font.firasans_medium, FontWeight.Medium), Font(R.font.firasans_bold, FontWeight.Bold) )
Puoi passare questo fontFamily al tuo composable Text. Poiché un fontFamily può includere pesi diversi, puoi impostare manualmente fontWeight per selezionare il peso corretto per il testo:
Column { Text(text = "text", fontFamily = firaSansFamily, fontWeight = FontWeight.Light) Text(text = "text", fontFamily = firaSansFamily, fontWeight = FontWeight.Normal) Text( text = "text", fontFamily = firaSansFamily, fontWeight = FontWeight.Normal, fontStyle = FontStyle.Italic ) Text(text = "text", fontFamily = firaSansFamily, fontWeight = FontWeight.Medium) Text(text = "text", fontFamily = firaSansFamily, fontWeight = FontWeight.Bold) }
Per scoprire come impostare la tipografia nell'intera app, consulta Sistemi di progettazione personalizzati in Compose.
Caratteri scaricabili
A partire da Compose 1.2.0, puoi utilizzare l'API dei caratteri scaricabili nella tua app Compose per scaricare in modo asincrono i caratteri Google e utilizzarli nella tua app.
Al momento non è disponibile il supporto per i caratteri scaricabili forniti da provider personalizzati.
Utilizzare i caratteri scaricabili a livello di programmazione
Per scaricare un carattere a livello di programmazione dall'interno dell'app:
- Aggiungi la dipendenza:
Alla moda
dependencies { ... implementation "androidx.compose.ui:ui-text-google-fonts:1.10.5" }
Kotlin
dependencies { ... implementation("androidx.compose.ui:ui-text-google-fonts:1.10.5") }
- Inizializza
GoogleFont.Providercon le credenziali per Google Fonts: I parametri ricevuti dal provider sono:val provider = GoogleFont.Provider( providerAuthority = "com.google.android.gms.fonts", providerPackage = "com.google.android.gms", certificates = R.array.com_google_android_gms_fonts_certs )
- L'autorità del provider di caratteri per Google Fonts.
- Il pacchetto del provider di caratteri per verificare l'identità del provider.
- Un elenco di set di hash per i certificati per verificare l'identità del
provider. Puoi trovare gli hash richiesti per il provider di Google Fonts
nel file
font_certs.xmlnell'app di esempio Jetchat.
- Definisci un
FontFamily: Puoi eseguire query per altri parametri del carattere, come peso e stile, rispettivamente con// ... import androidx.compose.ui.text.googlefonts.GoogleFont import androidx.compose.ui.text.font.FontFamily import androidx.compose.ui.text.googlefonts.Font // ... val fontName = GoogleFont("Lobster Two") val fontFamily = FontFamily( Font(googleFont = fontName, fontProvider = provider) )
FontWeighteFontStyle:// ... import androidx.compose.ui.text.googlefonts.GoogleFont import androidx.compose.ui.text.font.FontFamily import androidx.compose.ui.text.googlefonts.Font // ... val fontName = GoogleFont("Lobster Two") val fontFamily = FontFamily( Font( googleFont = fontName, fontProvider = provider, weight = FontWeight.Bold, style = FontStyle.Italic ) )
- Configura
FontFamilyda utilizzare nella funzione composable Text:
Text( fontFamily = fontFamily, text = "Hello World!" )
Puoi anche definire
la tipografia per utilizzare
il tuo FontFamily:
val MyTypography = Typography( bodyMedium = TextStyle( fontFamily = fontFamily, fontWeight = FontWeight.Normal, fontSize = 12.sp/*...*/ ), bodyLarge = TextStyle( fontFamily = fontFamily, fontWeight = FontWeight.Bold, letterSpacing = 2.sp, /*...*/ ), headlineMedium = TextStyle( fontFamily = fontFamily, fontWeight = FontWeight.SemiBold/*...*/ ), /*...*/ )
Dopodiché, imposta la tipografia sul tema della tua app:
MyAppTheme( typography = MyTypography )/*...*/
Per un esempio di un'app che implementa i caratteri scaricabili in Compose insieme a Material3, consulta l'app di esempio Jetchat.
Aggiungere caratteri di riserva
Puoi determinare una catena di fallback per il carattere nel caso in cui il download non vada a buon fine. Ad esempio, se hai definito il carattere scaricabile in questo modo:
// ... import androidx.compose.ui.text.googlefonts.Font // ... val fontName = GoogleFont("Lobster Two") val fontFamily = FontFamily( Font(googleFont = fontName, fontProvider = provider), Font(googleFont = fontName, fontProvider = provider, weight = FontWeight.Bold) )
Puoi definire i valori predefiniti per il carattere per entrambi i pesi in questo modo:
// ... import androidx.compose.ui.text.font.Font import androidx.compose.ui.text.googlefonts.Font // ... val fontName = GoogleFont("Lobster Two") val fontFamily = FontFamily( Font(googleFont = fontName, fontProvider = provider), Font(resId = R.font.my_font_regular), Font(googleFont = fontName, fontProvider = provider, weight = FontWeight.Bold), Font(resId = R.font.my_font_regular_bold, weight = FontWeight.Bold) )
Assicurati di aggiungere le importazioni corrette.
La definizione di FontFamily in questo modo crea un FontFamily contenente due catene, una per peso. Il meccanismo di caricamento tenterà di risolvere prima il carattere online e poi il carattere che si trova nella cartella delle risorse R.font locale.
Eseguire il debug dell'implementazione
Per verificare se il download del carattere è corretto, puoi definire un gestore di coroutine di debug. Il gestore fornisce il comportamento da adottare nel caso in cui il caricamento asincrono del carattere non vada a buon fine.
Inizia creando un
CoroutineExceptionHandler:
val handler = CoroutineExceptionHandler { _, throwable -> // process the Throwable Log.e(TAG, "There has been an issue: ", throwable) }
Passalo al
createFontFamilyResolver
metodo per fare in modo che il resolver utilizzi il nuovo gestore:
CompositionLocalProvider( LocalFontFamilyResolver provides createFontFamilyResolver(LocalContext.current, handler) ) { Column { Text( text = "Hello World!", style = MaterialTheme.typography.bodyMedium ) } }
Puoi anche utilizzare l'
isAvailableOnDevice
API del provider per verificare se il provider è disponibile e se i certificati sono
configurati correttamente. Per farlo, puoi chiamare il metodo isAvailableOnDevice che restituisce false se il provider non è configurato correttamente.
val context = LocalContext.current LaunchedEffect(Unit) { if (provider.isAvailableOnDevice(context)) { Log.d(TAG, "Success!") } }
Precisazioni
Google Fonts impiega diversi mesi per rendere disponibili i nuovi caratteri su Android.
Esiste un intervallo di tempo tra il momento in cui un carattere viene aggiunto in
fonts.google.com e il momento in cui è disponibile tramite
l'API dei caratteri scaricabili (nel sistema View o in Compose). Il caricamento dei caratteri appena aggiunti potrebbe non riuscire nella tua app con un
IllegalStateException.
Per aiutare gli sviluppatori a identificare questo errore rispetto ad altri tipi di errori di caricamento dei caratteri,
abbiamo aggiunto messaggi descrittivi per l'eccezione in Compose con le modifiche
qui.
Se riscontri problemi, segnalali utilizzando lo strumento di monitoraggio dei problemi.
Utilizzare i caratteri variabili
Un carattere variabile è un formato di carattere che consente a un file di carattere di contenere stili diversi. Con i caratteri variabili, puoi modificare gli assi (o i parametri) per generare lo stile che preferisci. Questi assi possono essere standard, come peso, larghezza, inclinazione e corsivo, o personalizzati, che variano a seconda dei caratteri variabili.
L'utilizzo di caratteri variabili anziché di file di caratteri normali consente di avere un solo file di caratteri anziché più file.
Per ulteriori informazioni sui caratteri variabili, consulta la sezione Google Fonts Conoscenze, l'intero catalogo dei caratteri variabili disponibili e una tabella degli assi supportati per ogni carattere.
Questo documento mostra come implementare un carattere variabile nella tua app Compose.
Caricare un carattere variabile
Scarica il carattere variabile che vuoi utilizzare (ad esempio Roboto Flex) e inseriscilo nella cartella
app/res/fontdella tua app. Assicurati che il file .ttfche aggiungi sia la versione del carattere variabile e che il nome del file del carattere sia tutto in minuscolo e non contenga caratteri speciali.Per caricare un carattere variabile, definisci un
FontFamilyutilizzando il carattere inserito nella directoryres/font/:// In Typography.kt @OptIn(ExperimentalTextApi::class) val displayLargeFontFamily = FontFamily( Font( R.font.robotoflex_variable, variationSettings = FontVariation.Settings( FontVariation.weight(950), FontVariation.width(30f), FontVariation.slant(-6f), ) ) )
L'API
FontVariationconsente di configurare gli assi dei caratteri standard, come peso, larghezza e inclinazione. Questi sono assi standard disponibili con qualsiasi carattere variabile. Puoi creare configurazioni diverse del carattere in base a dove verrà utilizzato.I caratteri variabili sono disponibili solo per le versioni di Android O e successive, quindi aggiungi una protezione e configura un fallback appropriato:
// In Typography.kt val default = FontFamily( /* * This can be any font that makes sense */ Font( R.font.robotoflex_static_regular ) ) @OptIn(ExperimentalTextApi::class) val displayLargeFontFamily = if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) { FontFamily( Font( R.font.robotoflex_variable, variationSettings = FontVariation.Settings( FontVariation.weight(950), FontVariation.width(30f), FontVariation.slant(-6f), ) ) ) } else { default }
Estrai le impostazioni in un insieme di costanti per un riutilizzo più semplice e sostituisci le impostazioni dei caratteri con queste costanti:
// VariableFontDimension.kt object DisplayLargeVFConfig { const val WEIGHT = 950 const val WIDTH = 30f const val SLANT = -6f const val ASCENDER_HEIGHT = 800f const val COUNTER_WIDTH = 500 } @OptIn(ExperimentalTextApi::class) val displayLargeFontFamily = if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) { FontFamily( Font( R.font.robotoflex_variable, variationSettings = FontVariation.Settings( FontVariation.weight(DisplayLargeVFConfig.WEIGHT), FontVariation.width(DisplayLargeVFConfig.WIDTH), FontVariation.slant(DisplayLargeVFConfig.SLANT), ) ) ) } else { default }
Configura la tipografia Material Design 3 typography per utilizzare il
FontFamily:// Type.kt val Typography = Typography( displayLarge = TextStyle( fontFamily = displayLargeFontFamily, fontSize = 50.sp, lineHeight = 64.sp, letterSpacing = 0.sp, /***/ ) )
Questo esempio utilizza
displayLargela tipografia Material 3, che ha impostazioni dei caratteri predefinite e utilizzi consigliati diversi. Ad esempio, devi utilizzaredisplayLargeper il testo breve e critico, poiché è il testo più grande sullo schermo.Con Material 3, puoi modificare i valori predefiniti di
TextStyleefontFamilyper personalizzare la tipografia. Nello snippet sopra, configuri le istanze diTextStyleper personalizzare le impostazioni dei caratteri per ogni famiglia di caratteri.Ora che hai definito la tipografia, passala a
MaterialThemeM3:MaterialTheme( colorScheme = MaterialTheme.colorScheme, typography = Typography, content = content )
Infine, utilizza un composable
Texte specifica lo stile in uno degli stili di tipografia definiti,MaterialTheme.typography.displayLarge:@Composable @Preview fun CardDetails() { MyCustomTheme { Card( shape = RoundedCornerShape(8.dp), elevation = CardDefaults.cardElevation(defaultElevation = 4.dp), modifier = Modifier .fillMaxWidth() .padding(16.dp) ) { Column( modifier = Modifier.padding(16.dp) ) { Text( text = "Compose", style = MaterialTheme.typography.displayLarge, modifier = Modifier.padding(bottom = 8.dp), maxLines = 1 ) Text( text = "Beautiful UIs on Android", style = MaterialTheme.typography.headlineMedium, modifier = Modifier.padding(bottom = 8.dp), maxLines = 2 ) Text( text = "Jetpack Compose is Android’s recommended modern toolkit for building native UI. It simplifies and accelerates UI development on Android. Quickly bring your app to life with less code, powerful tools, and intuitive Kotlin APIs.", style = MaterialTheme.typography.bodyLarge, modifier = Modifier.padding(bottom = 8.dp), maxLines = 3 ) } } } }
Ogni composable
Textviene configurato tramite lo stile del tema Material e contiene una configurazione di caratteri variabili diversa. Puoi utilizzareMaterialTheme.typographyper recuperare la tipografia fornita al composable M3MaterialTheme.
Utilizzare gli assi personalizzati
I caratteri possono avere anche assi personalizzati. Questi sono definiti all'interno del file del carattere stesso.
Ad esempio, il carattere Roboto Flex ha l'asse dell'altezza dell'ascendente ("YTAS"), che
regola l'altezza degli ascendenti minuscoli, mentre la larghezza del contatore ("XTRA")
regola la larghezza di ogni lettera.
Puoi modificare il valore di questi assi con le impostazioni FontVariation.
Per ulteriori informazioni sugli assi personalizzati che puoi configurare per un carattere, consulta la tabella degli assi supportati per ogni carattere.
Per utilizzare gli assi personalizzati, definisci le funzioni per gli assi personalizzati
ascenderHeightecounterWidth:fun ascenderHeight(ascenderHeight: Float): FontVariation.Setting { require(ascenderHeight in 649f..854f) { "'Ascender Height' must be in 649f..854f" } return FontVariation.Setting("YTAS", ascenderHeight) } fun counterWidth(counterWidth: Int): FontVariation.Setting { require(counterWidth in 323..603) { "'Counter width' must be in 323..603" } return FontVariation.Setting("XTRA", counterWidth.toFloat()) }
Queste funzioni eseguono le seguenti operazioni:
- Definiscono le protezioni per i valori che possono accettare. Come puoi vedere nel
catalogo dei caratteri variabili,
ascenderHeight (YTAS)ha un valore minimo di649fe un valore massimo di854f. - Restituiscono l'impostazione del carattere, in modo che la configurazione sia pronta per essere aggiunta al carattere. Nel metodo
FontVariation.Setting(), il nome dell'asse (YTAS, XTRA) è hardcoded e accetta il valore come parametro.
- Definiscono le protezioni per i valori che possono accettare. Come puoi vedere nel
catalogo dei caratteri variabili,
Utilizzando gli assi con la configurazione dei caratteri, passa parametri aggiuntivi a ogni
Fontcaricato:@OptIn(ExperimentalTextApi::class) val displayLargeFontFamily = if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) { FontFamily( Font( R.font.robotoflex_variable, variationSettings = FontVariation.Settings( FontVariation.weight(DisplayLargeVFConfig.WEIGHT), FontVariation.width(DisplayLargeVFConfig.WIDTH), FontVariation.slant(DisplayLargeVFConfig.SLANT), ascenderHeight(DisplayLargeVFConfig.ASCENDER_HEIGHT), counterWidth(DisplayLargeVFConfig.COUNTER_WIDTH) ) ) ) } else { default }
Tieni presente che l'altezza degli ascendenti minuscoli è aumentata e l'altro testo è più ampio:
Risorse aggiuntive
Per ulteriori informazioni, consulta il seguente post del blog sui caratteri variabili:
Consigliati per te
- Nota: il testo del link viene visualizzato quando JavaScript è disattivato
- Risorse in Compose
- Applicare uno stile al testo
- Material Design 2 in Compose