skills$openclaw/video-message
thewulf74.3k

by thewulf7

video-message – OpenClaw Skill

video-message is an OpenClaw Skills integration for devops workflows. Generate and send video messages with a lip-syncing VRM avatar. Use when user asks for video message, avatar video, video reply, or when TTS should be delivered as video instead of audio.

4.3k stars579 forksSecurity L1
Updated Feb 7, 2026Created Feb 7, 2026devops

Skill Snapshot

namevideo-message
descriptionGenerate and send video messages with a lip-syncing VRM avatar. Use when user asks for video message, avatar video, video reply, or when TTS should be delivered as video instead of audio. OpenClaw Skills integration.
ownerthewulf7
repositorythewulf7/avatar-video-messages
languageMarkdown
licenseMIT
topics
securityL1
installopenclaw add @thewulf7/avatar-video-messages
last updatedFeb 7, 2026

Maintainer

thewulf7

thewulf7

Maintains video-message in the OpenClaw Skills directory.

View GitHub profile
File Explorer
2 files
.
_meta.json
486 B
SKILL.md
4.4 KB
SKILL.md

name: video-message description: Generate and send video messages with a lip-syncing VRM avatar. Use when user asks for video message, avatar video, video reply, or when TTS should be delivered as video instead of audio. metadata: { "openclaw": { "emoji": "🎥", "requires": { "bins": ["ffmpeg", "avatarcam"] }, "install": [ { "id": "npm", "kind": "npm", "package": "@thewulf7/openclaw-avatarcam", "global": true, "bins": ["avatarcam"], "label": "Install avatarcam (npm)", }, { "id": "brew", "kind": "brew", "formula": "ffmpeg", "bins": ["ffmpeg"], "label": "Install ffmpeg (brew)", }, { "id": "apt", "kind": "apt", "packages": ["xvfb", "xauth"], "label": "Install headless X dependencies (Linux only)", }, ], }, }

Video Message

Generate avatar video messages from text or audio. Outputs as Telegram video notes (circular format).

Installation

npm install -g openclaw-avatarcam

Configuration

Configure in TOOLS.md:

### Video Message (avatarcam)
- avatar: default.vrm
- background: #00FF00

Settings Reference

SettingDefaultDescription
avatardefault.vrmVRM avatar file path
background#00FF00Color (hex) or image path

Prerequisites

System Dependencies

PlatformCommand
macOSbrew install ffmpeg
Linuxsudo apt-get install -y xvfb xauth ffmpeg
WindowsInstall ffmpeg and add to PATH
DockerSee Docker section below

Note: macOS and Windows don't need xvfb — they have native display support.

Docker Users

Add to OPENCLAW_DOCKER_APT_PACKAGES:

build-essential procps curl file git ca-certificates xvfb xauth libgbm1 libxss1 libatk1.0-0 libatk-bridge2.0-0 libgdk-pixbuf2.0-0 libgtk-3-0 libasound2 libnss3 ffmpeg

Usage

# With color background
avatarcam --audio voice.mp3 --output video.mp4 --background "#00FF00"

# With image background
avatarcam --audio voice.mp3 --output video.mp4 --background "./bg.png"

# With custom avatar
avatarcam --audio voice.mp3 --output video.mp4 --avatar "./custom.vrm"

Sending as Video Note

Use OpenClaw's message tool with asVideoNote:

message action=send filePath=/tmp/video.mp4 asVideoNote=true

Workflow

  1. Read config from TOOLS.md (avatar, background)
  2. Generate TTS if given text: tts text="..." → audio path
  3. Run avatarcam with audio + settings → MP4 output
  4. Send as video note via message action=send filePath=... asVideoNote=true
  5. Return NO_REPLY after sending

Example Flow

User: "Send me a video message saying hello"

# 1. TTS
tts text="Hello! How are you today?" → /tmp/voice.mp3

# 2. Generate video
avatarcam --audio /tmp/voice.mp3 --output /tmp/video.mp4 --background "#00FF00"

# 3. Send as video note
message action=send filePath=/tmp/video.mp4 asVideoNote=true

# 4. Reply
NO_REPLY

Technical Details

SettingValue
Resolution384x384 (square)
Frame rate30fps constant
Max duration60 seconds
Video codecH.264 (libx264)
Audio codecAAC
QualityCRF 18 (high quality)
ContainerMP4

Processing Pipeline

  1. Electron renders VRM avatar with lip sync at 1280x720
  2. WebM captured via canvas.captureStream(30)
  3. FFmpeg processes: crop → fps normalize → scale → encode
  4. Message tool sends via Telegram sendVideoNote API

Platform Support

PlatformDisplayNotes
macOSNative QuartzNo extra deps
Linuxxvfb (headless)apt install xvfb
WindowsNativeNo extra deps

Headless Rendering

Avatarcam auto-detects headless environments:

  • Uses xvfb-run when $DISPLAY is not set (Linux only)
  • macOS/Windows use native display
  • GPU stall warnings are safe to ignore
  • Generation time: ~1.5x realtime (20s audio ≈ 30s processing)

Notes

  • Config is read from TOOLS.md
  • Clean up temp files after sending: rm /tmp/video*.mp4
  • For regular video (not circular), omit asVideoNote=true
README.md

No README available.

Permissions & Security

Security level L1: Low-risk skills with minimal permissions. Review inputs and outputs before running in production.

Requirements

### System Dependencies | Platform | Command | |----------|---------| | **macOS** | `brew install ffmpeg` | | **Linux** | `sudo apt-get install -y xvfb xauth ffmpeg` | | **Windows** | Install ffmpeg and add to PATH | | **Docker** | See Docker section below | > **Note:** macOS and Windows don't need xvfb — they have native display support. ### Docker Users Add to `OPENCLAW_DOCKER_APT_PACKAGES`: ``` build-essential procps curl file git ca-certificates xvfb xauth libgbm1 libxss1 libatk1.0-0 libatk-bridge2.0-0 libgdk-pixbuf2.0-0 libgtk-3-0 libasound2 libnss3 ffmpeg ```

Configuration

Configure in `TOOLS.md`: ```markdown ### Video Message (avatarcam) - avatar: default.vrm - background: #00FF00 ``` ### Settings Reference | Setting | Default | Description | |---------|---------|-------------| | `avatar` | `default.vrm` | VRM avatar file path | | `background` | `#00FF00` | Color (hex) or image path |

FAQ

How do I install video-message?

Run openclaw add @thewulf7/avatar-video-messages in your terminal. This installs video-message into your OpenClaw Skills catalog.

Does this skill run locally or in the cloud?

OpenClaw Skills execute locally by default. Review the SKILL.md and permissions before running any skill.

Where can I verify the source code?

The source repository is available at https://github.com/openclaw/skills/tree/main/skills/thewulf7/avatar-video-messages. Review commits and README documentation before installing.