Interoperabilidad

Los dispositivos del ecosistema de Google Home se pueden implementar con Cloud-to-cloud, Matter o ambos. Algunos tipos de dispositivos son más complejos que otros y presentan un desafío para su desarrollo cuando se usan las APIs de Home de una manera que permita una interfaz fluida con otros dispositivos del ecosistema.

Uno de los desafíos para implementar algunos de estos tipos de dispositivos es que estos pueden estar compuestos por diferentes combinaciones de atributos. No todas las combinaciones funcionan tan bien como otras. Además, el modelo de datos de Cloud-to-cloud se asigna al modelo de datos de Matter, pero no siempre de una manera clara y uno a uno. Consulta Modelo de datos, en el que se analizan los modelos de datos y sus asignaciones con más detalle.

En esta página, se incluye más información sobre cómo se asignan entre sí los modelos de datos de dispositivos específicos y se ofrece orientación sobre qué atributos usar para implementar esos tipos de dispositivos.

Horno

El tipo de dispositivo Horno (OvenDevice) y sus atributos de componentes no son tan fáciles de implementar en comparación con otros tipos de dispositivos. Existen varias formas de implementar un horno en Matter, pero no todos los enfoques generan una interoperabilidad fluida con otros dispositivos o con el ecosistema de Google Home.

Asignación de atributos

En lugar de implementar un dispositivo de horno Matter con los clústeres de modo de horno y encendido y apagado, te recomendamos que uses el clúster de estado operativo de la cavidad del horno. Este clúster se representa en las APIs de Home con el atributo OvenCavityOperationalState y se asigna al atributo Cloud-to-cloud RunCycle. Define fases como "precalentamiento", "precalentado" y "enfriamiento".

APIs de Home Cloud-to-cloud
OvenCavityOperationalState RunCycle

El modelo de datos de Cloud-to-cloud Oven tiene limitaciones. El modelo de datos de horno Cloud-to-cloud solo permite una sola cámara, con un solo RunCycle. En cambio, Matter modela un horno de varias cámaras como un extremo de dispositivo con un clúster de estado operativo de la cavidad del horno para cada cámara.

En algunos dispositivos Oven, puede ser apropiado que la lista de fases cambie durante el tiempo de ejecución. Por ejemplo, los hornos que admiten el precalentamiento pueden tener entradas diferentes en la lista de fases durante la fase de precalentamiento que durante las fases de calentamiento o enfriamiento.

Como se analizó en la sección anterior, una implementación de Matter Oven debería implementar el clúster de estado operativo de la cavidad del horno, que se modela en las APIs de Home como el atributo OvenCavityOperationalState.

Para obtener mejores resultados, asegúrate de que tu dispositivo Cloud-to-cloud Oven implemente el atributo RunCycle y publica el estado actual configurando el atributo currentRunCycle. Las APIs de Home pueden observar este atributo a través de los atributos OvenCavityOperationalState.phaseList y OvenCavityOperationalState.currentPhase.

El dispositivo Oven también debe publicar una notificación de dispositivo de ciclo de ejecución actualizando los atributos priority, status y currentCycleRemainingTime de RunCycle. En el siguiente ejemplo, se envía un evento OperationalState.OperationCompletion y se puede usar para indicar que el horno pasó del ciclo de "precalentamiento" al ciclo de "precalentado":

{
  "currentRunCycle": [
    {
      "currentCycle": "pre-heating",
      "nextCycle": "pre-heated",
      "lang": "en"
    }
  ],
  "currentTotalRemainingTime": 1200,
  "currentCycleRemainingTime": 300
}

Cómo usar un horno en una automatización

Cuando crees una automatización para un horno implementado con el clúster de estado operativo de la cavidad del horno, consulta el atributo currentPhase para saber en qué ciclo se encuentra el horno:

   sequential {
    val starterNode =
      starter<_>(oven, OvenDevice, OvenCavityOperationalState /* Or OperationalState */)
    condition {
      expression = starterNode.phaseList[operationalState.currentPhase.toUInt()] equals "pre-heated"
    }
    action(speaker, SpeakerDevice) {
    command(AssistantBroadcast.broadcast("Oven Cycle Complete"))
  }
  // Additional actions here as needed
}

Para ver un ejemplo completo, consulta Hacer parpadear las luces y anunciar cuando el horno alcanza la temperatura elegida.