スマートホーム センサー ガイド
action.devices.types.SENSOR - 1 つのセンサーで、温度と湿度の両方のモニタリングなど、複数の機能を果たすことができます。センサーは定量的測定値(ppm で測定された一酸化炭素や煙のレベルなど)と定性的測定値(大気の汚染状況など)の一方または両方を報告できます。
このタイプのデバイスにはセンサーのアイコンが設定され、関連する類義語や別名が与えられます。
デバイスの機能
サービスがサポートする必要がある属性や状態、EXECUTE レスポンスと QUERY レスポンスの作成方法などの実装の詳細については、対応するトレイトのドキュメントをご覧ください。
推奨されるトレイト
これらのトレイトは、デバイスに適用できる場合は推奨されます。ただし、利用可能なすべてのトレイトの中から、既存の製品機能に最適な組み合わせを自由に選択できます。
センサーは、報告できるデータを対象とする他の特性も使用できます。次に例を示します。
- HumiditySetting
- OpenClose
- TemperatureControl - 気温以外の温度(水、表面温度、デバイス内部)に使用します。
- TemperatureSetting - 気温(周囲の空気)に使用します。
デバイスの例: シンプル センサー
このセクションでは、上記のデバイスタイプとトレイトに基づく一般的な「センサー」を表すインテント ペイロードの例を示します。実装でトレイトを追加または削除した場合は、それらの変更を反映するようにレスポンスを適宜変更します。
SYNC レスポンスの例
{
"requestId": "6894439706274654512",
"inputs": [
{
"intent": "action.devices.SYNC"
}
]
}{ "requestId": "6894439706274654512", "payload": { "agentUserId": "user123", "devices": [ { "id": "123", "type": "action.devices.types.SENSOR", "traits": [ "action.devices.traits.EnergyStorage", "action.devices.traits.OccupancySensing", "action.devices.traits.SensorState" ], "name": { "name": "Simple sensor" }, "willReportState": true, "attributes": { "sensorStatesSupported": [ { "name": "AirQuality", "descriptiveCapabilities": { "availableStates": [ "healthy", "moderate", "unhealthy", "very unhealthy" ] } } ], "queryOnlyEnergyStorage": true, "occupancySensorConfiguration": [ { "occupancySensorType": "PIR", "occupiedToUnoccupiedDelaySec": 10, "unoccupiedToOccupiedDelaySec": 10, "unoccupiedToOccupiedEventThreshold": 2 } ] }, "deviceInfo": { "manufacturer": "smart-home-inc", "model": "hs1234", "hwVersion": "3.2", "swVersion": "11.4" } } ] } }
QUERY レスポンスの例
{ "requestId": "6894439706274654514", "inputs": [ { "intent": "action.devices.QUERY", "payload": { "devices": [ { "id": "123" } ] } } ] }
{ "requestId": "6894439706274654514", "payload": { "devices": { "123": { "status": "SUCCESS", "online": true, "currentSensorStateData": [ { "name": "AirQuality", "currentSensorState": "healthy" } ], "descriptiveCapacityRemaining": "HIGH", "capacityRemaining": [ { "unit": "PERCENTAGE", "rawValue": 90 } ], "occupancy": "OCCUPIED" } } } }