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 atributos. 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, 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 los modelos de datos para dispositivos específicos que se asignan entre sí y se ofrecen algunas instrucciones 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. 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 atributos

En lugar de implementar un dispositivo de horno Matter con los clústeres Oven Mode y On Off, te recomendamos que uses el clúster Oven Cavity Operational State. Este clúster se representa en las APIs de Home con el OvenCavityOperationalState atributo, y se asigna al Cloud-to-cloud RunCycle atributo. 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 Oven Cavity Operational State para cada cámara.

En el caso de 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 MatterMatter debe implementar el clúster Oven Cavity Operational State, que se modela en las APIs de Home como el OvenCavityOperationalState atributo.

Para obtener mejores resultados, asegúrate de que tu dispositivo de horno Cloud-to-cloud implemente el trait RunCycle y publique 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 "precalentamiento" al ciclo "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 Oven Cavity Operational State, 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.