Le API Home per Android presentano tutti i dispositivi dell'ecosistema Google Home in un modello di dati unificato. Questo modello di dati copre tutti i tipi di dispositivi (di Google Nest o di produttori di terze parti), indipendentemente dalla tecnologia di smart home sottostante (come Matter o Cloud-to-cloud), e fornisce una superficie API comune per creare esperienze utente per sviluppatori di smart home e app mobile.
Tipi di dispositivo
I tipi di dispositivi presentati nelle API Home sono un'unificazione dei modelli di dati Matter e Cloud-to-cloud. Alcuni sono derivati direttamente da Matter, altri sono un'estensione dei tipi di dispositivi Matter e altri ancora sono derivati da Cloud-to-cloud.
I tipi di dispositivo contengono caratteristiche utilizzate per controllare e gestire i dispositivi. Come i tipi di dispositivo, i tratti derivano dai cluster Matter e dai tratti Cloud-to-cloud e vengono presentati in un formato comune simile a quello dei cluster Matter. Nelle API Home, le caratteristiche derivate da Matter sono chiamate tratti, non cluster.
Pertanto, i tipi e le caratteristiche dei dispositivi nelle API Home sono pensati per essere Matter-first. Un tipo di dispositivo o una caratteristica Matter ha la precedenza su un analogo Cloud-to-cloud.
Per un elenco dei tipi di dispositivi e delle relative caratteristiche, consulta Tipi di dispositivi supportati su Android.
Tratti
Le versioni Kotlin dei tratti vengono generate per l'utilizzo nelle API per la casa e contengono funzionalità aggiuntive specifiche per le API per la casa (non presenti in Matter o Cloud-to-cloud). Ad esempio, ogni tratto ha metodi per verificare se un tratto supporta un attributo o un comando specifico. Ciò è utile per determinare se la lettura dello stato o determinate azioni possono essere eseguite sul dispositivo di un utente, poiché non tutti i dispositivi di un tipo hanno le stesse funzionalità.
Ogni tratto è contenuto nel proprio namespace e deve essere importato singolarmente per essere utilizzato.
Ad esempio, per utilizzare il tratto Matter On/Off e il tipo di dispositivo Unità plug-in On/Off, importa i seguenti pacchetti nella tua applicazione:
import com.google.home.matter.standard.OnOff
import com.google.home.matter.standard.OnOffPluginUnitDevice
Per un tipo di dispositivo Garage (dalla smart home di Google), includi un mix di Matter e caratteristiche Google:
import com.google.home.google.LockUnlock
import com.google.home.matter.standard.DoorLock
import com.google.home.matter.standard.GoogleGarageDevice
Android Studio ha la funzionalità di completamento automatico e spesso
gestisce i nomi completi dei pacchetti quando aggiungi righe import ai file di origine
nel tuo progetto. Tuttavia, i nomi dei pacchetti non sono coerenti in tutti i tipi e le caratteristiche dei dispositivi. Consulta il riferimento per verificare il nome del pacchetto corretto per ogni
DeviceType o
Trait.
La maggior parte delle caratteristiche è supportata per l'uso con le automazioni, mentre alcune caratteristiche sono disponibili solo per le automazioni. Per maggiori dettagli, consulta Supporto dei tratti dell'API Automation su Android.
Composizione del tipo di dispositivo
Le API Home supportano la maggior parte dei cluster di applicazioni Matter come tratti nel modello di dati. Le caratteristiche che non corrispondono al controllo o agli stati del dispositivo e non offrono alcuna utilità per gli utenti finali, come Binding e Gruppi, non vengono esposte tramite le API Home.
Le caratteristiche derivate dalle caratteristiche di Cloud-to-cloud per la smart home in genere hanno
lo stesso nome tra Cloud-to-cloud e le API Home, come nell'esempio di OpenClose. Altri sono rappresentati come estensioni
delle caratteristiche Matter, create utilizzando
estensioni specifiche del produttore.Matter Questi tratti colmano il divario per un tratto smart home in cui la funzionalità è suddivisa tra l'SDK Matter e l'ecosistema Google Home. Un esempio specifico sono i tipi di dispositivi Google* che provengono da Cloud-to-cloud, ma non hanno ancora analoghi Matter.
I tipi di dispositivo sono composti da tratti di una o entrambe le origini, Matter o Cloud-to-cloud.
Ad esempio, il tipo di dispositivo ventilatore è composto da entrambi e presenta tre caratteristiche:
- Il tratto
IdentifyMatter fornisce tutte le funzionalità di MatterIdentify. - La caratteristica
FanControlMatter fornisce tutte le funzionalità della caratteristica MatterFanControl - La caratteristica
ExtendedFanControlGoogle fornisce tutte le funzionalità della caratteristica Google smart homeFanSpeednon coperte dalla caratteristicaFanControlMatter
Questo tipo di composizione dei tratti fornisce un modello flessibile per la funzionalità completa del tipo di dispositivo, astraendo i modelli di dati smart home sottostanti.