אפשר להפנות לאוטומציה במכשירים מרובי חלקים באופן דומה לאוטומציה שלא משתמשת במכשירים מרובי חלקים.
קודם כל, משיגים את החלקים של הרכיב כרגיל. במאמר מכשירים מרובי חלקים מוסבר איך עובדים עם מכשירים מרובי חלקים.
לאחר מכן, לכל חלק שרוצים להשתמש בו באוטומציה, יוצרים AutomationPartPath, שמאפשר להתייחס לחלק בטריגרים, בתנאים ובפעולות של אוטומציה.
// Obtain a reference to the device:
val multipartDevices = structure.devices(enableMultipartDevices = true).first().toList()
val lights = multipartDevices.filter { it.has(OnOffLightDevice) && it.has(OnOff) }
val light = lights.first()
// get the AutomationPartPath for the device
val lightPartPath = light.automationPart(light.part(OnOffLightDevice).first())
חשוב לדעת גם שבדרך כלל פעולות אוטומטיות מקבלות פרמטרים של מכשיר וסוג מכשיר. עם זאת, פעולת אוטומציה שמפנה למכשיר שהוא חלק מרכיב – שוב, באמצעות AutomationPartPath – צריכה רק את AutomationPartPath, כי AutomationPartPath כבר מכיל הפניה לסוג המכשיר בנוסף להפניה למכשיר הרכיב.
לדוגמה, ב-Automation API, יכול להיות שRefrigeratorסוג מכשיר מסוים יטופל כמכשיר מרובה חלקים. הוא מורכב מ-root RefrigeratorDevice
שיכול להכיל כמה תתי-חלקים, כמו מקפיאים או ארונות רגילים מסוג TemperatureControlledCabinetDevice.
כדי ליצור אוטומציות למקרר, אתם בעיקר משתמשים בשני מאפיינים סטנדרטיים:Matter
-
RefrigeratorAlarm: חשיפת אזעקות על מצב הדלת דרך המאפייןdoorOpenשל השדהstate. -
RefrigeratorAndTemperatureControlledCabinetMode: מאפשר מצבי קריאה ופקודה. לדוגמה, הרצת פקודות כמוchangeToModeכדי לעבור למצבים כמוLowEnergy,RapidCoolאוLowNoise.
הדוגמה הזו של פעולה אוטומטית מופעלת כשפותחים את דלת המקרר. אם הדלת נשארת פתוחה יותר משתי דקות, הפעולות האוטומטיות שולחות הודעה קולית לרמקולים חכמים, מהבהבות את האורות במטבח ושולחות התראה. שימו לב שהאוטומציה הזו משפיעה רק על תא המקרר במכשיר, ולא על תא ההקפאה (אם הוא קיים):
import com.google.home.automation.action
import com.google.home.automation.automation
import com.google.home.automation.condition
import com.google.home.automation.equals
import com.google.home.automation.starter
import com.google.home.google.AssistantBroadcast
import com.google.home.google.Notification
import com.google.home.matter.standard.OnOff
import com.google.home.matter.standard.OnOffLightDevice
import com.google.home.matter.standard.RefrigeratorAlarm
import com.google.home.matter.standard.RefrigeratorAlarm.Companion.state
import com.google.home.matter.standard.RefrigeratorDevice
import com.google.home.matter.standard.SpeakerDevice
import java.time.Duration
val structure: Structure = home.structures().first()
// Fetch devices using the multipart device model.
var multipartDevices = homeManager.devices(enableMultipartDevices = true)
// Obtain a reference to the refrigerator device.
val refrigeratorDevice = multipartDevices.first {
it.has(TemperatureControlledCabinetDevice) &&
it.has(RefrigeratorAndTemperatureControlledCabinetMode) &&
it.has(RefrigeratorAlarm)
}
// Get all temperature-controlled cabinet parts of the refrigerator
val cabinets = refrigeratorDevice.parts(TemperatureControlledCabinetDevice)
// Find the cabinet part with the 'refrigerator' semantic tag
val refrigeratorCabinet = cabinets.firstOrNull {
it.metadata.tags.contains(SemanticTag.Refrigerator.refrigerator)
}
val cabinetPartPath = refrigeratorCabinet.automationPath(TemperatureControlledCabinetDevice)
val speaker = home.devices().list().first { device -> device.has(SpeakerDevice) }
val refrigeratorDoorAlert = automation {
name = "Refrigerator Door Open Alert"
description = "Warn when the refrigerator door has been open for over 2 min"
isActive = true
sequential {
// 1. Starter: Monitor the refrigerator door alarm trait
val alarmStarter = starter<_>(cabinetPartPath, RefrigeratorAlarm)
// 2. Condition: Ensure the 'doorOpen' alarm remains active for 2 continuous min
condition {
expression = alarmStarter.state.doorOpen equals true
forDuration(Duration.ofMinutes(2))
}
// 3. Actions: Execute parallel reactions
parallel {
// Broadcast warning to household speakers
action(speaker, SpeakerDevice) {
command(AssistantBroadcast.broadcast("The refrigerator door has been left open!"))
}
// Push a notification alerts to home members' mobile devices
action(structure) {
command(Notification.sendNotifications(
"Fridge Alert",
{ body = "The refrigerator door has been open for over 2 min" }
))
}
}
}
}
בדוגמה הבאה, המקרר עובר למצב חיסכון באנרגיה כשהוא מזהה שאין אף אחד בבית.
import com.google.home.automation.action
import com.google.home.automation.automation
import com.google.home.automation.condition
import com.google.home.automation.equals
import com.google.home.automation.starter
import com.google.home.google.AreaPresenceState
import com.google.home.google.AreaPresenceState.Companion.presenceState
import com.google.home.google.AreaPresenceStateTrait.PresenceState
import com.google.home.matter.standard.RefrigeratorAndTemperatureControlledCabinetMode
import com.google.home.matter.standard.RefrigeratorAndTemperatureControlledCabinetMode.Companion.changeToMode
import com.google.home.matter.standard.RefrigeratorDevice
import com.google.home.matter.standard.TemperatureControlledCabinetDevice
val structure: Structure = home.structures().first()
// Fetch devices using the multipart device model.
var multipartDevices = homeManager.devices(enableMultipartDevices = true)
// Obtain a reference to the refrigerator device.
val refrigeratorDevice = multipartDevices.first {
it.has(TemperatureControlledCabinetDevice) &&
it.has(RefrigeratorAndTemperatureControlledCabinetMode) &&
it.has(RefrigeratorAlarm)
}
val refrigeratorPartPath = refrigeratorDevice.automationPart(refrigeratorDevice.part(RefrigeratorDevice).first())
// Get all temperature-controlled cabinet parts of the refrigerator
val cabinets = refrigeratorDevice.parts(TemperatureControlledCabinetDevice )
// Find the cabinet part with the 'refrigerator' semantic tag
val refrigeratorCabinet = cabinets.firstOrNull {
it.metadata.tags.contains(SemanticTag.Refrigerator.refrigerator)
}
val refrigeratorEcoMode = automation {
name = "Refrigerator Eco Mode"
description = "Automatically changes refrigerator to low energy mode when house is vacant."
isActive = true
sequential {
// 1. Starter: Monitor household presence changes
val presenceStarter = starter<_>(structure, AreaPresenceState)
// 2. Condition: Verify presence state transitions to vacant
condition {
expression = presenceStarter.presenceState equals PresenceState.PresenceStateVacant
}
// 3. Action: Set refrigerator cabinet Mode to 'Low Energy' (e.g. Mode 1u)
action(refrigeratorPartPath {
command(RefrigeratorAndTemperatureControlledCabinetMode.changeToMode(1u))
}
}
}