Nodes and media
Captura da câmera
OpenClaw oferece suporte a captura de câmera para fluxos de trabalho de agentes:
- Nó iOS (pareado via Gateway): capture uma foto (
jpg) ou um clipe de vídeo curto (mp4, com áudio opcional) vianode.invoke. - Nó Android (pareado via Gateway): capture uma foto (
jpg) ou um clipe de vídeo curto (mp4, com áudio opcional) vianode.invoke. - App macOS (nó via Gateway): capture uma foto (
jpg) ou um clipe de vídeo curto (mp4, com áudio opcional) vianode.invoke.
Todo acesso à câmera é protegido por configurações controladas pelo usuário.
Nó iOS
Configuração do usuário (ativada por padrão)
- Aba Settings do iOS → Camera → Allow Camera (
camera.enabled)- Padrão: ativado (chave ausente é tratada como habilitada).
- Quando desativado: comandos
camera.*retornamCAMERA_DISABLED.
Comandos (via Gateway node.invoke)
-
camera.list- Payload de resposta:
devices: array de{ id, name, position, deviceType }
- Payload de resposta:
-
camera.snap- Parâmetros:
facing:front|back(padrão:front)maxWidth: number (opcional; padrão1600no nó iOS)quality:0..1(opcional; padrão0.9)format: atualmentejpgdelayMs: number (opcional; padrão0)deviceId: string (opcional; decamera.list)
- Payload de resposta:
format: "jpg"base64: "<...>"width,height
- Proteção de payload: fotos são recomprimidas para manter o payload base64 abaixo de 5 MB.
- Parâmetros:
-
camera.clip- Parâmetros:
facing:front|back(padrão:front)durationMs: number (padrão3000, limitado a um máximo de60000)includeAudio: boolean (padrãotrue)format: atualmentemp4deviceId: string (opcional; decamera.list)
- Payload de resposta:
format: "mp4"base64: "<...>"durationMshasAudio
- Parâmetros:
Requisito de primeiro plano
Assim como canvas.*, o nó iOS só permite comandos camera.* em primeiro plano. Invocações em segundo plano retornam NODE_BACKGROUND_UNAVAILABLE.
Auxiliar da CLI
A maneira mais fácil de obter arquivos de mídia é via o auxiliar da CLI, que grava a mídia decodificada em um arquivo temporário e imprime o caminho salvo.
Exemplos:
openclaw nodes camera snap --node <id> # default: both front + back (2 MEDIA lines)openclaw nodes camera snap --node <id> --facing frontopenclaw nodes camera clip --node <id> --duration 3000openclaw nodes camera clip --node <id> --no-audioNotas:
nodes camera snapusa como padrão ambas as orientações para dar ao agente as duas visualizações.- Os arquivos de saída são temporários (no diretório temporário do SO), a menos que você crie seu próprio wrapper.
Nó Android
Configuração do usuário Android (ativada por padrão)
- Painel Settings do Android → Camera → Allow Camera (
camera.enabled)- Padrão: ativado (chave ausente é tratada como habilitada).
- Quando desativado: comandos
camera.*retornamCAMERA_DISABLED.
Permissões
- Android exige permissões em tempo de execução:
CAMERAparacamera.snapecamera.clip.RECORD_AUDIOparacamera.clipquandoincludeAudio=true.
Se as permissões estiverem ausentes, o app solicitará quando possível; se forem negadas, solicitações camera.* falharão com um erro
*_PERMISSION_REQUIRED.
Requisito de primeiro plano no Android
Assim como canvas.*, o nó Android só permite comandos camera.* em primeiro plano. Invocações em segundo plano retornam NODE_BACKGROUND_UNAVAILABLE.
Comandos Android (via Gateway node.invoke)
camera.list- Payload de resposta:
devices: array de{ id, name, position, deviceType }
- Payload de resposta:
Proteção de payload
Fotos são recomprimidas para manter o payload base64 abaixo de 5 MB.
App macOS
Configuração do usuário (desativada por padrão)
O app complementar para macOS expõe uma caixa de seleção:
- Settings → General → Allow Camera (
openclaw.cameraEnabled)- Padrão: desativado
- Quando desativado: solicitações de câmera retornam "Câmera desabilitada pelo usuário".
Auxiliar da CLI (node invoke)
Use a CLI principal openclaw para invocar comandos de câmera no nó macOS.
Exemplos:
openclaw nodes camera list --node <id> # list camera idsopenclaw nodes camera snap --node <id> # prints saved pathopenclaw nodes camera snap --node <id> --max-width 1280openclaw nodes camera snap --node <id> --delay-ms 2000openclaw nodes camera snap --node <id> --device-id <id>openclaw nodes camera clip --node <id> --duration 10s # prints saved pathopenclaw nodes camera clip --node <id> --duration-ms 3000 # prints saved path (legacy flag)openclaw nodes camera clip --node <id> --device-id <id>openclaw nodes camera clip --node <id> --no-audioNotas:
openclaw nodes camera snapusamaxWidth=1600como padrão, a menos que seja substituído.- No macOS,
camera.snapaguardadelayMs(padrão 2000ms) após o aquecimento/estabilização da exposição antes de capturar. - Payloads de foto são recomprimidos para manter base64 abaixo de 5 MB.
Segurança + limites práticos
- O acesso à câmera e ao microfone aciona os prompts de permissão usuais do SO (e exige strings de uso em Info.plist).
- Clipes de vídeo são limitados (atualmente
<= 60s) para evitar payloads de nó grandes demais (sobrecarga de base64 + limites de mensagem).
Vídeo de tela no macOS (nível do SO)
Para vídeo de tela (não câmera), use o complementar para macOS:
openclaw nodes screen record --node <id> --duration 10s --fps 15 # prints saved pathNotas:
- Exige permissão de Screen Recording do macOS (TCC).