Android'de çok parçalı cihaz otomasyonları

Bir otomasyon, çok parçalı cihazlara, çok parçalı cihaz kullanmayan bir otomasyona benzer şekilde referans verebilir.

Öncelikle, bileşen parçalarını normalde yaptığınız gibi edinin. Çok parçalı cihazlarla nasıl çalışacağınızı öğrenmek için Çok parçalı cihazlar başlıklı makaleyi inceleyin.

Ardından, otomasyonunuzda kullanmak istediğiniz her bölüm için bir AutomationPartPath oluşturun. Bu, otomasyon başlatıcılarında, koşullarında ve işlemlerinde bölüme referans vermenizi sağlar.

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

Otomasyon işlemlerinin genellikle parametre olarak bir cihaz ve cihaz türü aldığını da unutmayın. Ancak, bir bileşen parçası cihaza referans veren bir otomasyon işlemi (yine AutomationPartPath kullanılarak) yalnızca AutomationPartPath gerektirir. Çünkü AutomationPartPath, bileşen cihaz referansına ek olarak cihaz türüne referans içerir.

Örneğin, Automation API'de Refrigerator cihaz türü, çok parçalı bir cihaz olarak değerlendirilebilir. Kök RefrigeratorDevice ve dondurucular veya TemperatureControlledCabinetDevice türünde standart dolaplar gibi birden fazla alt parça dolabı içerebilir.

Buzdolabı otomasyonları oluşturmak için öncelikle iki standart Matter özelliğiyle etkileşimde bulunursunuz:

  • RefrigeratorAlarm: Kapı durumu alarmlarını state alanının doorOpen özelliği aracılığıyla gösterir.
  • RefrigeratorAndTemperatureControlledCabinetMode: Okuma ve komut modlarına izin verir. Örneğin, changeToMode gibi komutları çalıştırarak LowEnergy, RapidCool veya LowNoise gibi modlara geçebilirsiniz.

Bu örnek otomasyon, buzdolabı kapısı açıldığında tetiklenir. Kapı iki dakikadan uzun süre açık kalırsa otomasyon, akıllı hoparlörlerde sesli bildirim yayınlar, mutfak ışıklarını yakıp söndürür ve anlık bildirim gönderir. Bu otomasyonun yalnızca cihazın buzdolabı bölmesini etkilediğini ve dondurucu bölmesini (varsa) dikkate almadığını unutmayın:

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

Aşağıdaki örnekte, evde kimsenin olmadığı algılandığında buzdolabı düşük enerji moduna geçiriliyor.

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