Google Home エコシステムのデバイスは、Cloud-to-cloud、Matter、またはその両方を使用して実装できます。デバイスタイプによっては、他のデバイスとのスムーズなインターフェースを可能にする方法で Home API を使用して開発することが難しいものもあります。
これらのデバイスタイプの一部を実装する際の課題の 1 つは、デバイスがさまざまな特性の組み合わせで構成される可能性があることです。すべての組み合わせが同じように機能するわけではありません。また、Cloud-to-cloud データモデルは Matter データモデルにマッピングされますが、必ずしも明確な 1 対 1 の関係ではありません。データモデルとそのマッピングの詳細については、Android のデータモデルをご覧ください。
このページでは、特定のデバイスのデータモデルが相互にどのようにマッピングされるかについて詳しく説明し、それらのデバイスタイプを実装するために使用する特性に関するガイダンスを提供します。
オーブン
オーブン(OvenDevice
)デバイスタイプとそのコンポーネント トレイトは、他のデバイスタイプと比較して実装が簡単ではありません。Matter でオーブンを実装する方法は複数ありますが、すべてのアプローチが他のデバイスや Google Home エコシステムとのシームレスな相互運用につながるわけではありません。
トレイト マッピング
Oven Mode クラスタと On Off クラスタを使用して Matter Oven デバイスを実装するのではなく、Oven Cavity Operational State クラスタを使用することをおすすめします。このクラスタは、Home API で OvenCavityOperationalState
トレイトによって表され、Cloud-to-cloud
RunCycle
トレイトにマッピングされます。「予熱」、「予熱完了」、「冷却」などのフェーズを定義します。
Google Home の API | Cloud-to-cloud |
---|---|
OvenCavityOperationalState
|
RunCycle
|
Cloud-to-cloud オーブン データモデルには制限があります。Cloud-to-cloud オーブン データモデルでは、1 つの RunCycle
を持つ 1 つのチャンバーのみが許可されます。一方、Matter は、各チャンバーのオーブン キャビティ動作状態クラスタを持つデバイス エンドポイントとして、マルチチャンバー オーブンをモデル化します。
一部のオーブン デバイスでは、フェーズリストが実行時に変更されることが適切である場合があります。たとえば、予熱をサポートするオーブンでは、予熱フェーズと加熱フェーズまたは冷却フェーズで、フェーズリストのエントリが異なる場合があります。
おすすめの実装方法
前のセクションで説明したように、Matter オーブン実装では、オーブン キャビティのオペレーショナル ステート クラスタを実装する必要があります。これは、Home API では OvenCavityOperationalState
トレイトとしてモデル化されています。
最適な結果を得るには、Cloud-to-cloud オーブン デバイスが RunCycle
トレイトを実装し、currentRunCycle
属性を設定して現在の状態を公開していることを確認してください。この属性は、OvenCavityOperationalState.phaseList
属性と OvenCavityOperationalState.currentPhase
属性を介して Home API で監視できます。
オーブン デバイスは、RunCycle
の priority
、status
、currentCycleRemainingTime
属性を更新して、実行サイクル デバイス通知も公開する必要があります。次の例では、OperationalState.OperationCompletion
イベントが送信されます。これは、オーブンが「予熱」サイクルから「予熱完了」サイクルに移行したことを示すために使用できます。
{
"currentRunCycle": [
{
"currentCycle": "pre-heating",
"nextCycle": "pre-heated",
"lang": "en"
}
],
"currentTotalRemainingTime": 1200,
"currentCycleRemainingTime": 300
}
自動化でオーブンを使用する
Oven Cavity Operational State クラスタを使用して実装されたオーブンの自動化を構築する場合は、currentPhase
属性を参照して、オーブンのサイクルを確認します。
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
}
完全な例については、オーブンが選択した温度に達したときに照明を点滅させて通知するをご覧ください。