คู่มือตัวควบคุมอุณหภูมิสมาร์ทโฮม
action.devices.types.THERMOSTAT
- ตัวควบคุมอุณหภูมิเป็นอุปกรณ์จัดการอุณหภูมิพร้อมจุดและโหมดที่ตั้งไว้ วิธีนี้จะแยกอุปกรณ์ออกจากเครื่องทำความร้อนและเครื่องปรับอากาศซึ่งอาจมีเฉพาะโหมดและการตั้งค่า (เช่น สูง/ต่ำ) เทียบกับเป้าหมายอุณหภูมิ
ประเภทนี้บ่งบอกว่าอุปกรณ์มีไอคอนตัวควบคุมอุณหภูมิ รวมถึงคำพ้องและชื่อแทนที่เกี่ยวข้อง
อุปกรณ์ประเภทนี้จะควบคุมอุณหภูมิ ขณะที่หน่วยทำความร้อน/ทำความเย็นบางรุ่นมีการควบคุมและโหมดสูง/ต่ำที่แตกต่างกัน แต่จะไม่มีการควบคุมอุณหภูมิความสามารถของอุปกรณ์
โปรดดูเอกสารลักษณะที่เกี่ยวข้องเพื่อดูรายละเอียดการนำไปใช้งาน เช่น แอตทริบิวต์และสถานะของบริการที่ควรรองรับ รวมถึงวิธีสร้างการตอบสนอง EXECUTE และ QUERY
ลักษณะที่จำเป็น
ลักษณะและคำสั่งเหล่านี้จำเป็น หากเกี่ยวข้องกับอุปกรณ์ของคุณ หากอุปกรณ์ของคุณไม่รองรับลักษณะเหล่านี้ ให้ป้อนรหัสข้อผิดพลาด functionNotSupported
ในคำตอบ QUERY หรือ EXECUTE ดูข้อมูลเพิ่มเติมได้ที่ข้อผิดพลาดและข้อยกเว้น
คำสั่งของตัวควบคุมอุณหภูมิมักจะเชื่อมโยงอยู่ใน Intent EXECUTE
รายการ ผู้ใช้ที่บอกว่า *ตั้งความร้อนเป็น 72* จะสร้างคำสั่งโหมดตามด้วยการตั้งค่าอุณหภูมิ
ข้อกำหนดด้านคุณภาพ
- เวลาในการตอบสนอง: ต้องน้อยกว่าหรือเท่ากับ 700 มิลลิวินาที
- ความเสถียร: ต้องมากกว่าหรือเท่ากับ 97%
อุปกรณ์ตัวอย่าง: ตัวควบคุมอุณหภูมิแบบง่าย
ส่วนนี้ประกอบด้วยตัวอย่างเพย์โหลด Intent ที่แสดงถึง "ตัวควบคุมอุณหภูมิ" ทั่วไป โดยอิงตามประเภทอุปกรณ์และลักษณะข้างต้น หากคุณเพิ่มหรือนำลักษณะในการใช้งานออก ให้แก้ไขคำตอบให้สอดคล้องกับการเปลี่ยนแปลงเหล่านั้น
ตัวอย่างการตอบสนองของ SYNC
{ "requestId": "6894439706274654512", "inputs": [ { "intent": "action.devices.SYNC" } ] }
{ "requestId": "6894439706274654512", "payload": { "agentUserId": "user123", "devices": [ { "id": "123", "type": "action.devices.types.THERMOSTAT", "traits": [ "action.devices.traits.TemperatureSetting" ], "name": { "name": "Simple thermostat" }, "willReportState": true, "attributes": { "availableThermostatModes": [ "off", "heat", "cool", "heatcool", "on" ], "thermostatTemperatureRange": { "minThresholdCelsius": 15, "maxThresholdCelsius": 30 }, "thermostatTemperatureUnit": "F" }, "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, "thermostatMode": "cool", "thermostatTemperatureSetpoint": 23, "thermostatTemperatureAmbient": 25.1, "thermostatHumidityAmbient": 45.3 } } } }
ตัวอย่างคำสั่ง EXECUTE
ThermostatTemperatureSetpoint
ดูรายละเอียดเพิ่มเติมเกี่ยวกับพารามิเตอร์คําสั่งได้ที่ข้อมูลอ้างอิง
action.devices.traits.TemperatureSetting
{ "requestId": "6894439706274654516", "inputs": [ { "intent": "action.devices.EXECUTE", "payload": { "commands": [ { "devices": [ { "id": "123" } ], "execution": [ { "command": "action.devices.commands.ThermostatTemperatureSetpoint", "params": { "thermostatTemperatureSetpoint": 22 } } ] } ] } } ] }
{ "requestId": "6894439706274654516", "payload": { "commands": [ { "ids": [ "123" ], "status": "SUCCESS", "states": { "online": true, "thermostatMode": "cool", "thermostatTemperatureSetpoint": 22, "thermostatTemperatureAmbient": 25.1 } } ] } }
ThermostatTemperatureSetRange
ดูรายละเอียดเพิ่มเติมเกี่ยวกับพารามิเตอร์คําสั่งได้ที่ข้อมูลอ้างอิง
action.devices.traits.TemperatureSetting
{ "requestId": "6894439706274654518", "inputs": [ { "intent": "action.devices.EXECUTE", "payload": { "commands": [ { "devices": [ { "id": "123" } ], "execution": [ { "command": "action.devices.commands.ThermostatTemperatureSetRange", "params": { "thermostatTemperatureSetpointHigh": 26, "thermostatTemperatureSetpointLow": 22 } } ] } ] } } ] }
{ "requestId": "6894439706274654518", "payload": { "commands": [ { "ids": [ "123" ], "status": "SUCCESS", "states": { "online": true, "thermostatMode": "heatcool", "thermostatTemperatureSetpointHigh": 26, "thermostatTemperatureSetpointLow": 22, "thermostatTemperatureAmbient": 25.1 } } ] } }
ThermostatSetMode
ดูรายละเอียดเพิ่มเติมเกี่ยวกับพารามิเตอร์คําสั่งได้ที่ข้อมูลอ้างอิง
action.devices.traits.TemperatureSetting
{ "requestId": "6894439706274654520", "inputs": [ { "intent": "action.devices.EXECUTE", "payload": { "commands": [ { "devices": [ { "id": "123" } ], "execution": [ { "command": "action.devices.commands.ThermostatSetMode", "params": { "thermostatMode": "heatcool" } } ] } ] } } ] }
{ "requestId": "6894439706274654520", "payload": { "commands": [ { "ids": [ "123" ], "status": "SUCCESS", "states": { "online": true, "thermostatMode": "heatcool", "thermostatTemperatureSetpointHigh": 26, "thermostatTemperatureSetpointLow": 22, "thermostatTemperatureAmbient": 25.1 } } ] } }
ข้อผิดพลาดเกี่ยวกับอุปกรณ์
ดูรายการข้อผิดพลาดและข้อยกเว้นทั้งหมดinHeatOrCool
- คำสั่งทำความร้อน/ทำความเย็น/ช่วงการทำงานล้มเหลวเนื่องจากอุปกรณ์อยู่ในการทำความร้อนหรือความเย็นอย่างชัดแจ้งinHeatCool
- คำสั่งทำความร้อนหรือทำความเย็นไม่สำเร็จเนื่องจากอุปกรณ์อยู่ในความร้อนหรือความเย็นlockedToRange
- อุปกรณ์ล็อกอยู่โดยใช้ช่วงอุณหภูมิหรือโหมด และจะทำการเปลี่ยนแปลงตามที่ขอไม่ได้rangeTooClose
- จุดอุณหภูมิของช่วงฮีตคูลอยู่ใกล้กันเกินไป