Google Home ekosistemindeki cihazlar Cloud-to-cloud, Matter veya her ikisi kullanılarak uygulanabilir. Bazı cihaz türleri diğerlerinden daha karmaşıktır ve ekosistemdeki diğer cihazlarla sorunsuz arayüz oluşturmaya izin verecek şekilde Home API'leri kullanırken geliştirme açısından zorluk yaratır.
Bu cihaz türlerinden bazılarının uygulanmasındaki zorluklardan biri, cihazların farklı özellik kombinasyonlarından oluşabilmesidir. Bazı kombinasyonlar diğerleri kadar iyi çalışmaz. Ayrıca, Cloud-to-cloud veri modeli Matter veri modeliyle eşlenir ancak her zaman net ve bire bir şekilde eşlenmez. Veri modelleri ve bunların eşlemeleri hakkında daha ayrıntılı bilgi için Android'deki veri modeli başlıklı makaleyi inceleyin.
Bu sayfada, belirli cihazların veri modellerinin birbirleriyle nasıl eşlendiği hakkında daha fazla bilgi verilmekte ve bu cihaz türlerini uygulamak için hangi özelliklerin kullanılacağı konusunda bazı bilgiler sunulmaktadır.
Fırın
Fırın
(OvenDevice)
cihaz türü ve bileşen özellikleri, diğer cihaz türlerine kıyasla daha karmaşık bir şekilde uygulanır. Oven'ı Matter içinde uygulamanın birden fazla yolu vardır ancak tüm yaklaşımlar diğer cihazlarla veya Google Home ekosistemiyle sorunsuz birlikte çalışmaya yol açmaz.
Özellik eşleme
Matter Fırın cihazını Fırın Modu ve Açma/Kapama kümelerini kullanarak uygulamak yerine Fırın Boşluğu Çalışma Durumu kümesini kullanmanızı öneririz. Bu küme, Home API'lerinde OvenCavityOperationalState özelliğiyle temsil edilir ve Cloud-to-cloud
RunCycle özelliğiyle eşlenir. "Ön ısıtma", "ön ısıtılmış" ve "soğutma" gibi aşamaları tanımlar.
| Home API'leri | Cloud-to-cloud |
|---|---|
OvenCavityOperationalState
|
RunCycle
|
Cloud-to-cloud Fırın veri modeliyle ilgili sınırlamalar vardır. Cloud-to-cloud Fırın veri modeli yalnızca tek bir bölmeye ve tek bir RunCycle'ye izin verir. Buna karşılık, Matter, çok bölmeli bir fırını her bölme için bir Fırın Boşluğu Çalışma Durumu kümesi içeren bir cihaz uç noktası olarak modeller.
Bazı fırın cihazlarında, aşama listesinin çalışma zamanında değişmesi uygun olabilir. Örneğin, ön ısıtmayı destekleyen fırınlar, ön ısıtma aşamasında, ısıtma veya soğutma aşamalarına göre aşama listesinde farklı girişlere sahip olabilir.
Önerilen uygulama
Önceki bölümde belirtildiği gibi, Matter fırın uygulaması, Home API'lerinde OvenCavityOperationalState özelliği olarak modellenen Fırın Boşluğu Çalışma Durumu kümesini uygulamalıdır.
En iyi sonuçları elde etmek için Cloud-to-cloudfırın cihazınızın
RunCycle özelliğini uyguladığından ve currentRunCycle özelliğini ayarlayarak mevcut durumu yayınladığından emin olun. Bu özellik, Home API'leri tarafından OvenCavityOperationalState.phaseList ve OvenCavityOperationalState.currentPhase özellikleri aracılığıyla gözlemlenebilir.
Fırın cihazı, priority, status ve currentCycleRemainingTime özelliklerini güncelleyerek bir çalışma döngüsü cihaz bildirimi de yayınlamalıdır. Aşağıdaki örnek, RunCycle etkinliğinin gönderilmesiyle sonuçlanır ve fırının "ön ısıtma" döngüsünden "ön ısıtılmış" döngüsüne geçtiğini belirtmek için kullanılabilir:OperationalState.OperationCompletion
{
"currentRunCycle": [
{
"currentCycle": "pre-heating",
"nextCycle": "pre-heated",
"lang": "en"
}
],
"currentTotalRemainingTime": 1200,
"currentCycleRemainingTime": 300
}
Otomasyonda fırın kullanma
Fırın boşluğu operasyonel durumu kümesi kullanılarak uygulanan bir fırın için otomasyon oluştururken fırının hangi döngüde olduğunu öğrenmek için currentPhase özelliğine bakın:
sequential {
val starterNode =
starter<_>(oven, OvenDevice, OvenCavityOperationalState /* Or OperationalState */)
condition {
expression = starterNode.phaseList[operationalState.currentPhase.toUInt()] equals "pre-heated"
}
action(speaker, SpeakerDevice) {
command(AssistantBroadcast.broadcast("Oven Cycle Complete"))
}
// Additional actions here as needed
}
Tam bir örnek için Fırın seçilen sıcaklığa ulaştığında ışıkları yakıp duyur başlıklı makaleyi inceleyin.