يمكن أن يشير التشغيل الآلي إلى الأجهزة المتعدّدة الأجزاء بطريقة مشابهة للتشغيل الآلي الذي لا يستخدم أجهزة متعدّدة الأجزاء.
أولاً، احصل على جزء أو أجزاء المكوّن كما تفعل عادةً. اطّلِع على الأجهزة المتعدّدة الأجزاء لمعرفة كيفية استخدام الأجهزة المتعدّدة الأجزاء.
بعد ذلك، لكل جزء تريد استخدامه في التشغيل الآلي، أنشئ
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 يحتوي على مرجع
لنوع الجهاز بالإضافة إلى مرجع جهاز المكوّن.
على سبيل المثال، في Automation API، يمكن التعامل مع نوع الجهاز Refrigerator كجهاز متعدّد الأجزاء. يتألف من RefrigeratorDevice أساسي يمكن أن يحتوي على خزائن فرعية متعدّدة، مثل المجمدات أو الخزائن العادية من النوع TemperatureControlledCabinetDevice.
لإنشاء إجراءات مبرمَجة للثلاجة، يمكنك التفاعل بشكل أساسي مع سمتَين عاديتَين من Matter 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)
}
}