اتوماسیون چندبخشی دستگاه در iOS

یک اتوماسیون ممکن است به دستگاه‌های چندبخشی مشابه اتوماسیونی که از دستگاه‌های چندبخشی استفاده نمی‌کند، ارجاع دهد.

ابتدا، قطعه(های) تشکیل‌دهنده را طبق معمول تهیه کنید. برای نحوه کار با دستگاه‌های چندبخشی، به دستگاه‌های چندبخشی مراجعه کنید.

سپس، برای هر بخشی که می‌خواهید در اتوماسیون خود استفاده کنید، یک 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)
  }
}