eval/skills/wl-overlay/SKILL.md
Fullscreen Wayland overlays for screen recordings via gtk4-layer-shell. MUST be invoked before any work involving: ov eval wl overlay commands, recording overlays, title cards, lower-thirds, countdowns, or fade transitions.
npx skillsauth add overthinkos/overthink-plugins wl-overlayInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
ov eval wl overlay creates and manages fullscreen Wayland overlays using the layer-shell protocol via gtk4-layer-shell. Overlays render directly in the compositor, appearing natively in screen recordings without post-production editing. Supports true alpha transparency — desktop content is visible through semi-transparent overlays.
Three components work together:
wl-overlay layer — installs gtk4-layer-shell, gtk4, python3-gobject RPMs + ov-overlay Python daemon/clientov eval wl overlay Go commands — CLI that resolves the container and invokes ov-overlay inside itov-overlay daemon — GTK4 application managing multiple named overlay windows via Unix socket IPCThe daemon starts on-demand in a tmux session (ov-overlay-daemon) when the first show command is issued. It persists until hide --all or the tmux session is killed.
| Action | Command | Description |
|--------|---------|-------------|
| Show overlay | ov eval wl overlay show <image> --type text --text "Hello" | Display a named overlay |
| Hide one | ov eval wl overlay hide <image> --name intro | Remove specific overlay |
| Hide all | ov eval wl overlay hide <image> --all | Remove all overlays |
| List | ov eval wl overlay list <image> | List active overlays (JSON) |
| Status | ov eval wl overlay status <image> | Check daemon health |
Full-screen semi-transparent overlay with centered text. Use for intro/outro title cards.
ov eval wl overlay show myimage --type text \
--text "Building a REST API" \
--bg "rgba(0,0,0,0.7)" \
--font-size 64 --name title
Bottom-anchored bar with name and optional subtitle. Use for speaker identification.
ov eval wl overlay show myimage --type lower-third \
--text "Andreas Trawoeger" \
--subtitle "Developer" --name speaker
Corner-anchored persistent text at low opacity. Use for draft/preview markers.
ov eval wl overlay show myimage --type watermark \
--text "DRAFT" --position bottom-right \
--color red --opacity 0.5 --name wm
Default opacity is 0.3. Positions: top-left, top-right, bottom-left, bottom-right, top, bottom.
Full-screen animated countdown that auto-hides on completion. Use before recording starts.
ov eval wl overlay show myimage --type countdown --seconds 5 --name cd
Transparent overlay with a colored rectangle at specified coordinates. Use to draw attention to a screen region.
ov eval wl overlay show myimage --type highlight \
--region "430,290,510,50" \
--color "rgba(255,0,0,0.4)" --name hl
Region format: X,Y,Width,Height in pixels.
Full-screen solid color overlay. Use for transitions (fade to black, fade to white).
ov eval wl overlay show myimage --type fade --color black --name outro
Any overlay (except countdown, which has built-in auto-hide) can auto-remove after a duration:
ov eval wl overlay show myimage --type text --text "INTRO" --duration 5s --name intro
Supported formats: 5s, 1.5m, 500ms, or bare seconds (5).
Overlays compose naturally with ov eval record:
# Title card
ov eval wl overlay show myimage --type text --text "Building a REST API" \
--bg "rgba(0,0,0,0.9)" --font-size 64 --name title
# Start recording
ov eval record start myimage -n demo -m desktop
# Fade out title after 3s
sleep 3
ov eval wl overlay hide myimage --name title
# Lower-third speaker ID
ov eval wl overlay show myimage --type lower-third \
--text "Andreas Trawoeger" --subtitle "Developer" --name speaker
# ... record content ...
# Fade to black for ending
ov eval wl overlay show myimage --type fade --color black --name outro
sleep 2
# Stop recording
ov eval record stop myimage -n demo -o demo.mp4
ov eval wl overlay hide myimage --all
All overlay types work on all wlroots-based compositors:
| Compositor | Environment | Status | Notes | |-----------|-------------|--------|-------| | sway | sway-browser-vnc | WORKS | Instant rendering, captured by wayvnc | | labwc | selkies-desktop | WORKS | ~15s capture latency in controller mode (no browser). Instant in recordings |
window { background: none; } CSS at daemon startup. Without this, GTK4 on Wayland creates opaque surfacesGtk.DrawingArea + Cairo, not CSS. GTK4 CSS background-color with rgba() does not composite correctly on layer-shell windowsGtk4LayerShell.Layer.OVERLAY (highest z-order, above waybar/swaync)KeyboardMode.NONE — overlays never capture input-1 — overlays don't push other windows/usr/bin/python3 (system Python with PyGObject), not pixi's PythonOn selkies-desktop, pixelflux-screenshot captures from the H.264 WebSocket stream. In controller mode (no browser client connected), the frame rate is very low — screenshots may take 15-30 seconds to reflect overlay changes. This does NOT affect recordings — ov eval record captures at 30fps, so overlays appear immediately in recorded video.
Socket: /tmp/ov-overlay.sock (Unix domain, JSON-line)
{"action":"show","type":"text","text":"Hello","name":"intro","bg":"rgba(0,0,0,0.7)"}
{"action":"hide","name":"intro"}
{"action":"hide_all"}
{"action":"list"}
{"action":"status"}
| Flag | Default | Description |
|------|---------|-------------|
| --type | (required) | text, lower-third, watermark, countdown, highlight, fade |
| --text | "" | Text content |
| --subtitle | "" | Subtitle (lower-third only) |
| --name | auto-generated | Overlay identifier for hide/list |
| --position | center | Positioning (watermark: corner anchoring) |
| --bg | type-dependent | Background color (CSS rgba or named) |
| --color | white | Text/highlight color |
| --font-size | 48 | Font size in pixels |
| --opacity | 1.0 (watermark: 0.3) | Overall window opacity |
| --duration | none | Auto-hide after duration (e.g. 5s) |
| --seconds | 3 | Countdown seconds |
| --region | 100,100,400,300 | Highlight region X,Y,W,H |
wl-overlay layer (gtk4-layer-shell + python3-gobject)tmux layer (for daemon hosting)sway-desktop and selkies-desktop metalayers/ov-eval:wl — Compositor-agnostic desktop automation (screenshots, input, windows)/ov-eval:record — Terminal and desktop recording (overlays compose with recording workflow)/ov-eval:cdp — Chrome DevTools Protocol (DOM-level interaction)/ov-selkies:wl-overlay-layer — Layer reference (RPM packages, dependencies)/ov-selkies:sway-desktop — Desktop metalayer (includes wl-overlay)/ov-selkies:selkies-desktop-layer — Desktop metalayer (includes wl-overlay)Source: ov/wl_overlay.go (Go commands), layers/wl-overlay/ov-overlay (Python daemon/client).
development
Claude Code multi-agent support in Overthink — sub-agents, dynamic workflows, and agent teams, and how each drives the existing `ov eval` disposable beds to test and verify. MUST be invoked before authoring or invoking an ov sub-agent / dynamic workflow / agent team, wiring agent-lifecycle hooks, or asking "which primitive should drive the R10 beds?".
tools
Mounts a virtiofs share tagged `workspace` at /workspace inside a VM guest via a systemd .mount unit. Use when a kind:vm entity shares a host directory into the guest and you need it auto-mounted (and re-mounted at every boot).
development
MUST be invoked before any work involving: the `kind: android` schema kind, a `target: android` deploy, the `apk:` layer package format (installing Android apps declaratively), AndroidDeployTarget, an in-pod emulator OR a remote/physical adb-endpoint device, or nested `pod → android` deployment. The first-class Android device + app surface that sits above `ov eval adb`/`appium`.
tools
Use when committing, branching, pushing, merging, tagging, creating PRs, or approving/merging PRs with gh — the feat/-branch, R10-gated, never-force-push landing workflow across the main repo + the plugins submodule + image/<distro> submodules. Covers sync-to-upstream, branch/worktree pruning, the fork+PR path for contributors without write access, and cross-repo @github landing order.