สคีมาลักษณะโหมดสมาร์ทโฮม

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 บูลีน

(ค่าเริ่มต้น: false)

หากตั้งค่านี้เป็น "จริง" ระบบจะใช้ไวยากรณ์เพิ่มเติมสำหรับตรรกะการเพิ่ม/การลดตามลําดับ (เพิ่มขึ้น) ของอาร์เรย์การตั้งค่า

commandOnlyModes บูลีน

(ค่าเริ่มต้น: false)

ระบุว่าอุปกรณ์รองรับการสื่อสารแบบทางเดียว (จริง) หรือแบบ 2 ทาง (เท็จ) ตั้งค่าแอตทริบิวต์นี้เป็น "จริง" หากอุปกรณ์ตอบสนองต่อ Intent QUERY หรือการรายงานสถานะสำหรับลักษณะนี้ไม่ได้

queryOnlyModes บูลีน

(ค่าเริ่มต้น: false)

ต้องระบุหากอุปกรณ์รองรับการดำเนินการแบบค้นหาเท่านั้น แอตทริบิวต์นี้ระบุว่าอุปกรณ์สามารถค้นหาข้อมูลสถานะได้เท่านั้นและไม่สามารถควบคุมได้

ตัวอย่าง

อุปกรณ์ที่มีโหมดและการตั้งค่าหลายรายการ

{
  "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 ออบเจ็กต์

ต้องระบุ

คู่คีย์/ค่าที่มีโหมด name ของอุปกรณ์เป็นคีย์ และ setting_name ปัจจุบันเป็นค่า

<string> String

ปัจจุบัน setting_name

ตัวอย่าง

อุปกรณ์อยู่ในโหมดใด

{
  "currentModeSettings": {
    "load_mode": "small_load",
    "temp_mode": "cold_temp"
  }
}

คำสั่งของอุปกรณ์

อุปกรณ์ที่มีลักษณะนี้อาจตอบสนองต่อคําสั่งต่อไปนี้ซึ่งเป็นส่วนหนึ่งของการดำเนินการ EXECUTE ดูข้อมูลเพิ่มเติมเกี่ยวกับการจัดการ Intent EXECUTE ได้ที่การดำเนินการตาม Intent

action.devices.commands.SetModes

อัปเดตการตั้งค่าโหมด

พารามิเตอร์

พารามิเตอร์ ประเภท คำอธิบาย
updateModeSettings ออบเจ็กต์

ต้องระบุ

คู่คีย์/ค่าที่มีโหมด name ของอุปกรณ์เป็นคีย์ และ setting_name ใหม่เป็นค่า

<string> String

setting_name ใหม่

ตัวอย่าง

ตั้งค่าเป็นโหลดขนาดใหญ่

{
  "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

ข้อผิดพลาดของอุปกรณ์

ดูรายการข้อผิดพลาดและข้อยกเว้นทั้งหมด