Automatisierungen mit mehreren Geräten unter iOS

Eine Automatisierung kann sich auf Geräte mit mehreren Teilen beziehen, ähnlich wie eine Automatisierung, die keine Geräte mit mehreren Teilen verwendet.

Zuerst müssen Sie die Komponente(n) wie gewohnt abrufen. Unter Geräte mit mehreren Teilen erfahren Sie, wie Sie mit Geräten mit mehreren Teilen arbeiten.

Erstellen Sie dann für jeden Teil, den Sie in Ihrer Automatisierung verwenden möchten, einen AutomationPartPath, So können Sie in Automatisierungsstartern, ‑bedingungen und aktionen auf den Teil verweisen.

//  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)

Außerdem ist zu beachten, dass Automatisierungsaktionen in der Regel ein Gerät und einen Gerätetyp als Parameter verwenden. Für eine Automatisierungsaktion, die auf ein Gerät mit einem Teil verweist (wieder mit einem AutomationPartPath), ist jedoch nur der AutomationPartPath erforderlich, da er neben dem Verweis auf das Komponentengerät auch einen Verweis auf den Gerätetyp enthält.AutomationPartPath

In der Automation API kann beispielsweise der Gerätetyp Refrigerator als Gerät mit mehreren Teilen behandelt werden. Er besteht aus einem RefrigeratorDevice als Stammelement, das mehrere Unterteile enthalten kann, z. B. Gefrierschränke oder Standardschränke vom Typ TemperatureControlledCabinetDevice.

Für Automatisierungen für Kühlschränke interagieren Sie hauptsächlich mit zwei Standard Matter Merkmalen:

  • RefrigeratorAlarm: Gibt Alarme zum Türstatus über das Attribut doorOpen des Felds state aus.
  • RefrigeratorAndTemperatureControlledCabinetMode: Ermöglicht das Lesen und Steuern von Modi. Beispielsweise können Sie Befehle wie changeToMode ausführen, um zu Modi wie LowEnergy, RapidCool oder LowNoise zu wechseln.

Diese Beispielautomatisierung wird ausgelöst, wenn die Kühlschranktür geöffnet wird. Wenn die Tür länger als zwei Minuten offen bleibt, sendet die Automatisierung eine Sprachbenachrichtigung auf Smart Speakern, lässt die Küchenlampen blinken und sendet eine Push-Benachrichtigung. Diese Automatisierung wirkt sich nur auf das Kühlschrankfach des Geräts aus und ignoriert das Gefrierfach (falls vorhanden):

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"]
      )
    }
  }
}

Im folgenden Beispiel wird der Kühlschrank in den Modus „Niedriger Energieverbrauch“ versetzt, wenn erkannt wird, dass niemand zu Hause ist.

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)
  }
}