Interoperabilidad en Android

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 desarrollar 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 pueden estar compuestos por diferentes combinaciones de rasgos. No todas las combinaciones funcionan tan bien como otras. Además, el Cloud-to-cloud modelo de datos se asigna al modelo de datos Matter, pero no siempre de forma clara y uno a uno. Consulta Modelo de datos en Android, que analiza los modelos de datos y sus asignaciones con más detalle.

En esta página, se incluye más información sobre los modelos de datos para dispositivos específicos que se asignan entre sí y se ofrecen algunas instrucciones sobre qué rasgos usar para implementar esos tipos de dispositivos.

Horno

El tipo de dispositivo Horno (OvenDevice) y sus rasgos de componentes no son tan sencillos de implementar en comparación con otros tipos de dispositivos. Hay varias formas de implementar un horno en Matter, pero no todos los enfoques dan como resultado una interoperación perfecta con otros dispositivos o con el ecosistema de Google Home.

Asignación de rasgos

En lugar de implementar un dispositivo de horno Matter con los clústeres de modo de horno y encendido/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 OvenCavityOperationalState rasgo y se asigna al Cloud-to-cloud RunCycle rasgo. Define fases como "precalentamiento", "precalentado" y "enfriamiento".

APIs de Home Cloud-to-cloud
OvenCavityOperationalState RunCycle

Existen limitaciones en el modelo de datos de horno de Cloud-to-cloud. El modelo de datos de horno Cloud-to-cloud solo permite una sola cámara, con un solo RunCycle. Por el contrario, 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.

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

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

Para obtener mejores resultados, asegúrate de que tu dispositivo de horno Cloud-to-cloud implemente el rasgo 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 de horno 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
}

Usa 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, haz referencia al atributo currentPhase para saber en qué ciclo está 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 obtener un ejemplo completo, consulta Cómo hacer parpadear las luces y anunciar cuando el horno alcanza la temperatura elegida.