É mostrado como usar as teclas de um controle remoto Bluetooth (com um adaptador USB) para controlar a função de espera, aumentar e diminuir o volume e controlar a câmera de um dispositivo de sala ou mesa. Podemos criar uma macro que escuta eventos relevantes e executa as ações associadas usando a API do dispositivo de sala ou mesa.

O recurso de dispositivo de entrada USB de terceiros é descrito nesse artigo.

No exemplo a seguir, você tem que inserir o texto que é gravado em fonte normal. O texto em itálico é a resposta recebida do dispositivo de sala ou mesa.

1

Inicie sessão no dispositivo de sala ou mesa no SSH. Você precisa de um usuário local admin.

2

Configure o dispositivo para permitir o uso de um controle remoto USB de terceiros.

xConfiguration Peripherals InputDevice Mode: On
** end

OK

               

 

Você pode verificar se a configuração está ativada ou desativada usando esse comando:

xConfiguration Peripherals InputDevice Mode
*c xConfiguration Peripherals InputDevice Mode: On
** end

OK

                  
3

Registre-se para obter comentários, para nós sermos notificados quando os botões de controle remoto forem pressionados e soltos.

xFeedback Register /event/userinterface/inputdevice
** end

OK

               

 

Você pode verificar em quais comentários o dispositivo está registrado, usando desse comando:

xFeedback list
/event/userinterface/inputdevice
** end

OK

                  
4

Pressione e solte um botão no controle remoto para verificar se o registro de comentários funciona.

Essa ação gera dois eventos: Pressionado e Solto. Se você manter pressionar um botão, você verá o evento Pressionado até soltar o botão. Em seguida, o evento Solto é gerado.

Esses eventos são emitidos quando pressionar e soltar a tecla Enter:

 
                  
*e UserInterface InputDevice Key Action Key: KEY_ENTER
*e UserInterface InputDevice Key Action Code: 28
*e UserInterface InputDevice Key Action Type: Pressed
** end
*e UserInterface InputDevice Key Action Key: KEY_ENTER
*e UserInterface InputDevice Key Action Code: 28
*e UserInterface InputDevice Key Action Type: Released
** end

               
5

Grave uma macro que escuta eventos InputDevice relevantes e executa as ações associadas usando a API do dispositivo.

  • Acione os botões de espera, volume para cima e volume para baixo. Quando a macro vê um evento contendo KEY_VOLUMEUP, KEY_VOLUMEDOWN ou KEY_SLEEP, executa os comandos relacionados.

  • Crie uma função de controle de câmera para as teclas de seta. É recomendado manter a câmera movendo, enquanto o botão estiver sendo pressionado. Quando o botão for solto, o movimento da câmera é interrompido. Quando a macro vê um evento contendo KEY_LEFT, KEY_RIGHT, KEY_UP ou KEY_DOWN, executa os comandos relacionados.

const xapi = require('xapi');

function com(command, args='') {
  xapi.command(command, args);
  log(command + ' ' + JSON.stringify(args));
}

function log(event) {
  console.log(event);
}

function notify(message) {
  xapi.command('UserInterface Message TextLine Display', {
    Text: message,
    duration: 3
  });
}

function cameraControl(motor, direction, cameraId='1') {
  com('Camera Ramp', { 'CameraId': cameraId,
                       [motor]: direction
  });
}

function init() {
  let standbyState;
  xapi.status.get('Standby').then((state) => {standbyState = state.State === 'Off' ? false : true; });
  xapi.status.on('Standby', state => {
      standbyState = state.State === 'Off' ? false : true; 
  });
  
  xapi.event.on('UserInterface InputDevice Key Action', press => {
    if (press.Type == "Pressed") {
      switch (press.Key) {
        case "KEY_LEFT":
          cameraControl('Pan', 'Left');
          break;
        case "KEY_RIGHT":
          cameraControl('Pan', 'Right');
          break;
        case "KEY_UP":
          cameraControl('Tilt', 'Up');
          break;
        case "KEY_DOWN":
          cameraControl('Tilt', 'Down');
          break;
        default:
          break;
        }
    } else if (press.Type == "Released") {
        switch (press.Key) {
          case "KEY_LEFT":
            cameraControl('Pan', 'Stop');
          break;
          case "KEY_RIGHT":
            cameraControl('Pan', 'Stop');
          break;
          case "KEY_UP":
            cameraControl('Tilt', 'Stop');
          break;
          case "KEY_DOWN":
            cameraControl('Tilt', 'Stop');
          break;
          case 'KEY_VOLUMEUP':
            com('Audio Volume Increase');
            break;
          case 'KEY_VOLUMEDOWN':
            com('Audio Volume Decrease');
            break;
          case 'KEY_SLEEP':
            com(standbyState ? 'Standby Deactivate' : 'Standby Activate');
            break;
          default:
            break;
          }
      } 
  });
}

init();