设备能力与状态

优质
小牛编辑
140浏览
2023-12-01

1.1.1. 设备能力与状态

  • 设备能力 actions: 指的是智能设备具备的能力,比如智能灯泡具有开关、调颜色、调亮度的能力。
  • 设备状态 state: 指的是设备当前的状态,与定义的设备能力对应。
  • 设备能力接受值与状态值详见 设备能力

Example:

actions:

{
  "switch":["on","off"],
  "color":["num"],
  "brightness":["num"]
}

actions 数据定义参考: jsonschemalint 在线校验工具

state:

{
  "switch": "on",
  "color": 256,
  "brightness": 10
}

state 数据定义参考: jsonschemalint 在线校验工具

设备能力 actions

开关 switch
  • actions 接受值 [ "on", "off", "stop"]
    • "on" : 开
    • "off" : 关
    • "stop" : 暂停,停止

Example:

{ "switch": ["on", "off"] }
  • state 值
    • {string}
    • actions 定义设备能力对应的状态
    • 可以为 null

Example:

{ "property": "switch", "name":"on" }
颜色 color
  • actions 接受值 [ "random", "num" ]
    • "random": 颜色随机RGB值
    • "num": 指定颜色RGB值,例如蓝色RGB值为 0x00FF00
    • 当设备同时支持调颜色和调亮度时,则亮度值将会整合在RGB中,因此RGB设备的调亮度能力不需要添加 brightness 的能力,只需添加 color 即可。如,RGB灯。

Example:

{ "color": ["num"] }
  • state 值
    • {number}
    • RGB 十六进制数值
    • 0x000000 - 0xFFFFFF
    • 可以为 null

Example:

{ "property": "color", "name":"num", "value": 65280 }
亮度 brightness
  • actions 接受值 [ "up", "down", "max", "min", "num" ]
    • "up": 调亮
    • "down": 调暗
    • "max": 调到最亮
    • "min": 调到最暗
    • "num": 调到 0 到 100 之间指定数值,若设备亮度范围更大,则需要自行转换。
    • 当设备支持RGB调颜色和调亮度时,不需要添加此能力。当设备不支持RGB调色,但支持调亮度时,则添加此能力。如,白光灯。

Example:

{ "brightness": ["up", "down", "num"] }
  • state 值
    • {number}
    • 0 到 100 之间十进制数值
    • 可以为 null

Example:

{ "property": "brightness", "name":"num", "value": 68 }
模式 mode
  • actions 接受值 [ "auto", "manual", "cool", "heat", "dry", "fan", "silent", "energy", "sleep"]
    • "auto": 自动模式
    • "manual": 手动模式
    • "cool": 制冷模式
    • "heat": 制热模式
    • "dry": 除湿模式
    • "fan": 送风模式
    • "silent": 静音模式
    • "energy": 省电模式
    • "sleep": 睡眠模式

Example:

自动模式

{ "property": "mode", "name":"auto" }
  • state 值
    • {string}
    • actions 定义能力对应的一个状态
    • 可以为 null

Example:

{ "property": "mode", "name":"auto"}
位置量 position 暂时不支持
  • actions 接受值 [ "up","down","num" ]
    • "up": 如:窗帘打开一点
    • "down": 如:窗帘关闭一点
    • "num": 如:窗帘打开/关闭到百分之几

Example:

{ "position": ["num"] }
  • state 值
    • {number}
    • 0 到 100 之间十进制数值
    • 如果不能明确获取到具体数值,可以为 null

Example:

{ "property": "position", "name":"num", "value": 10}
风速 fanspeed
  • actions 接受值 [ "up", "down", "max", "min", "switch", "num" ]
    • "up": 调高,调大
    • "down": 调低,调小
    • "max": 调到最高,调到最大
    • "min": 调到最低, 调到最小
    • "switch": 切换不同档位
    • "num": 调到指定数值

Example:

{ "fanspeed": ["up", "down", "num"] }
  • state 值
    • {number}
    • 0 到 100 之间十进制数值
    • 如果不能明确获取到具体数值,可以为 null

Example:

{ "property": "fanspeed", "name":"num", "value": 10}
转向模式 swing_mode
  • actions 接受值 [ "auto", "on", "off", "horizon", "horizon.off","vertical", "vertical.off" ]
    • "auto": 自动模式
    • "on": 打开转向模式
    • "off": 关闭转向模式
    • "horizon": 水平转向,左右转向
    • "horizon.off": 关闭水平转向、关闭左右转向
    • "vertical": 垂直转向、上下转向
    • "vertical.off": 关闭垂直转向、上下转向

Example:

{ "swing_mode": ["auto", "horizon", "vertical"] }
  • state 值
    • {string}
    • actions 定义的能力对应的一个状态
    • 可以为 null

Example:

{ "swing_mode": "auto" }
{ "property": "position", "name":"num", "value": 10}
音量 volume
  • actions 接受值 [ "up", "down", "max", "min", "num" ]
    • "up": 调高,调大
    • "down": 调低,调小
    • "max": 调到最大
    • "min": 调到最小
    • "num": 调到指定数值

Example:

{ "volume": ["up", "down", "mun"] }
  • state 值
    • {number}
    • 0 到 100 之间十进制数值
    • 如果不能明确获取到具体数值,可以为 null

Example:

{ "property": "volume", "name":"num", "value": 100}
频道 channel
  • actions 接受值 [ "next", "prev", "random", "num" ]
    • "prev": 上一个频道
    • "next": 下一个频道
    • "random": 随机频道
    • "num": 指定频道
    • "channelName": 通过频道名调台 开发中

Example:

{ "property": "channel", "name":"num", "value": 10}
{ "property": "channel", "name":"channelName", "value": "CCTV-1"}
  • state 值
    • {number}
    • 正整数
    • 如果不能明确获取到具体数值,可以为 null

Example:

{ "property": "channel", "name":"num", "value": 34}

对应错误码:

湿度 humidity
  • actions 接受值 [ "up", "down", "max", "min", "num" ]
    • "up": 调高
    • "down": 调低
    • "max": 调到最大
    • "min": 调到最小
    • "num": 调到指定数值

Example:

{ "humidity": ["up", "down", "max", "min", "num"] }
  • state 值
    • {number}
    • 0 到 100 之间十进制数值
    • 如果不能明确获取到具体数值,可以为 null

Example:

{ "property": "humidity", "name":"num", "value": 100}
温度 temperature
  • actions 接受值 [ "up", "down", "max", "min", "num" ]
    • "up": 调高
    • "down": 调低
    • "max": 调到最大
    • "min": 调到最小
    • "num": 调到指定数值

Example:

{ "temperature": ["up", "down"] }
  • state 值
    • {number}
    • 0 到 100 之间十进制数值
    • 如果不能明确获取到具体数值,可以为 null

Example:

{ "property": "temperature", "name":"num", "value": 26}
色温 color_temperature
  • actions 接受值 [ "up", "down", "max", "min", "num" ]
    • "up": 调高
    • "down": 调低
    • "max": 调到最大
    • "min": 调到最小
    • "num": 调到指定数值

Example:

{ "color_temperature": ["up", "down"] }
  • state 值
    • {number}
    • 0 到 100 之间十进制数值
    • 如果不能明确获取到具体数值,可以为 null

Example:

{ "property": "color_temperature", "name":"num", "value": 26}
ping
  • actions 接受值 [ "trigger" ]
    • ping 是设备提示的功能。比如,智慧灯泡闪一下(打开关闭或者关闭打开,或者换颜色,改亮度),用来发现。如果设备没有该能力,又支持开关,那么默认开关一下,用以提示。
      • trigger 触发

Example:

{ "property": "ping", "name":"trigger"}
  • state 值
    • 为空,不需要提供state
媒体播放控制 media_control
  • actions接受值[ "play_media", "pause", "play", "stop", "playmode", "previous", "next", "get_meta" ]

    • play_media 播放媒体,接受值 [ "media_tag", "singer", "song" ]

      • media_tag 媒体源,可选,接受值{ "type": "favlist"}
      • singer 歌手,可选
      • song 歌曲,可选

      Example 1:若琪,我要听歌

      { "property": "media_control", "name": "play_media", "value": { } }
      

      在没有提供艺术家、曲目、媒体源的情况下,设备可以随机播放媒体或者根据用户平时喜好提供具体内容

      Example 2:若琪,我要听王菲的歌

      {
          "property": "media_control",
          "name": "play_media",
          "value": {
              "signer": "王菲"
          }
      }
      

      在只提供艺术家的情况下设备可以播放某个艺术家的Top歌曲

      Example 3:若琪,我要听收藏夹中周杰伦的歌

      {
          "property": "media_control",
          "name":"play_media",
          "value": {
              "media_tag": {
                  "type" : "favlist"
              },
              "singer": "周杰伦"
          }
      }
      

      在提供了媒体源的情况下代表用户希望播放某一个媒体源下的曲目,设备可以从用户的媒体源中选择艺术家和曲目进行播放,媒体源暂时只支持『收藏夹』

    • pause 暂停播放

    • play 继续播放

    • stop 停止播放

    • playmode 设置播放模式,接受值[ "repeatOne", "repeat", "shuffle" ]

      • repeatOne 单曲循环
      • repeat 循环列表
      • shuffle 随机播放

      Example: 若琪,打开单曲循环

      { "property": "media_control", "name":"playmode", "value": "repeatOne"}
      
    • previous 上一首

    • next 下一首

    • get_meta 获取当前播放媒体信息

      Example: 若琪,现在放的什么歌

      { "property": "media_control", "name":"get_meta", "value": { } }
      

      在处理无误的情况下请返回以下格式的内容来进行TTS播报

      {
          "status": 0,
          "artist": {
              "name": "艺术家名字"
          },
          "name": "曲目名称"
      }
      

Example:

{ "property": "media_control", "name":"play"}
  • state 值
    • get_meta 需要提供指定格式的内容,其他的返回状态码即可
通用档位 level 开发中
  • actions 接受值 ["num", "prev", "next"]
    • num 档位数值
    • prev 上一个档位
    • next 下一个档位
  • state 值 {number} 非负整数,表示当前档位

Example:

{ "property": "level", "name":"num", "value": 4 }