智能家居开关 trait 架构

action.devices.traits.Toggles - 此 trait 适用于设置只能处于两种状态中的一种的任何设备。

这些设置可以表示处于开启/关闭或活动/非活动状态的物理按钮、HTML 中的复选框,或任何其他类型的特定启用/停用元素。如果设置有两个以上的状态,或者具有未选择任何二进制选项的状态,则最好将其表示为 Modes trait,这相当于多状态旋钮、单选按钮(实体或 HTML)或非明确开启/关闭的二进制状态(例如“AM/FM”或“冷/热”)。

此 trait 涵盖用户可以设置的一个或多个单独的切换开关。一般来说,这些切换开关应用于与其他设备行为无关的功能。关联的行为(例如开启或关闭设备本身)应使用更具体的 trait(例如 trait TemperatureSetting 中的 thermostatMode)。

设备属性

具有此 trait 的设备可能会在 SYNC 操作中报告以下属性。如需详细了解如何处理 SYNC intent,请参阅intent 执行方式

属性 类型 说明
availableToggles 数组

必填。

可用切换开关列表。

[item, ...] 对象

可用切换开关。

name String

必填。

切换开关的内部名称,将在命令和状态中使用。这可能不利于用户,并且会在所有语言版本中共享。

name_values 数组

必填。

每个受支持语言中的切换开关同义词。

[item, ...] 对象

指定语言中的切换开关的同义词。

name_synonym 数组

必填。

切换开关的同义词。此列表中的第一个字符串将用作相应语言中相应关卡的规范名称。

[item, ...] String

同义词名称。

lang String

必填。

语言代码 (ISO 639-1)。请参阅支持的语言

commandOnlyToggles 布尔值

(默认值:false

指示设备是否支持使用单向(true)或双向(false)通信。如果设备无法响应此 trait 的 QUERY intent 或报告状态,请将此属性设为 true。

queryOnlyToggles 布尔值

(默认值:false

如果设备支持仅查询执行,则必需。此属性用于指明是否只能查询设备的状态信息,而无法控制设备。

示例

具有多个切换开关的设备。

{
  "availableToggles": [
    {
      "name": "sterilization_toggle",
      "name_values": [
        {
          "name_synonym": [
            "Clean",
            "Bio clean"
          ],
          "lang": "en"
        }
      ]
    },
    {
      "name": "energysaving_toggle",
      "name_values": [
        {
          "name_synonym": [
            "Energy saving",
            "Eco"
          ],
          "lang": "en"
        }
      ]
    }
  ]
}

仅限命令的开关。

{
  "availableToggles": [
    {
      "name": "filter_toggle",
      "name_values": [
        {
          "name_synonym": [
            "Filtered",
            "Filter"
          ],
          "lang": "en"
        }
      ]
    }
  ],
  "commandOnlyToggles": true
}

仅限查询的设备切换开关

{
  "availableToggles": [
    {
      "name": "filter_toggle",
      "name_values": [
        {
          "name_synonym": [
            "Filtered",
            "Filter"
          ],
          "lang": "en"
        }
      ]
    }
  ],
  "queryOnlyToggles": true
}

设备状态

具有此 trait 的实体可能会在 QUERY 操作期间报告以下状态。如需详细了解如何处理 QUERY intent,请参阅intent 执行方式

类型 说明
currentToggleSettings 对象

必填。

键值对,其中设备的切换开关 name 作为键,当前状态作为值。

<string> 布尔值

当前切换状态。

示例

是否开启了杀菌功能?

{
  "currentToggleSettings": {
    "sterilization_toggle": true,
    "energysaving_toggle": false
  }
}

设备命令

具有此 trait 的设备可能会在 EXECUTE 操作期间响应以下命令。如需详细了解如何处理 EXECUTE intent,请参阅intent 执行方式

action.devices.commands.SetToggles

设置给定的切换开关状态。

参数

参数 类型 说明
updateToggleSettings 对象

必填。

键值对,其中设备的开关 name 用作键,新状态用作值。

<string> 布尔值

新切换开关状态

示例

开启节能模式

{
  "command": "action.devices.commands.SetToggles",
  "params": {
    "updateToggleSettings": {
      "energysaving_toggle": true
    }
  }
}

关闭过滤器

{
  "command": "action.devices.commands.SetToggles",
  "params": {
    "updateToggleSettings": {
      "filter_toggle": false
    }
  }
}

示例话语

  • Bitte schalte Power Cool am Kühlschrank aus
  • stelle den Kühlschrank auf Power Cool
  • activate power freeze for the freezer
  • cancel power cool for the kitchen fridge
  • pon el enfriamiento rápido en la nevera
  • quita el enfriamiento rápido
  • mets le mode power cool sur le réfrigérateur
  • Éteins le mode power freeze du réfrigérateur .
  • रेफ़्रिजरेटर का पावर कूल मोड बंद कर दो
  • रेफ़्रिजरेटर में पावर कूल मोड चालू करो
  • disattiva il power freeze del freezer
  • imposta la funzione power freeze del surgelatore
  • 冷蔵庫 急速冷凍 つけて
  • 冷蔵庫 急速冷凍 を切ってくれる
  • 냉장고 급속 냉장 해제해
  • 냉장고 모드 급속 냉장 으로 바꿔
  • Zet de power cool uit op de koelkast
  • zet de koelkast op superkoelen
  • Ativa a função power freeze no congelador .
  • Desativa o bloqueio infantil do forno .
  • desligar o power cool da geladeira
  • iniciar o modo power freeze do freezer
  • Stäng av power cool i kylskåpet
  • sätt på power freeze frysen

设备错误

查看错误和异常的完整列表。