Bir otomasyon, çok parçalı cihazlara, çok parçalı cihaz kullanmayan bir otomasyona benzer şekilde referans verebilir.
Öncelikle, bileşen parçalarını normalde yaptığınız gibi edinin. Çok parçalı cihazlarla nasıl çalışacağınızı öğrenmek için Çok parçalı cihazlar başlıklı makaleyi inceleyin.
Ardından, otomasyonunuzda kullanmak istediğiniz her bölüm için bir AutomationPartPath oluşturun. Bu, otomasyon başlatıcılarında, koşullarında ve işlemlerinde bölüme referans vermenizi sağlar.
// Obtain a reference to the device:
let multipartDevices = try await self.home.devices(enableMultipartDevices: true).list()
let light = multipartDevices.first(where: {
$0.parts.contains(OnOffLightDeviceType.self) && $0.structureID == structure.id
})
let lightDeviceType = await light.parts.get(OnOffLightDeviceType.self)
let lightPartPath = light.automationPart(lightDeviceType)
Otomasyon işlemlerinin genellikle parametre olarak bir cihaz ve cihaz türü aldığını da unutmayın. Ancak, bir bileşen parçası cihaza referans veren bir otomasyon işlemi (yine AutomationPartPath kullanılarak) yalnızca AutomationPartPath gerektirir. Çünkü AutomationPartPath, bileşen cihaz referansına ek olarak cihaz türüne referans içerir.
Örneğin, Automation API'de Refrigerator cihaz türü, çok parçalı bir cihaz olarak değerlendirilebilir. Kök RefrigeratorDevice ve dondurucular veya TemperatureControlledCabinetDevice türünde standart dolaplar gibi birden fazla alt parça dolabı içerebilir.
Buzdolabı otomasyonları oluşturmak için öncelikle iki standart Matter özelliğiyle etkileşimde bulunursunuz:
RefrigeratorAlarm: Kapı durumu alarmlarınıstatealanınındoorOpenözelliği aracılığıyla gösterir.RefrigeratorAndTemperatureControlledCabinetMode: Okuma ve komut modlarına izin verir. Örneğin,changeToModegibi komutları çalıştırarakLowEnergy,RapidCoolveyaLowNoisegibi modlara geçebilirsiniz.
Bu örnek otomasyon, buzdolabı kapısı açıldığında tetiklenir. Kapı iki dakikadan uzun süre açık kalırsa otomasyon, akıllı hoparlörlerde sesli bildirim yayınlar, mutfak ışıklarını yakıp söndürür ve anlık bildirim gönderir. Bu otomasyonun yalnızca cihazın buzdolabı bölmesini etkilediğini ve dondurucu bölmesini (varsa) dikkate almadığını unutmayın:
import GoogleHomeSDK
import GoogleHomeTypes
typealias RefrigeratorAlarmTrait = Matter.RefrigeratorAlarmTrait
typealias OnOffTrait = Matter.OnOffTrait
// Fetch devices using the multipart device model.
let multipartDevices = try await self.home.devices(enableMultipartDevices: true).list()
// Obtain a reference to the refrigerator device.
guard let refrigeratorDevice = multipartDevices.first {
$0.types.contains(TemperatureControlledCabinetDeviceType.self) &&
$0.traits.contains(Matter.RefrigeratorAndTemperatureControlledCabinetModeTrait.self) &&
$0.traits.contains(Matter.RefrigeratorAlarmTrait.self)
}
let refrigeratorDeviceType = await refrigeratorDevice.parts.get(RefrigeratorDeviceType.self).first
// Get all temperature-controlled cabinet parts of the refrigerator
let cabinets = refrigeratorDeviceType.parts(type: TemperatureControlledCabinetDeviceType.self)
// Find the cabinet part with the 'refrigerator' semantic tag
let refrigeratorCabinet = cabinets.first {
$0.metadata.tags.contains(SemanticTag.Refrigerator.refrigerator)
}
var cabinetPartPath = refrigeratorDevice.automationPart(refrigeratorCabinet)
let structure = home.structures().list().first
let speaker = multipartDevices.first(where: {
$0.types.contains(SpeakerDeviceType.self) && $0.structureID == structure.id
})
let refrigeratorDoorAlert = automation(
name: "Refrigerator Door Open Alert",
description: "Warn when the refrigerator door has been open for over 2 min."
) {
// 1. Starter: Monitor the refrigerator door alarm trait
let alarmStarter = starter(
cabinetPartPath,
RefrigeratorAlarmTrait.self
)
alarmStarter
// 2. Condition: Ensure the 'doorOpen' alarm remains active for 120 seconds
condition(for: .seconds(120)) {
alarmStarter.state.doorOpen.equals(true)
}
// 3. Actions: Execute parallel reactions
parallel {
// Broadcast warning to household speakers
action(speaker, SpeakerDeviceType.self) {
Google.AssistantBroadcastTrait.broadcast(msg: "The refrigerator door has been left open!")
}
// Push a notification alerts to home members' mobile devices
action(structure) {
Google.NotificationTrait.sendNotifications(
title: "Fridge Alert",
body: "The refrigerator door has been open for over 2 min.",
optInMemberEmailsArray: ["222larabrown@gmail.com"]
)
}
}
}
Aşağıdaki örnekte, evde kimsenin olmadığı algılandığında buzdolabı düşük enerji moduna geçiriliyor.
import GoogleHomeSDK
import GoogleHomeTypes
typealias AreaPresenceStateTrait = Google.AreaPresenceStateTrait
typealias RefrigeratorAndTemperatureControlledCabinetModeTrait = Matter.RefrigeratorAndTemperatureControlledCabinetModeTrait
let structure = home.structures().list().first()
// Fetch devices using the multipart device model.
let devices = try await self.home.devices(enableMultipartDevices: true).list()
// Obtain a reference to the refrigerator device.
guard let refrigeratorDevice = multipartDevices.first {
$0.types.contains(TemperatureControlledCabinetDeviceType.self) &&
$0.traits.contains(Matter.RefrigeratorAndTemperatureControlledCabinetModeTrait.self) &&
$0.traits.contains(Matter.RefrigeratorAlarmTrait.self)
}
let refrigeratorDeviceType = await refrigeratorDevice.parts.get(RefrigeratorDeviceType.self)
// Get all temperature-controlled cabinet parts of the refrigerator
let cabinets = refrigeratorDeviceType.parts(type: TemperatureControlledCabinetDeviceType.self)
// Find the cabinet part with the 'refrigerator' semantic tag
let refrigeratorCabinet = cabinets.first {
$0.metadata.tags.contains(SemanticTag.Refrigerator.refrigerator)
}
let cabinetPartPath = refrigeratorDevice.automationPart(refrigeratorCabinet)
let refrigeratorEcoMode = automation(
name: "Refrigerator Eco Mode",
description: "Automatically changes refrigerator to low energy mode when house is vacant."
) {
// 1. Starter: Monitor household presence changes
let presenceStarter = starter(structure, AreaPresenceStateTrait.self)
presenceStarter
// 2. Condition: Verify presence state transitions to vacant
condition {
presenceStarter.presenceState.equals(.presenceStateVacant)
}
// 3. Action: Set refrigerator cabinet Mode to 'Low Energy' (commonly option index 1)
action(cabinetPartPath) {
RefrigeratorAndTemperatureControlledCabinetModeTrait.changeToMode(newMode: 1)
}
}