Interoperabilidade no Android

Os dispositivos no ecossistema do Google Home podem ser implementados usando Cloud-to-cloud, Matter, ou ambas. Alguns tipos de dispositivos são mais complexos do que outros e apresentam um desafio para desenvolver ao usar as APIs do Google Home de uma maneira que permita uma interface suave com outros dispositivos no ecossistema.

Um dos desafios na implementação de alguns desses tipos de dispositivos é que eles podem ser compostos por diferentes combinações de características. Nem todas as combinações funcionam tão bem quanto outras. Além disso, o Cloud-to-cloud modelo de dados é mapeado para o Matter modelo de dados, mas nem sempre de maneira clara e um para um. Consulte Modelo de dados no Android, que discute os modelos de dados e os mapeamentos com mais detalhes.

Esta página contém mais informações sobre os modelos de dados para dispositivos específicos e oferece algumas orientações sobre quais características usar para implementar esses tipos de dispositivos.

Forno

O tipo de dispositivo do forno (OvenDevice) e as características do componente não são tão simples de implementar em comparação com outros tipos de dispositivos. Há várias maneiras de implementar um forno em Matter, mas nem todas as abordagens resultam em uma interoperabilidade perfeita com outros dispositivos ou com o ecossistema do Google Home.

Mapeamento de características

Em vez de implementar um dispositivo de forno Matter usando os clusters de modo de forno e de ativação/desativação, recomendamos o uso do cluster de estado operacional da cavidade do forno. Esse cluster é representado nas APIs do Google Home pela OvenCavityOperationalState característica e é mapeado para a Cloud-to-cloud RunCycle característica. Ele define fases como "aquecimento programado", "pré-aquecido" e "resfriamento".

APIs do Google Home Cloud-to-cloud
OvenCavityOperationalState RunCycle

Há limitações no modelo de dados do forno Cloud-to-cloud. O modelo de dados do forno Cloud-to-cloud permite apenas uma única câmara, com um único RunCycle. Em contraste, Matter modela um forno de várias câmaras como um endpoint de dispositivo com um cluster de estado operacional da cavidade do forno para cada câmara.

Para alguns dispositivos de forno, pode ser apropriado que a lista de fases mude no momento da execução. Por exemplo, os fornos que oferecem suporte ao pré-aquecimento podem ter entradas diferentes na lista de fases durante a fase de pré-aquecimento do que durante as fases de aquecimento ou resfriamento.

Conforme discutido na seção anterior, uma Matter implementação de forno precisa implementar o cluster de estado operacional da cavidade do forno, que é modelado nas APIs do Google Home como a OvenCavityOperationalState característica.

Para melhores resultados, verifique se o dispositivo de forno Cloud-to-cloud implementa a trait RunCycle e publique o estado atual definindo o atributo currentRunCycle. Esse atributo pode ser observado pelas APIs do Google Home pelos OvenCavityOperationalState.phaseList e OvenCavityOperationalState.currentPhase atributos.

O dispositivo de forno também precisa publicar uma notificação de ciclo de execução atualizando os atributos priority, status e currentCycleRemainingTime de RunCycle. O exemplo a seguir resulta no envio de um OperationalState.OperationCompletion evento e pode ser usado para indicar que o forno fez a transição do ciclo de 'aquecimento programado' para o ciclo 'pré-aquecido':

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

Usar um forno em uma automação

Ao criar uma automação para um forno implementado usando o cluster de estado operacional da cavidade do forno, consulte o atributo currentPhase para saber em qual ciclo o forno está:

   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 um exemplo completo, consulte Acender as luzes e anunciar quando o forno atingir a temperatura escolhida.