iOS'teki veri modeli

iOS için Home API'leri, Google Home ekosistemindeki tüm cihazları birleşik 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-first olarak tasarlanmıştır. Matter cihaz türü veya özelliği, Cloud-to-cloud analoguna göre önceliklidir.

Cihaz türlerinin ve özelliklerinin listesi için iOS'te desteklenen cihaz türleri başlıklı makaleyi inceleyin.

Özellikler

Özelliklerin Swift 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 özellikten yararlanabilirsiniz.

Özellikleri ve cihaz türlerini içe aktarmak için GoogleHomeTypes modülünü uygulamanıza aktarın:

import GoogleHomeTypes

Ayrıca, kodu kısaltmak ve ad alanı tekrarını önlemek için özellik ve cihaz türü adlarında typealias kullanabilirsiniz:

import GoogleHomeTypes

typealias OpenCloseTrait = Google.OpenCloseTrait
typealias OnOffTrait = Matter.OnOffTrait
typealias FanDevice = Matter.FanDeviceType

Özelliklerin çoğu otomasyonlarla kullanılabilir. Bazı özellikler ise yalnızca otomasyonlarda kullanılabilir. Daha fazla bilgi için Android'de Automation API özelliği desteği başlıklı makaleyi inceleyin.

Cihaz türü bileşimi

Home API'leri, veri modelindeki özellikler olarak çoğu Matter uygulama kümesini destekler. Cihaz kontrolüne veya durumlarına 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 Home API'leri arasında aynı ada sahiptir. Örneğin, OpenCloseTrait. Diğerleri ise Matter üreticiye özel uzantıları kullanılarak oluşturulan Matter özelliklerinin uzantıları olarak gösterilir. 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 doldurur. Buna özel bir örnek, Cloud-to-cloud'dan gelen ancak henüz Matter benzerleri olmayan Google* cihaz türleridir.

Cihaz türleri, Matter veya Cloud-to-cloud kaynaklarından birinin ya da her ikisinin özelliklerinden oluşur.

Örneğin, FanDeviceType hem hem de özelliklerinden oluşur ve üç özelliği vardır:

  • IdentifyTrait Matter özelliği, Matter IdentifyTrait özelliğindeki tüm işlevleri sağlar.
  • FanControlTrait Matter özelliği, Matter FanControlTrait özelliğindeki tüm işlevleri sağlar.
  • ExtendedFanControlTrait Google özelliği, FanControlTrait Matter özelliği kapsamına girmeyen smart home FanSpeedTrait Google özelliğindeki tüm işlevleri 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.