Android için Home API'leri, Google Home ekosistemindeki tüm cihazları birleşik bir veri modelinde sunar. Bu veri modeli, temel akıllı ev teknolojisinden (ör. Matter veya Cloud-to-cloud) bağımsız olarak Google Nest veya üçüncü taraf üreticilerin tüm cihaz türlerini kapsar ve hem smart home hem de mobil uygulama geliştiriciler için kullanıcı deneyimleri oluşturmak üzere ortak bir API yüzeyi sağlar.
Cihaz türleri
Home API'lerinde sunulan cihaz türleri, Matter ve Cloud-to-cloud veri modellerinin birleştirilmiş halidir. Bazıları doğrudan Matter cihazlarından, bazıları Matter cihaz türlerinin uzantısı olarak, bazıları ise Cloud-to-cloud cihazlarından türetilir.
Cihaz türleri, cihazları kontrol etmek ve yönetmek için kullanılan özellikleri içerir. Özellikler, cihaz türleri gibi Matter kümelerinden ve Cloud-to-cloud özelliklerinden türetilir ve Matter kümelerine benzer ortak bir biçimde sunulur. Home API'lerinde, Matter-türetilmiş özelliklere kümeler değil, özellikler adı verilir.
Bu nedenle, Home API'lerindeki cihaz türleri ve özellikleri Matter öncelikli olarak tasarlanmıştır. Matter cihaz türü veya özellik, Cloud-to-cloud benzerine göre önceliklidir.
Cihaz türlerinin ve özelliklerinin listesi için Android'de desteklenen cihaz türleri başlıklı makaleyi inceleyin.
Özellikler
Özelliklerin Kotlin sürümleri, Home API'lerinde kullanılmak üzere oluşturulur ve Home API'lerine özgü ek özellikler içerir (Matter veya Cloud-to-cloud'de bulunmaz). Örneğin, her özelliğin, bir özelliğin belirli bir özelliği veya komutu destekleyip desteklemediğini kontrol etmeye yönelik yöntemleri vardır. Bir cihaz türündeki tüm cihazların aynı özelliklere sahip olması beklenmediğinden, durumun okunmasının veya belirli işlemlerin kullanıcının cihazında gerçekleştirilip gerçekleştirilemeyeceğini belirlemek için bu özellik kullanışlıdır.
Her özellik kendi ad alanında bulunur ve kullanılmak üzere ayrı ayrı içe aktarılmalıdır.
Örneğin, Matter On/Off özelliğini ve On/Off Plug-in Unit cihaz türünü kullanmak için aşağıdaki paketleri uygulamanıza aktarın:
import com.google.home.matter.standard.OnOff
import com.google.home.matter.standard.OnOffPluginUnitDevice
Garaj cihazı türü (Google akıllı evinden) için Matter ve Google özelliklerini birlikte kullanın:
import com.google.home.google.LockUnlock
import com.google.home.matter.standard.DoorLock
import com.google.home.matter.standard.GoogleGarageDevice
Android Studio otomatik tamamlama işlevine sahiptir ve projenizdeki kaynak dosyalarına import satırları eklerken genellikle tam paket adlarını sizin için işler. Ancak paket adları tüm cihaz türleri ve özellikleri için tutarlı değildir. Her DeviceType veya Trait için doğru paket adını doğrulamak üzere referansı inceleyin.
Çoğu özellik Otomasyonlarla birlikte kullanım için desteklenir ve bazı özellikler yalnızca Otomasyonlar için kullanılabilir. Daha fazla ayrıntı için Android'de Otomasyon API özelliği desteği konusuna bakın.
Cihaz türü bileşimi
Home API'leri, veri modelindeki özellikler olarak çoğu Matter uygulama kümesini destekler. Cihaz kontrolüne veya durumlara karşılık gelmeyen ve son kullanıcılara herhangi bir fayda sağlamayan özellikler (ör. Bağlama ve Gruplar) Home API'leri aracılığıyla kullanıma sunulmaz.
Cloud-to-cloud akıllı ev özelliklerinden türetilen özellikler genellikle Cloud-to-cloud ile Ev API'leri arasında aynı ada sahiptir; örneğin OpenClose örneğinde olduğu gibi. Diğerleri, Matter üreticisine özgü uzantılar kullanılarak oluşturulan Matter özelliklerinin uzantıları olarak temsil edilir. Bu özellikler, işlevselliğin Matter SDK'sı ile Google Home ekosistemi arasında bölündüğü smart home özelliği için boşluğu kapatır. Bunun belirli bir örneği, Cloud-to-cloud'den gelen ancak henüz Matter analogları olmayan Google* cihaz türleridir.
Cihaz türleri, Matter veya Cloud-to-cloud kaynaklarından birinden veya her ikisinden gelen özelliklerden oluşur.
Örneğin, Fan cihazı türü her ikisinden de oluşur ve üç özelliğe sahiptir:
IdentifyMatter özelliği, MatterIdentifyözelliğindeki tüm işlevleri sağlar.FanControlMatter özelliği, MatterFanControlözelliğinin tüm işlevlerini sağlarExtendedFanControlGoogle özelliği,FanControlMatter özelliğinin kapsamadığı Google smart homeFanSpeedözelliğinin tüm işlevlerini sağlar
Bu tür özellik bileşimi, temel smart home veri modellerini soyutlayarak eksiksiz cihaz türü işlevselliği için esnek bir model sağlar.