Smart-Home-APIs für Android – Übersicht

Die Google Home-APIs für Android bieten eine einheitliche API-Oberfläche, mit der Entwickler mit dem Status von Entitäten im Zuhause eines Nutzers interagieren können. Diese Einheiten können Geräte und Nicht-Geräteinformationen beschreiben, die mit der Struktur und den Räumen eines Nutzers verknüpft sind.

Die Home-APIs definieren die folgenden Entitäten, mit denen ein Nutzer interagieren kann:

  • Gebäude stellen ein Zuhause mit Räumen und Geräten dar.
  • Räume sind Teil eines Zuhauses und enthalten Geräte.
  • Geräte implementieren Merkmale mit Attributen, entsprechen Typen, geben Ereignisse aus und reagieren auf Befehle.
  • Automatisierungen sind Teil einer Struktur und verwenden Metadaten und Geräte des Zuhauses, um Aufgaben im Zuhause zu automatisieren.

Abbildung 1 zeigt diese Architektur:

Diagramm der Architektur der Home-APIs für eine Android-App
Abbildung 1: Architektur der Home-APIs für eine Android-App

Gerätetypen der Home API können durch Matter, einen offenen Standard für das Smart Home, oder durch ein Cloud-to-cloud-Gerät im Google Home-Ökosystem unterstützt werden. Einige Gerätetypen können Funktionen von beiden enthalten. Weitere Informationen finden Sie unter Unterstützte Gerätetypen auf Android.

In Matter werden Gerätefunktionen nach Clustern gruppiert, die in den Home-APIs als Matter-Standardattribute dargestellt werden. Die Home-APIs unterstützen den Standardsatz von Matter-Clustern, wie in der aktuellen Matter-Spezifikation definiert.

Im Google Home-Ökosystem wird die Gerätefunktionalität nach Smart-Home-Traits gruppiert, die in den Home-APIs als Google Smart-Home-Traits dargestellt werden. Die Home-APIs unterstützen die Smart-Home-Merkmale, die im Cloud-to-cloud-Programm definiert sind.

Andere Attribute wie herstellerspezifische Cluster und Plattformattribute sind ebenfalls verfügbar. Weitere Informationen zum Datenmodell unter Android

Sprache

Die Home APIs für Android sind in Kotlin geschrieben und bieten eine idiomatische Kotlin-Schnittstelle, die Flow zur Verwaltung von Status und Abos verwendet. Das bietet eine Reihe von Vorteilen gegenüber einer Standard-Abo-API.

Falls Sie es noch nicht getan haben, empfehlen wir Ihnen, sich mit der Kotlin-Dokumentation zu Coroutinen, Flow und Jetpack Compose vertraut zu machen:

Entitäts-IDs

Jede Entität in den Home APIs hat eine ID, die ihre primäre Kennung darstellt. Diese ID ist eine eindeutige und stabile Kennung, die sich während der gesamten Lebensdauer der Entität nicht ändert. Diese ID kann zum Zwischenspeichern von Objekten oder zum Prüfen auf Gleichheit verwendet werden, da sich die Metadaten einer Entität ändern können.

In der HasId-Schnittstelle erfahren Sie, welche Entitäten eine ID haben.

Terminologiezuordnung

Entitäten in den Home APIs werden den Konzepten Matter und Cloud-to-cloud so zugeordnet:

Gebäude-APIs Matter Cloud-to-cloud
Attribut Cluster Attribut
Attribut Attribut Attribut, Status
Befehl Befehl Befehl
Ereignis Ereignis Folgeantwort, Benachrichtigung