Jetpack Compose offre un'implementazione di Material Design 3, la prossima evoluzione di Material Design. Material 3 include temi, componenti e funzionalità di personalizzazione di Material You aggiornati, come i colori dinamici, ed è progettato per essere coerente con il nuovo stile visivo e l'interfaccia utente di sistema su Android 12 e versioni successive.
Di seguito viene mostrata l'implementazione di Material Design 3 utilizzando come esempio l'app di esempio di risposta. L'esempio di risposta si basa interamente su Material Design 3.
Dipendenza
Per iniziare a utilizzare Material 3 nella tua app Compose, aggiungi la dipendenza Compose Material 3 ai file build.gradle
:
implementation "androidx.compose.material3:material3:$material3_version"
Una volta aggiunta la dipendenza, puoi iniziare ad aggiungere sistemi di Material Design alle tue app, tra cui colore, tipografia e forma.
API sperimentali
Alcune API M3 sono considerate sperimentali. In questi casi, devi attivare la funzionalità a livello di funzione o file utilizzando l'annotazione ExperimentalMaterial3Api
:
// import androidx.compose.material3.ExperimentalMaterial3Api @Composable fun AppComposable() { // M3 composables }
Temi di Material
Un tema M3 contiene i seguenti sottosistemi: combinazione di colori, typography e forme. Quando personalizzi questi valori, le modifiche vengono applicate automaticamente ai componenti M3 che utilizzi per creare l'app.
Jetpack Compose implementa questi concetti con il composable M3 MaterialTheme
:
MaterialTheme( colorScheme = /* ... typography = /* ... shapes = /* ... ) { // M3 app content }
Per applicare un tema ai contenuti dell'applicazione, definisci la combinazione di colori, la tipografia e le forme specifiche della tua app.
Combinazione di colori
La base di una combinazione di colori è l'insieme di cinque colori chiave. Ognuno di questi colori si riferisce a una tavolozza di 13 tonalità, utilizzata dai componenti di Material 3. Ad esempio, questa è la combinazione di colori per il tema chiaro di Rispondi:
Scopri di più su Schemi di colori e ruoli dei colori.
Generare combinazioni di colori
Sebbene sia possibile creare un ColorScheme
personalizzato manualmente, spesso è più facile generarne uno utilizzando i colori di origine del tuo brand. Lo strumento Material Theme
Builder ti consente di farlo ed eventualmente di esportare il codice di temi di Compose. Vengono generati i seguenti file:
Color.kt
contiene i colori del tema con tutti i ruoli definiti sia per i colori del tema chiaro che per quelli scuri.
val md_theme_light_primary = Color(0xFF476810) val md_theme_light_onPrimary = Color(0xFFFFFFFF) val md_theme_light_primaryContainer = Color(0xFFC7F089) // .. // .. val md_theme_dark_primary = Color(0xFFACD370) val md_theme_dark_onPrimary = Color(0xFF213600) val md_theme_dark_primaryContainer = Color(0xFF324F00) // .. // ..
Theme.kt
contiene una configurazione per le combinazioni di colori chiare e scure e per il tema dell'app.
private val LightColorScheme = lightColorScheme( primary = md_theme_light_primary, onPrimary = md_theme_light_onPrimary, primaryContainer = md_theme_light_primaryContainer, // .. ) private val DarkColorScheme = darkColorScheme( primary = md_theme_dark_primary, onPrimary = md_theme_dark_onPrimary, primaryContainer = md_theme_dark_primaryContainer, // .. ) @Composable fun ReplyTheme( darkTheme: Boolean = isSystemInDarkTheme(), content: @Composable () -> Unit ) { val colorScheme = if (!darkTheme) { LightColorScheme } else { DarkColorScheme } MaterialTheme( colorScheme = colorScheme, content = content ) }
Per supportare i temi chiaro e scuro, utilizza isSystemInDarkTheme()
. In base all'impostazione di sistema, definisci la combinazione di colori da utilizzare: chiara o scura.
Combinazioni di colori dinamiche
Il colore dinamico è la parte fondamentale di Material You, in cui un algoritmo ricava colori personalizzati dallo sfondo di un utente da applicare alle sue app e all'interfaccia utente di sistema. Questa tavolozza dei colori viene utilizzata come punto di partenza per generare combinazioni di colori chiare e scure.
Il colore dinamico è disponibile su Android 12 e versioni successive. Se il colore dinamico è disponibile, puoi configurare un ColorScheme
dinamico. In caso contrario, dovresti utilizzare un ColorScheme
chiaro o scuro personalizzato.
ColorScheme
fornisce funzioni di creazione per creare una combinazione di colori chiara o
scura dinamica:
// Dynamic color is available on Android 12+ val dynamicColor = Build.VERSION.SDK_INT >= Build.VERSION_CODES.S val colors = when { dynamicColor && darkTheme -> dynamicDarkColorScheme(LocalContext.current) dynamicColor && !darkTheme -> dynamicLightColorScheme(LocalContext.current) darkTheme -> DarkColorScheme else -> LightColorScheme }
Utilizzo del colore
Puoi accedere ai colori dei temi Material nella tua app tramite
MaterialTheme.colorScheme
:
Text( text = "Hello theming", color = MaterialTheme.colorScheme.primary )
Ogni ruolo di colore può essere utilizzato in vari punti a seconda dello stato, dell'importanza e dell'enfasi del componente.
- Il colore principale è il colore di base, utilizzato per i componenti principali come pulsanti in evidenza, stati attivi e la tinta delle superfici in rilievo.
- Il colore della chiave secondaria viene utilizzato per i componenti meno in evidenza nell'interfaccia utente, come i chip di filtro, ed espande le opportunità di espressione del colore.
- Il colore chiave terziario viene utilizzato per ricavare i ruoli degli accenti a contrasto che possono essere utilizzati per bilanciare i colori primari e secondari o attirare maggiormente l'attenzione su un elemento.
Il design dell'app di esempio di Risposta utilizza il colore on-primary-container sopra primary-container per mettere in evidenza l'elemento selezionato.
Card( colors = CardDefaults.cardColors( containerColor = if (isSelected) MaterialTheme.colorScheme.primaryContainer else MaterialTheme.colorScheme.surfaceVariant ) ) { Text( text = "Dinner club", style = MaterialTheme.typography.bodyLarge, color = if (isSelected) MaterialTheme.colorScheme.onPrimaryContainer else MaterialTheme.colorScheme.onSurface, ) }
Qui puoi vedere nel riquadro di navigazione della risposta come i colori dei contenitori secondari e terziari vengono utilizzati in contrasto per creare enfasi e accenti.
Tipografia
Material Design 3 definisce una scala di tipo, inclusi gli stili di testo che sono stati adattati da Material Design 2. La denominazione e il raggruppamento sono stati semplificati in: display, titolo, titolo, testo e etichetta, con dimensioni grandi, medie e piccole per ciascuna.
M3 | Dimensioni carattere/altezza riga predefinite |
displayLarge |
Roboto 57/64 |
displayMedium |
Roboto 45/52 |
displaySmall |
Roboto 36/44 |
headlineLarge |
Roboto 32/40 |
headlineMedium |
Roboto 28/36 |
headlineSmall |
Roboto 24/32 |
titleLarge |
New- Roboto Medium 22/28 |
titleMedium |
Roboto Medium 16/24 |
titleSmall |
Roboto Medium 14/20 |
bodyLarge |
Roboto 16/24 |
bodyMedium |
Roboto 14/20 |
bodySmall |
Roboto 12/16 |
labelLarge |
Roboto Medium 14/20 |
labelMedium |
Roboto Medium 12/16 |
labelSmall |
New Roboto Medium, 11/16 |
Definisci la tipografia
Compose fornisce la classe M3 Typography
, insieme alle classi TextStyle
e relative ai caratteri esistenti, per modellare la scala di tipi di Material 3. Il costruttore Typography
offre valori predefiniti per ogni stile, in modo da poter omettere i parametri che non vuoi personalizzare:
val replyTypography = Typography( titleLarge = TextStyle( fontWeight = FontWeight.SemiBold, fontSize = 22.sp, lineHeight = 28.sp, letterSpacing = 0.sp ), titleMedium = TextStyle( fontWeight = FontWeight.SemiBold, fontSize = 16.sp, lineHeight = 24.sp, letterSpacing = 0.15.sp ), // .. ) // ..
È probabile che il tuo prodotto non abbia bisogno di tutti i 15 stili predefiniti della scala di tipo Material Design. In questo esempio, vengono scelte cinque dimensioni per un insieme ridotto, mentre il resto viene omesso.
Puoi personalizzare la tipografia modificando i valori predefiniti di TextStyle
e delle proprietà relative ai caratteri come fontFamily
e letterSpacing
.
bodyLarge = TextStyle( fontWeight = FontWeight.Normal, fontFamily = FontFamily.SansSerif, fontStyle = FontStyle.Italic, fontSize = 16.sp, lineHeight = 24.sp, letterSpacing = 0.15.sp, baselineShift = BaselineShift.Subscript ),
Dopo aver definito Typography
, passalo a MaterialTheme
M3:
MaterialTheme( typography = replyTypography, ) { // M3 app Content }
Utilizzare gli stili di testo
Puoi recuperare la tipografia fornita al composable MaterialTheme
M3 utilizzando MaterialTheme.typography
:
Text( text = "Hello M3 theming", style = MaterialTheme.typography.titleLarge ) Text( text = "you are learning typography", style = MaterialTheme.typography.bodyMedium )
Per saperne di più sulle linee guida di Material per l'applicazione della tipografia, consulta la pagina dedicata.
Forme
Le superfici di Material possono essere visualizzate in forme diverse. Le forme attirano l'attenzione, identificano i componenti, comunicano lo stato ed esprimono il brand.
La scala delle forme definisce lo stile degli angoli del contenitore, offrendo una gamma di rotondità da quadrata a completamente circolare.
Definire le forme
Compose fornisce alla classe M3 Shapes
parametri espansi per supportare nuove forme M3. La scala delle forme M3 è più simile alla scala dei tipi,
consentendo una gamma espressiva di forme nell'interfaccia utente.
Esistono forme di diverse dimensioni:
- Extra small
- Piccolo
- Media
- Grandi
- Extra large
Per impostazione predefinita, ogni forma ha un valore predefinito, ma puoi sostituirli:
val replyShapes = Shapes( extraSmall = RoundedCornerShape(4.dp), small = RoundedCornerShape(8.dp), medium = RoundedCornerShape(12.dp), large = RoundedCornerShape(16.dp), extraLarge = RoundedCornerShape(24.dp) )
Una volta definito il Shapes
, puoi trasmetterlo all'MaterialTheme
M3:
MaterialTheme( shapes = replyShapes, ) { // M3 app Content }
Utilizzare le forme
Puoi personalizzare la scala delle forme per tutti i componenti in MaterialTheme
o
per singolo componente.
Applica una forma di medie e grandi dimensioni con valori predefiniti:
Card(shape = MaterialTheme.shapes.medium) { /* card content */ } FloatingActionButton( shape = MaterialTheme.shapes.large, onClick = { } ) { /* fab content */ }
Esistono altre due forme, RectangleShape
e CircleShape
, che fanno parte di Compose. La forma rettangolare non ha raggio del bordo e la forma circolare mostra bordi completamente cerchiati:
Card(shape = RectangleShape) { /* card content */ } Card(shape = CircleShape) { /* card content */ }
Gli esempi riportati di seguito mostrano alcuni dei componenti a cui sono stati applicati valori di forma predefiniti:
Puoi scoprire di più sulle linee guida di Material sull'applicazione della forma.
Corsivo
L'enfasi in M3 viene fornita utilizzando variazioni di colore e le relative combinazioni in tinta. In M3, esistono due modi per mettere in evidenza l'interfaccia utente:
- Utilizzo di colori di superficie, variante di superficie e sfondo insieme a colori su superficie e su variante di superficie del sistema di colori M3 espanso. Ad esempio, la proprietà surface può essere utilizzata con la proprietà on-surface-variant e la proprietà surface-variant può essere utilizzata con la proprietà on-surface per fornire diversi livelli di enfasi.
- Utilizzare spessori di carattere diversi per il testo. Sopra, hai visto che puoi assegnare pesi personalizzati alla nostra scala di caratteri per dare enfasi diversa.
bodyLarge = TextStyle( fontWeight = FontWeight.Bold ), bodyMedium = TextStyle( fontWeight = FontWeight.Normal )
Altitudine
Il materiale 3 rappresenta l'elevazione principalmente utilizzando overlay di colori tonali. Si tratta di un nuovo modo per differenziare i contenitori e le superfici tra loro: l'aumento dell'elevazione tonale utilizza un tono più prominente, oltre alle ombre.
Anche le sovrapposizioni di elevazione nei temi scuri sono state sostituite da sovrapposizioni di colori tonali in Material 3. Il colore dell'overlay proviene dallo spazio del colore principale.
La superficie M3, il composable di supporto alla base della maggior parte dei componenti M3, include il supporto sia per l'elevazione tonale che per quella delle ombre:
Surface( modifier = Modifier, tonalElevation = /*... shadowElevation = /*... ) { Column(content = content) }
Componenti di materiale
Material Design include un'ampia gamma di componenti Material (ad esempio pulsanti, chip, schede, barra di navigazione) che già seguono Material Theme e ti aiutano a creare bellissime app Material Design. Puoi iniziare a utilizzare subito i componenti con proprietà predefinite.
Button(onClick = { /*..*/ }) { Text(text = "My Button") }
M3 fornisce molte versioni degli stessi componenti da utilizzare in ruoli diversi in base all'enfasi e all'attenzione.
- Un pulsante di azione mobile esteso per l'azione di maggiore enfasi:
ExtendedFloatingActionButton( onClick = { /*..*/ }, modifier = Modifier ) { Icon( imageVector = Icons.Default.Edit, contentDescription = stringResource(id = R.string.edit), ) Text( text = stringResource(id = R.string.add_entry), ) }
- Un pulsante con riempimento per un'azione di grande enfasi:
Button(onClick = { /*..*/ }) { Text(text = stringResource(id = R.string.view_entry)) }
- Un pulsante di testo per un'azione di scarsa enfasi:
TextButton(onClick = { /*..*/ }) { Text(text = stringResource(id = R.string.replated_articles)) }
Scopri di più sui pulsanti e su altri componenti di Material. Material 3 offre una vasta gamma di suite di componenti, come pulsanti, barre di app e componenti di navigazione, progettati specificamente per diversi casi d'uso e dimensioni dello schermo.
Componenti di navigazione
Material fornisce anche diversi componenti di navigazione che ti aiutano a implementare la navigazione, a seconda delle dimensioni e degli stati dello schermo.
NavigationBar
viene utilizzato per i dispositivi compatti quando vuoi scegliere come target massimo 5 destinazioni:
NavigationBar(modifier = Modifier.fillMaxWidth()) { Destinations.entries.forEach { replyDestination -> NavigationBarItem( selected = selectedDestination == replyDestination, onClick = { }, icon = { } ) } }
NavigationRail
viene utilizzato per tablet o smartphone di piccole e medie dimensioni in modalità Riquadro. Offre ergonomia agli utenti e migliora l'esperienza utente
per questi dispositivi.
NavigationRail( modifier = Modifier.fillMaxHeight(), ) { Destinations.entries.forEach { replyDestination -> NavigationRailItem( selected = selectedDestination == replyDestination, onClick = { }, icon = { } ) } }
Rispondi utilizzando entrambi i temi predefiniti per offrire un'esperienza utente coinvolgente per tutte le dimensioni dei dispositivi.
NavigationDrawer
viene utilizzato per tablet di medie e grandi dimensioni in cui hai abbastanza spazio per mostrare i dettagli. Puoi utilizzare sia PermanentNavigationDrawer
che
ModalNavigationDrawer
insieme a NavigationRail
.
PermanentNavigationDrawer(modifier = Modifier.fillMaxHeight(), drawerContent = { Destinations.entries.forEach { replyDestination -> NavigationRailItem( selected = selectedDestination == replyDestination, onClick = { }, icon = { }, label = { } ) } }) { }
Le opzioni di navigazione migliorano l'esperienza utente, l'ergonomia e la raggiungibilità. Puoi scoprire di più sui componenti di navigazione Material nel codelab Componi adattativo.
Personalizzare il tema di un componente
M3 incoraggia la personalizzazione e la flessibilità. A tutti i componenti vengono applicati colori predefinite, ma sono disponibili API flessibili per personalizzarli, se necessario.
La maggior parte dei componenti, come schede e pulsanti, fornisce un oggetto predefinito che espone interfacce di colore e elevazione che possono essere modificate per personalizzare il componente:
val customCardColors = CardDefaults.cardColors( contentColor = MaterialTheme.colorScheme.primary, containerColor = MaterialTheme.colorScheme.primaryContainer, disabledContentColor = MaterialTheme.colorScheme.surface, disabledContainerColor = MaterialTheme.colorScheme.onSurface, ) val customCardElevation = CardDefaults.cardElevation( defaultElevation = 8.dp, pressedElevation = 2.dp, focusedElevation = 4.dp ) Card( colors = customCardColors, elevation = customCardElevation ) { // m3 card content }
Scopri di più sulla personalizzazione di Material 3.
UI di sistema
Alcuni aspetti di Material You provengono dal nuovo stile visivo e dall'interfaccia utente di sistema su Android 12 e versioni successive. Due aree chiave in cui sono presenti modifiche sono l'effetto ripple e l'overscroll. Non sono necessarie ulteriori operazioni per implementare queste modifiche.
Onde
Ora l'effetto Ripple utilizza una scintilla sottile per illuminare le superfici quando viene premuto. Onda Materiale di Compose utilizza una piattaforma RippleDrawable sotto il cofano su Android, quindi l'effetto scintilla è disponibile su Android 12 e versioni successive per tutti i componenti Materiale.
Scorrimento eccessivo
L'overscroll ora utilizza un effetto di allungamento sul bordo dei contenitori con scorrimento.
Lo scorrimento elastico è attivo per impostazione predefinita nei composabili contenitore con scorrimento, ad esempio LazyColumn
, LazyRow
e LazyVerticalGrid
, in Compose Foundation 1.1.0 e versioni successive, indipendentemente dal livello API.
Accessibilità
Gli standard di accessibilità integrati nei componenti Material sono progettati per fornire una base per la progettazione di prodotti inclusivi. Comprendere l'accessibilità del tuo prodotto può migliorare l'usabilità per tutti gli utenti, inclusi quelli con disabilità visive, cecità, disturbi uditivi, disturbi cognitivi, disturbi motori o disabilità situazionali (ad esempio un braccio rotto).
Accessibilità dei colori
Il colore dinamico è progettato per soddisfare gli standard di accessibilità per il contrasto dei colori. Il sistema di tavolozze di tonalità è fondamentale per rendere accessibile qualsiasi combinazione di colori per impostazione predefinita.
Il sistema di colori di Material fornisce valori e misurazioni di tonalità standard che possono essere utilizzati per soddisfare i rapporti di contrasto accessibili.
Tutti i componenti Material e i temi dinamici utilizzano già i ruoli di colore sopra indicati da un insieme di tavolozze di tonalità, selezionate per soddisfare i requisiti di accessibilità. Tuttavia, se personalizzi i componenti, assicurati di utilizzare i ruoli di colore appropriati ed evita la mancata corrispondenza.
Utilizza on-primary sopra primary e on-primary-container sopra primary-container, e lo stesso per altri colori di accento e neutri per fornire all'utente un contrasto accessibile.
L'utilizzo di un contenitore terziario sopra quello principale offre all'utente un pulsante con scarso contrasto:
// ✅ Button with sufficient contrast ratio Button( onClick = { }, colors = ButtonDefaults.buttonColors( containerColor = MaterialTheme.colorScheme.primary, contentColor = MaterialTheme.colorScheme.onPrimary ) ) { } // ❌ Button with poor contrast ratio Button( onClick = { }, colors = ButtonDefaults.buttonColors( containerColor = MaterialTheme.colorScheme.tertiaryContainer, contentColor = MaterialTheme.colorScheme.primaryContainer ) ) { }
Accessibilità della tipografia
La scala di tipo M3 aggiorna la rampa e i valori di tipo statico per offrire un framework semplificato, ma dinamico, delle categorie di dimensioni che si adattano a tutti i dispositivi.
Ad esempio, in M3 a Display Small possono essere assegnati valori diversi a seconda del contesto del dispositivo, ad esempio uno smartphone o un tablet.
Schermi grandi
Material fornisce indicazioni su layout adattabili e dispositivi pieghevoli per rendere le tue app accessibili e migliorare l'ergonomia degli utenti che tengono dispositivi di grandi dimensioni.
Material fornisce diversi tipi di navigazione per aiutarti a offrire un'esperienza utente migliore per i dispositivi di grandi dimensioni.
Puoi scoprire di più sulle norme sulla qualità delle app per schermi di grandi dimensioni di Android e consultare il nostro esempio di risposta per un design adattabile e accessibile.
Scopri di più
Per scoprire di più sui temi Material in Compose, consulta le seguenti risorse:
App di esempio
Documenti
Riferimento API e codice sorgente
Video
Consigliati per te
- Nota: il testo del link viene visualizzato quando JavaScript è disattivato
- Eseguire la migrazione da Material 2 a Material 3 in Compose
- Material Design 2 in Scrivi
- Sistemi di progettazione personalizzati in Compose