智能家居切换特征架构

action.devices.traits.Toggles - 此特征属于其设置只能处于两种状态之一的任何设备。

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

此特征涵盖用户可以设置的一个或多个切换开关。通常,这些切换开关应该用于与其他设备行为解除关联的功能。关联的行为(例如开启或关闭设备本身)应使用更具体的特征(例如,特征 TemperatureSetting 中的 thermostatMode)。

设备属性

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

属性 类型 说明
availableToggles 数组

必填。

可用切换开关的列表。

[item, ...] 对象

可用切换开关。

name String

必填。

切换开关的内部名称,将用于命令和状态。该播放列表可能不便于使用,并且会在所有语言之间共享。

name_values 数组

必填。

该切换开关在每种支持的语言中的同义词。

[item, ...] 对象

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

name_synonym 数组

必填。

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

[item, ...] String

同义词名称。

lang String

必填。

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

commandOnlyToggles Boolean

(默认值:false

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

queryOnlyToggles Boolean

(默认值: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
}

设备状态

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

类型 说明
currentToggleSettings 对象

必填。

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

<string> Boolean

当前的切换状态。

示例

是否开启了消毒功能?

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

设备命令

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

action.devices.commands.SetToggles

设置给定的切换状态。

参数

参数 类型 说明
updateToggleSettings 对象

必填。

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

<string> Boolean

新的切换状态

示例

开启节能功能

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

关闭过滤器

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

示例话语

de-DE

  • Bitte schalte Power Cool am Kühlschrank aus
  • stelle den Kühlschrank auf Power Cool

en-US

  • activate power freeze for the freezer
  • cancel power cool for the kitchen fridge

es-ES

  • pon el enfriamiento rápido en la nevera
  • quita el enfriamiento rápido

fr-FR

  • mets le mode power cool sur le réfrigérateur
  • Éteins le mode power freeze du réfrigérateur .

hi-IN

  • रेफ़्रिजरेटर का पावर कूल मोड बंद कर दो
  • रेफ़्रिजरेटर में पावर कूल मोड चालू करो

it-IT

  • disattiva il power freeze del freezer
  • imposta la funzione power freeze del surgelatore

ja-JP

  • 冷蔵庫 急速冷凍 つけて
  • 冷蔵庫 急速冷凍 を切ってくれる

ko-KR

  • 냉장고 급속 냉장 해제해
  • 냉장고 모드 급속 냉장 으로 바꿔

nl-NL

  • Zet de power cool uit op de koelkast
  • zet de koelkast op superkoelen

pt-BR

  • 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

sv-SE

  • Stäng av power cool i kylskåpet
  • sätt på power freeze frysen

设备出错

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