สคีมาลักษณะโหมดสมาร์ทโฮม
action.devices.traits.Modes
- ลักษณะนี้ครอบคลุมโหมดและการตั้งค่าเฉพาะโหมดทั้งหมดที่มีสำหรับอุปกรณ์
ลักษณะนี้ใช้กับอุปกรณ์ที่มีโหมด "n-way" จำนวนมากเท่าใดก็ได้ โดยที่โหมดและการตั้งค่าของแต่ละโหมดจะกำหนดเองและแตกต่างกันไปในแต่ละอุปกรณ์หรือประเภทอุปกรณ์ แต่ละโหมดมีการตั้งค่าได้หลายแบบ แต่เลือกได้เพียงครั้งละ 1 โหมดเท่านั้น เครื่องอบผ้าไม่สามารถทำงานในโหมด "ซักถนอม" "ซักปกติ" และ "ซักหนัก" พร้อมกัน การตั้งค่าที่เปิดหรือปิดได้ง่ายๆ อยู่ในลักษณะ Toggles
เช่น เครื่องซักผ้าอาจมีการตั้งค่าสำหรับปริมาณผ้าและอุณหภูมิ ทั้งสองอย่างนี้จะเป็นโหมดเนื่องจากไม่เกี่ยวข้องกัน แต่แต่ละรายการจะอยู่ในสภาวะได้เพียงสถานะเดียวในแต่ละครั้ง ผู้ใช้สามารถตั้งค่าโหมด เช่น อุณหภูมิ ได้อย่างชัดเจนด้วยคำสั่งอย่างตั้งค่าอุณหภูมิของเครื่องซักผ้าเป็นเย็น
โหมดบางโหมดเป็นแบบ "เรียงลําดับ" และสามารถปรับได้ด้วยคําว่า "ขึ้น/ลง" "เพิ่ม/ลด" เช่น ขนาดการโหลด (เล็ก กลาง ใหญ่) และอุณหภูมิมีลําดับชัดเจน (โปรดทราบว่าอุณหภูมิไม่ใช่ตัวควบคุมอุณหภูมิจริงที่มีเป้าหมายเป็นตัวเลขเหมือนในอุปกรณ์อื่นๆ) แต่ประเภทการโหลด (ชุดชั้นใน ปกติ ขนสัตว์ ฯลฯ) อาจไม่เป็นเช่นนั้น
ลักษณะนี้ครอบคลุมโหมดเดี่ยวอย่างน้อย 1 โหมดที่ผู้ใช้ตั้งค่าได้ โดยทั่วไปแล้ว คุณควรใช้โหมดเหล่านี้กับฟังก์ชันการทำงานที่ไม่ได้ลิงก์กับลักษณะการทํางานของอุปกรณ์อื่นๆ ลักษณะการทำงานที่ลิงก์ เช่น การเปิดหรือปิดอุปกรณ์ ควรใช้ลักษณะที่เฉพาะเจาะจงมากขึ้น (เช่น thermostatMode
ในลักษณะ TemperatureSetting)
แอตทริบิวต์อุปกรณ์
อุปกรณ์ที่มีลักษณะนี้อาจรายงานแอตทริบิวต์ต่อไปนี้เป็นส่วนหนึ่งของการดำเนินการ SYNC
ดูข้อมูลเพิ่มเติมเกี่ยวกับการจัดการ Intent SYNC
ได้ที่การดำเนินการตาม Intent
Attributes | ประเภท | คำอธิบาย |
---|---|---|
availableModes |
อาร์เรย์ |
ต้องระบุ รายการโหมดที่ใช้ได้ |
[item, ...] |
ออบเจ็กต์ |
โหมดที่ใช้ได้ |
name |
String |
ต้องระบุ ชื่อภายในของโหมดที่จะใช้ในคําสั่งและสถานะ ซึ่งอาจทำให้ผู้ใช้ไม่สะดวกและจะแชร์ในทุกภาษา |
name_values |
อาร์เรย์ |
ต้องระบุ คำพ้องความหมายของโหมดในแต่ละภาษาที่รองรับ |
[item, ...] |
ออบเจ็กต์ |
คำพ้องความหมายของโหมดในภาษาหนึ่งๆ |
name_synonym |
อาร์เรย์ |
ต้องระบุ คำพ้องความหมายของโหมด ระบบจะใช้สตริงแรกในรายการนี้เป็นชื่อแคนอนิกของระดับในภาษานั้น |
[item, ...] |
String |
ชื่อคำพ้อง |
lang |
String |
ต้องระบุ รหัสภาษา (ISO 639-1) ดูภาษาที่รองรับ |
settings |
อาร์เรย์ |
ต้องระบุ การตั้งค่าที่รองรับสำหรับโหมดนี้ |
[item, ...] |
ออบเจ็กต์ |
การตั้งค่าที่รองรับ ต้องมีอย่างน้อย 2 รายการ |
setting_name |
String |
ต้องระบุ ชื่อภายในของการตั้งค่าโหมด ซึ่งจะใช้ในคำสั่งและสถานะ ซึ่งอาจทำให้ผู้ใช้ไม่สะดวกและจะแชร์ในทุกภาษา |
setting_values |
อาร์เรย์ |
ต้องระบุ คำพ้องความหมายของการตั้งค่าในแต่ละภาษาที่รองรับ |
[item, ...] |
ออบเจ็กต์ |
คำพ้องความหมายของการตั้งค่าในภาษาหนึ่งๆ |
setting_synonym |
อาร์เรย์ |
ต้องระบุ คำพ้องความหมายของการตั้งค่า ระบบจะใช้สตริงแรกในรายการนี้เป็นชื่อแคนอนิกของระดับในภาษานั้น |
[item, ...] |
String |
ชื่อคำพ้อง |
lang |
String |
ต้องระบุ รหัสภาษา (ISO 639-1) ดูภาษาที่รองรับ |
ordered |
บูลีน |
(ค่าเริ่มต้น: หากตั้งค่านี้เป็น "จริง" ระบบจะใช้ไวยากรณ์เพิ่มเติมสำหรับตรรกะการเพิ่ม/การลดตามลําดับ (เพิ่มขึ้น) ของอาร์เรย์การตั้งค่า |
commandOnlyModes |
บูลีน |
(ค่าเริ่มต้น: ระบุว่าอุปกรณ์รองรับการสื่อสารแบบทางเดียว (จริง) หรือแบบ 2 ทาง (เท็จ) ตั้งค่าแอตทริบิวต์นี้เป็น "จริง" หากอุปกรณ์ตอบสนองต่อ Intent QUERY หรือการรายงานสถานะสำหรับลักษณะนี้ไม่ได้ |
queryOnlyModes |
บูลีน |
(ค่าเริ่มต้น: ต้องระบุหากอุปกรณ์รองรับการดำเนินการแบบค้นหาเท่านั้น แอตทริบิวต์นี้ระบุว่าอุปกรณ์สามารถค้นหาข้อมูลสถานะได้เท่านั้นและไม่สามารถควบคุมได้ |
ตัวอย่าง
อุปกรณ์ที่มีโหมดและการตั้งค่าหลายรายการ
{ "availableModes": [ { "name": "load_mode", "name_values": [ { "name_synonym": [ "Load", "Size", "Load size" ], "lang": "en" } ], "settings": [ { "setting_name": "small_load", "setting_values": [ { "setting_synonym": [ "Small", "Half" ], "lang": "en" } ] }, { "setting_name": "medium_load", "setting_values": [ { "setting_synonym": [ "Medium", "Normal" ], "lang": "en" } ] }, { "setting_name": "large_load", "setting_values": [ { "setting_synonym": [ "Large", "Full" ], "lang": "en" } ] } ], "ordered": true }, { "name": "temp_mode", "name_values": [ { "name_synonym": [ "Temperature", "Temp" ], "lang": "en" } ], "settings": [ { "setting_name": "hot_temp", "setting_values": [ { "setting_synonym": [ "Hot", "White" ], "lang": "en" } ] }, { "setting_name": "warm_temp", "setting_values": [ { "setting_synonym": [ "Warm", "Color" ], "lang": "en" } ] }, { "setting_name": "cold_temp", "setting_values": [ { "setting_synonym": [ "Cold", "Delicate" ], "lang": "en" } ] } ], "ordered": false } ] }
อุปกรณ์ที่มีโหมดคำสั่งเท่านั้น
{ "availableModes": [ { "name": "light_mode", "name_values": [ { "name_synonym": [ "Light", "Lighting" ], "lang": "en" } ], "settings": [ { "setting_name": "day_light", "setting_values": [ { "setting_synonym": [ "Day", "Bright" ], "lang": "en" } ] }, { "setting_name": "night_light", "setting_values": [ { "setting_synonym": [ "Night", "Dark" ], "lang": "en" } ] }, { "setting_name": "reading_light", "setting_values": [ { "setting_synonym": [ "Reading", "Ambiant" ], "lang": "en" } ] } ], "ordered": false } ], "commandOnlyModes": true, "queryOnlyModes": false }
สถานะอุปกรณ์
เอนทิตีที่มีลักษณะนี้อาจรายงานสถานะต่อไปนี้เป็นส่วนหนึ่งของการดำเนินการ QUERY
ดูข้อมูลเพิ่มเติมเกี่ยวกับการจัดการ Intent QUERY
ได้ที่การดำเนินการตาม Intent
รัฐ | ประเภท | คำอธิบาย |
---|---|---|
currentModeSettings |
ออบเจ็กต์ |
ต้องระบุ คู่คีย์/ค่าที่มีโหมด |
<string> |
String |
ปัจจุบัน |
ตัวอย่าง
อุปกรณ์อยู่ในโหมดใด
{ "currentModeSettings": { "load_mode": "small_load", "temp_mode": "cold_temp" } }
คำสั่งของอุปกรณ์
อุปกรณ์ที่มีลักษณะนี้อาจตอบสนองต่อคําสั่งต่อไปนี้ซึ่งเป็นส่วนหนึ่งของการดำเนินการ EXECUTE
ดูข้อมูลเพิ่มเติมเกี่ยวกับการจัดการ Intent EXECUTE
ได้ที่การดำเนินการตาม Intent
action.devices.commands.SetModes
อัปเดตการตั้งค่าโหมด
พารามิเตอร์
พารามิเตอร์ | ประเภท | คำอธิบาย |
---|---|---|
updateModeSettings |
ออบเจ็กต์ |
ต้องระบุ คู่คีย์/ค่าที่มีโหมด |
<string> |
String |
|
ตัวอย่าง
ตั้งค่าเป็นโหลดขนาดใหญ่
{ "command": "action.devices.commands.SetModes", "params": { "updateModeSettings": { "load_mode": "large_load" } } }
ตัวอย่างคำพูด
de-DE
- Stelle den Staubsauger auf Ruhemodus
en-US
- set the vacuum to energy saver mode
es-ES
- pon la lavadora en modo frío
fr-FR
- mets l'aspirateur en silencieux
hi-IN
- वैक्यूम पर कार्पेट मोड लगाएं
it-IT
- imposta l'aspirapolvere su silenzioso
ja-JP
- 掃除機 を 静音 モードに設定して
ko-KR
- 세탁기 세탁량 많음 으로 설정해
pt-BR
- acionar a função autolimpeza do aspirador
- ligar o modo de aquecimento