یک اتوماسیون ممکن است به دستگاههای چندبخشی مشابه اتوماسیونی که از دستگاههای چندبخشی استفاده نمیکند، ارجاع دهد.
ابتدا، قطعه(های) تشکیلدهنده را طبق معمول تهیه کنید. برای نحوه کار با دستگاههای چندبخشی، به دستگاههای چندبخشی مراجعه کنید.
سپس، برای هر بخشی که میخواهید در اتوماسیون خود استفاده کنید، یک AutomationPartPath ایجاد کنید که به شما امکان میدهد آن بخش را در شروعکنندهها، شرطها و اقدامات اتوماسیون ارجاع دهید.
// 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)
نکتهی دیگری که باید به آن توجه کرد این است که اکشنهای اتوماسیون معمولاً یک دستگاه و یک نوع دستگاه را به عنوان پارامتر دریافت میکنند. با این حال، یک اکشن اتوماسیون که به یک دستگاهِ قطعهی تشکیلدهندهی قطعه ارجاع میدهد - باز هم با استفاده از AutomationPartPath - فقط به AutomationPartPath نیاز دارد، زیرا AutomationPartPath از قبل علاوه بر ارجاع به دستگاهِ قطعه، شامل ارجاعی به نوع دستگاه نیز هست.
برای مثال، در API اتوماسیون، یک نوع دستگاه Refrigerator ممکن است به عنوان یک دستگاه چندبخشی در نظر گرفته شود. این دستگاه شامل یک RefrigeratorDevice ریشه است که میتواند شامل چندین کابینت زیربخشی مانند فریزر یا کابینتهای استاندارد از نوع TemperatureControlledCabinetDevice باشد.
برای ساخت اتوماسیون یخچال، شما در درجه اول با دو ویژگی استاندارد Matter تعامل دارید:
-
RefrigeratorAlarm: آلارمهای وضعیت درب را از طریق ویژگیdoorOpenدر فیلدstateنمایش میدهد. -
RefrigeratorAndTemperatureControlledCabinetMode: حالتهای خواندن و دستور دادن را امکانپذیر میکند. برای مثال، اجرای دستوراتی مانندchangeToModeبرای تغییر به حالتهایی مانندLowEnergy،RapidCoolیاLowNoise.
این مثال اتوماسیون زمانی فعال میشود که درب یخچال باز شود. اگر درب بیش از دو دقیقه باز بماند، اتوماسیون یک اعلان صوتی را روی بلندگوهای هوشمند پخش میکند، چراغهای آشپزخانه را روشن میکند و یک اعلان فوری ارسال میکند. توجه داشته باشید که این اتوماسیون فقط بر روی محفظه یخچال دستگاه تأثیر میگذارد و محفظه فریزر (در صورت وجود) را نادیده میگیرد:
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"]
)
}
}
}
مثال زیر وقتی یخچال تشخیص میدهد که کسی در خانه نیست، آن را به حالت کممصرف تغییر میدهد.
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)
}
}