In Android 8.0, il menu Impostazioni include diversi componenti e widget che coprono gli utilizzi più comuni. Consigliamo ai produttori e agli sviluppatori di dispositivi di utilizzare i componenti comuni durante l'estensione dell'app Impostazioni, in modo che le nuove interfacce utente rimangano coerenti con l'UI Impostazioni esistente.
Ecco un riepilogo dei miglioramenti:
- Modifica del comportamento dello divisore nel framework di preferenze della libreria di supporto. Ora è tracciato uno spartito tra le categorie.
- Il tema ActionBar è stato modificato. L'ActionBar ora utilizza un tema a colori chiari con un testo dai colori intensi.
- Nuovo layout di preferenza. Lo spazio per le icone rimane anche quando una preferenza non ha un'icona.
Nuovi widget:
- Un widget di intestazione per i dettagli sull'app. Mostra l'icona dell'app, l'etichetta e altre informazioni dell'app.
- Un pulsante di espansione in alcune pagine. La pagina può iniziare come compressa e nascondere gli elementi meno importanti finché l'utente non fa clic sul pulsante di espansione.
- UI del selettore di app predefinita:
- L'interfaccia utente per la scelta del browser predefinito, dell'app predefinita per smartphone e così via.
- In precedenza era una finestra di dialogo, ora è un'interfaccia utente a schermo intero basata su pulsanti di opzione.
- Una preferenza di stile "MasterSwitch". Si tratta di una preferenza con due target di clic. Il target sinistro porta a un sottoinsieme o a un intent. Il target a destra è un pulsante di attivazione/disattivazione che consente di controllare l'intera pagina.
Esempi e fonte
- Comportamento dello divisore
- Tutte le pagine delle Impostazioni sono state modificate in modo da utilizzare il nuovo comportamento del divisore.
- Il comportamento del divisore è definito come ThemeOverlay in:
packages/apps/Settings/res/values/styles_preference.xml
- Modifica del tema ActionBar
- Tutte le pagine delle Impostazioni sono state modificate per utilizzare il nuovo tema ActionBar.
- Il tema è definito in Theme.DeviceDefault.Settings
- Nuovo layout delle preferenze
- Molte pagine delle Impostazioni ora utilizzano il nuovo layout delle preferenze.
- Puoi trovare il codice in:
packages/apps/Settings/res/values/styles_preference.xml
- Widget dell'intestazione dell'app
- La maggior parte delle pagine delle informazioni sull'app nelle Impostazioni implementa già la nuova intestazione dell'app.
- Esempi e codice sono disponibili all'indirizzo:
packages/apps/Settings/src/com/android/settings/applications/AppHeaderController.java
- Pulsante Espandi
- Esempi e codice sono disponibili all'indirizzo:
packages/apps/Settings/src/com/android/settings/dashboard/ProgressiveDisclosureMixin.java
Nota:questo componente deve essere utilizzato insieme a DashboardFragment. Scopri di più su DashboardFragment in Updated Information Architecture (Architettura delle informazioni aggiornata).
- Esempi e codice sono disponibili all'indirizzo:
- Selettore di app predefinito
- Puoi trovare il codice per la classe base in:
packages/apps/Settings/src/com/android/settings/applications/defaultapps/DefaultAppPickerFragment.java
- Esistono diverse sottoclassi di DefaultAppPickerFragment, ognuna delle quali implementa un selettore per intent diversi.
- Puoi trovare il codice per la classe base in:
- Preferenza di stile MasterSwitch
- Il codice si trova in:
https://cs.android.com/android/platform/superproject/+/main:packages/apps/Settings/src/com/android/settings/wifi/WifiPrimarySwitchPreferenceController.java
- Un esempio di caso d'uso è l'interruttore principale Wi-Fi. Puoi trovare un esempio all'indirizzo:
packages/apps/Settings/src/com/android/settings/wifi/WifiMasterSwitchPreferenceController.java
- Il codice si trova in:
Implementazione
I produttori di dispositivi possono iniziare a utilizzare subito tutti i nuovi componenti. Se gli OEM decidono di implementare una nuova preferenza di stile "MasterSwitch" o un selettore di app predefinito, devono seguire gli esempi riportati in questo documento e i file di riferimento (Javadoc) scritti con ogni componente per ulteriori dettagli.
Personalizzare il menu Impostazioni
- Comportamento dello divisore. Per cambiare il modo in cui viene disegnato il divisore, aggiorna lo stile dei divisori Impostazioni e
modifica il valore dei seguenti elementi:
allowDividerAbove
allowDividerBelow
allowDividerAfterLastItem
- Colore del tema ActionBar. Le attività dovrebbero utilizzare
Theme.DeviceDefault.Settings
come tema o creare un tema personalizzato utilizzandoTheme.DeviceDefault.Settings
come elemento principale. - Widget intestazione dell'app. Utilizza i setter in AppHeaderController per personalizzare ogni campo e chiama
build()
una volta impostati tutti i campi. - Pulsante Espandi:
- Per disabilitare completamente la funzionalità, esegui l'override del costruttore per ProgressiveDisclosureMixin e imposta keepExpanded su true.
- Per personalizzare il numero di elementi da mostrare inizialmente, chiama il metodo
ProgressiveDisclosureMixin.setTileLimit()
durante il metodoonAttach(Context)
del frammento.