Esquema de trait ColorSpectrum para casas inteligentes

action.devices.traits.ColorSpectrum: Esta característica pertenece a cualquier dispositivo que pueda establecer un espectro de color. Esto se aplica a las bombillas "a todo color" que aceptan rangos de colores RGB. Las luces pueden tener cualquier combinación de ColorSpectrum y ColorTemperature. Las luces de acento y las tiras LED pueden tener Spectrum, mientras que algunas bombillas de lectura solo tienen Temperature. Las bombillas básicas o las luces bajas en enchufes inteligentes no tienen ninguno.

Dispositivo ATTRIBUTES

Atributo Definición
colorModel Opcional. Se puede configurar en la string hsv a fin de indicar la preferencia de dispositivo para el modelo de color HSV (matiz, saturación, valor). El valor predeterminado es rgb.

Ejemplo de solicitud y respuesta de SYNC

{
   
"requestId": "ff36a3cc-ec34-11e6-b1a0-64510650abcf",
   
"inputs": [{
     
"intent": "action.devices.SYNC"
   
}]
}
'use strict';

const {smarthome} = require('actions-on-google');
const functions = require('firebase-functions');

const app = smarthome();

app
.onSync((body, headers) => {
 
return {
    requestId
: body.requestId,
    payload
: {
      agentUserId
: '1836.15267389',
      devices
: [{
        id
: '123',
        type
: 'action.devices.types.LIGHT',
        traits
: [
         
'action.devices.traits.ColorSpectrum'
       
],
        name
: {
          defaultNames
: ['AAA bulb A19 color hyperglow'],
          name
: 'lamp1',
          nicknames
: ['reading lamp']
       
},
        willReportState
: true,
        attributes
: {
          colorModel
: 'rgb'
       
},
        deviceInfo
: {
          manufacturer
: 'AAA',
          model
: 'hg11',
          hwVersion
: '1.2',
          swVersion
: '5.4'
       
},
        customData
: {
          fooValue
: 12,
          barValue
: false,
          bazValue
: 'dancing alpaca'
       
}
     
}]
   
}
 
};
});

// ...

exports
.smarthome = functions.https.onRequest(app);
{
 
"requestId": "ff36a3cc-ec34-11e6-b1a0-64510650abcf",
 
"payload": {
   
"agentUserId": "1836.15267389",
   
"devices": [
     
{
       
"id": "123",
       
"type": "action.devices.types.LIGHT",
       
"traits": [
         
"action.devices.traits.ColorSpectrum"
       
],
       
"name": {
         
"defaultNames": [
           
"AAA bulb A19 color hyperglow"
         
],
         
"name": "lamp1",
         
"nicknames": [
           
"reading lamp"
         
]
       
},
       
"willReportState": true,
       
"attributes": {
         
"colorModel": "rgb"
       
},
       
"deviceInfo": {
         
"manufacturer": "AAA",
         
"model": "hg11",
         
"hwVersion": "1.2",
         
"swVersion": "5.4"
       
},
       
"customData": {
         
"fooValue": 12,
         
"barValue": false,
         
"bazValue": "dancing alpaca"
       
}
     
}
   
]
 
}
}

Dispositivo STATES

Estado Definición
color Objeto. Configuración de color actual. Como una luz determinada está en el modo de espectro O temperatura, este objeto incluye la configuración de color actual en el modo relevante.
  • String name. Si el punto de color (Spectrum o Temperature) coincide con un nombre predeterminado de la lista de colores del socio, muestra el nombre.
  • spectrumRGB número entero. Valor del espectro en RGB (valor hexadecimal como un número entero).

COMANDOS del dispositivo

Comando Parámetros/Definición
action.devices.commands.ColorAbsolute Objeto color. Obligatorio. Incluirá RGB o Temperature y, opcionalmente, un nombre.
  • String name. Es el nombre del color (en inglés), como se proporciona en el comando del usuario. No siempre está disponible (para comandos relativos).
  • spectrumRGB número entero. Valor del espectro en RGB (valor hexadecimal como un número entero).

Ejemplo de solicitud y respuesta EXECUTE

Establece la luz en rojo.
{
 
"requestId": "ff36a3cc-ec34-11e6-b1a0-64510650abcf",
 
"inputs": [{
   
"intent": "action.devices.EXECUTE",
   
"payload": {
     
"commands": [{
       
"devices": [{
         
"id": "123",
         
"customData": {
           
"fooValue": 74,
           
"barValue": true,
           
"bazValue": "sheepdip"
         
}
       
}],
       
"execution": [{
         
"command": "action.devices.commands.ColorAbsolute",
         
"params": {
           
"color": {
           
"name": "red",
           
"spectrumRGB": 16711680
           
}
         
}
       
}]
     
}]
   
}
 
}]
}
'use strict';

const {smarthome} = require('actions-on-google');
const functions = require('firebase-functions');

const app = smarthome();

app
.onExecute((body, headers) => {
 
return {
    requestId
: body.requestId,
    payload
: {
      commands
: [{
        ids
: ['123'],
        status
: 'SUCCESS',
        states
: {
          color
: {
            name
: 'red',
            spectrumRGB
: 12655639
         
}
       
}
     
}]
   
}
 
};
});

// ...

exports
.smarthome = functions.https.onRequest(app);
{
 
"requestId": "ff36a3cc-ec34-11e6-b1a0-64510650abcf",
 
"payload": {
   
"commands": [
     
{
       
"ids": [
         
"123"
       
],
       
"status": "SUCCESS",
       
"states": {
         
"color": {
           
"name": "red",
           
"spectrumRGB": 12655639
         
}
       
}
     
}
   
]
 
}
}
A continuación, se incluyen otros ejemplos de invocaciones:
  • Establece las luces en verde.
  • Cambiar la lámpara de escritorio a roja