Il componente Switch consente agli utenti di attivare o disattivare due stati: selezionato
e non selezionato. Utilizza un interruttore per consentire all'utente di eseguire una delle seguenti operazioni:
- Attivare o disattivare un'impostazione.
- Attivare o disattivare una funzionalità.
- Selezionare un'opzione.
Il componente è composto da due parti: il cursore e la traccia. Il cursore è la parte trascinabile dell'interruttore e la traccia è lo sfondo. L'utente può trascinare il cursore a sinistra o a destra per modificare lo stato dell'interruttore. Può anche toccare l'interruttore per selezionarlo e deselezionarlo.
Compatibilità delle versioni
Questa implementazione richiede che il minSDK del progetto sia impostato sul livello API 21 o superiore.
Dipendenze
Implementare un interruttore
L'esempio seguente è un'implementazione minima del composable Switch:
Risultati
Creare un cursore personalizzato
Puoi passare qualsiasi composable per il parametro thumbContent per creare un cursore personalizzato. Di seguito è riportato un esempio di interruttore che utilizza un'icona personalizzata per il cursore:
Risultati
L'aspetto non selezionato è lo stesso dell'esempio nella sezione precedente. Tuttavia, quando è selezionata, questa implementazione appare come segue:
Utilizzare colori personalizzati
Utilizza il parametro colors per modificare il colore del cursore e della traccia di un interruttore, tenendo conto del fatto che l'interruttore sia selezionato o meno.
Risultati
Punti chiave
Parametri base:
checked: lo stato iniziale dell'interruttore.onCheckedChange: un callback chiamato quando lo stato dell'interruttore cambia.enabled: indica se l'interruttore è attivo o disattivo.colors: i colori utilizzati per l'interruttore.
Parametri avanzati
thumbContent: utilizzalo per personalizzare l'aspetto del cursore quando è selezionato.colors: utilizzalo per personalizzare il colore della traccia e del cursore.
Raccolte che contengono questa guida
Questa guida fa parte di queste raccolte di guide rapide curate che riguardano obiettivi di sviluppo Android più ampi: