Skip to main content

Cross-platform headless screen and audio capture library and CLI

Project description

recap

Cross-platform headless screen and audio capture library and CLI.

Features

  • Cross-platform: Windows, macOS, and Linux
  • Record an entire monitor or a single window
  • Record system audio (loopback capture)
  • Per-application audio capture (Windows only via WASAPI process loopback)
  • Video-only, audio-only, or audio+video modes
  • Crop support with configurable size and anchor position
  • CLI tool (recap) and importable Python library
  • Rust native backend (PyO3) for Windows, with automatic fallback to pure-Python
  • Uses FFmpeg for encoding/muxing only

Platform Support

Feature Windows macOS Linux
Monitor capture ✓ GDI BitBlt ✓ CoreGraphics ✓ X11 XGetImage
Window capture ✓ PrintWindow ✓ CGWindowListCreateImage ✓ X11 XGetImage
System audio ✓ WASAPI loopback ⚠ Requires BlackHole/Soundflower ✓ PulseAudio monitor
Per-app audio ✓ WASAPI process loopback ✗ Not supported ✗ Not supported
Rust backend
HW encoding NVENC / QSV / AMF VideoToolbox / NVENC NVENC / VAAPI / QSV

macOS Notes

  • Screen Recording permission must be granted in System Settings → Privacy & Security → Screen Recording.
  • System audio capture requires a virtual audio loopback device such as BlackHole. Install BlackHole, then set it as your system output (or use a Multi-Output Device to hear audio simultaneously). Recap auto-detects BlackHole/Soundflower when available.
  • Per-application audio capture is not supported; system-wide audio is captured instead.

Linux Notes

  • Video capture requires X11 (XWayland is acceptable). Native Wayland capture is not yet supported. If running under Wayland, ensure DISPLAY is set for XWayland.
  • Audio capture uses PulseAudio/PipeWire loopback (default.monitor). Ensure pactl is available (pulseaudio-utils or pipewire-pulse).
  • Per-application audio capture is not directly supported; system-wide audio is captured instead.

Requirements

  • Python 3.10–3.13
  • FFmpeg on PATH or specified via --ffmpeg
  • Rust toolchain (only if building from source on Windows)

Platform-specific requirements

  • Windows: Windows 10 version 2004+ for per-app audio capture
  • macOS: macOS 11+ recommended; Screen Recording permission required
  • Linux: X11 or XWayland; PulseAudio or PipeWire; xrandr for multi-monitor detection

Installation

From PyPI (prebuilt wheels)

pip install recap-capture

From source (editable)

Requires maturin and the Rust toolchain (for the Windows native backend):

pip install maturin
git clone https://github.com/Lexian-droid/recap.git
cd recap
maturin develop --release   # builds native backend (Windows only)
pip install -e .

On macOS/Linux, skip the maturin develop step if you don't need the Rust backend — the pure-Python implementations are used automatically.

Architecture

The project has a hybrid Python/Rust structure with a platform abstraction layer:

recap/              Python package (CLI, config, orchestration)
  __init__.py       Public API and version
  _native.py        Bridge to Rust — sets NATIVE_AVAILABLE flag
  cli.py            CLI entry point
  config.py         RecordingConfig dataclass
  recorder.py       Orchestrates capture threads + FFmpeg
  video.py          Platform-dispatching video capture
  audio.py          Platform-dispatching audio capture
  discovery.py      Platform-dispatching monitor/window/device enumeration
  ffmpeg.py         FFmpeg discovery and process wiring
  exceptions.py     Exception hierarchy
  platforms/        Platform abstraction layer
    __init__.py     Platform detection utilities
    macos/          macOS backends (CoreGraphics + FFmpeg avfoundation)
    linux/          Linux backends (X11 + FFmpeg pulse/alsa)

rust_core/          Rust native backend (PyO3/maturin, Windows only)
  src/lib.rs        PyO3 module registration
  src/video.rs      GDI BitBlt / PrintWindow video capture
  src/audio.rs      WASAPI loopback + process loopback audio capture
  src/discovery.rs  Monitor/window/audio device enumeration

Platform dispatch

The video.py, audio.py, and discovery.py modules contain the Windows implementation at the top level. On macOS or Linux, platform-specific implementations are imported from recap/platforms/ and replace the module-level names. This means the public API (from recap import VideoCapture) works identically regardless of platform.

On Windows, the Rust extension (recap._rust_core) can further replace the Python backends with native implementations for maximum performance.

Window-specific recording

When a window is targeted via --window-title or --window-handle:

  • Video is captured using the platform's native window capture API
  • Audio on Windows uses WASAPI process loopback to isolate audio from that process. On macOS/Linux, system-wide audio is captured instead (with a warning).

Releasing

GitHub Actions will publish the package to PyPI when you push a tag that starts with v (e.g. v0.5.0). Wheels are built for Python 3.10–3.13. The Rust native backend is compiled for Windows; macOS and Linux use pure-Python backends.

CLI Usage

# Check environment
recap doctor

# List available capture targets
recap monitors
recap windows
recap devices

# Record primary monitor with audio
recap record --output recording.mp4

# Record a specific window (video + window-specific audio on Windows)
recap record --window-title "Notepad" --output notepad.mp4

# Record video only
recap record --video-only --output silent.mp4

# Record a 1280x720 crop from the top-left of the selected source
recap record --crop-size 1280x720 --crop-position top-left --output cropped.mp4

# Record a centered 1280x720 crop from a specific window
recap record --window-title "Notepad" --crop-size 1280x720 --crop-position middle --output notepad-cropped.mp4

# Record audio only
recap record --audio-only --output audio.wav

# Record for 30 seconds
recap record --duration 30 --output clip.mp4

Crop positions

--crop-position supports:

  • top-left, top-middle, top-right
  • middle-left, middle, middle-right
  • bottom-left, bottom-middle, bottom-right

Center aliases are also accepted (center, top-center, middle-center, etc.).

Library Usage

from recap import Recorder, RecordingConfig

config = RecordingConfig(output="recording.mp4")
recorder = Recorder(config)
recorder.start()
# ... do work ...
recorder.stop()
recorder.wait()

Window-specific recording

from recap import Recorder, RecordingConfig

config = RecordingConfig(
    output="discord.mp4",
    window_title="Discord",
)
recorder = Recorder(config)
recorder.start()
# captures the Discord window's video (and per-app audio on Windows)
recorder.stop()
recorder.wait()

License

MIT

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

recap_capture-0.5.0.tar.gz (54.8 kB view details)

Uploaded Source

Built Distributions

If you're not sure about the file name format, learn more about wheel file names.

recap_capture-0.5.0-cp313-cp313-win_amd64.whl (262.9 kB view details)

Uploaded CPython 3.13Windows x86-64

recap_capture-0.5.0-cp312-cp312-win_amd64.whl (263.5 kB view details)

Uploaded CPython 3.12Windows x86-64

recap_capture-0.5.0-cp311-cp311-win_amd64.whl (262.8 kB view details)

Uploaded CPython 3.11Windows x86-64

recap_capture-0.5.0-cp310-cp310-win_amd64.whl (262.7 kB view details)

Uploaded CPython 3.10Windows x86-64

File details

Details for the file recap_capture-0.5.0.tar.gz.

File metadata

  • Download URL: recap_capture-0.5.0.tar.gz
  • Upload date:
  • Size: 54.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for recap_capture-0.5.0.tar.gz
Algorithm Hash digest
SHA256 2c4d81134b72fd41e0da8a6f3df4e1237184b03a2ca2ee8d8a8b8e9b49155731
MD5 01ba1e41883ac1f65b69d1403f10f1a4
BLAKE2b-256 1bbdf16a935e01e7f3aae95afe03901f92e225ab371844a772b50ed21e9b9a16

See more details on using hashes here.

Provenance

The following attestation bundles were made for recap_capture-0.5.0.tar.gz:

Publisher: release.yml on Lexian-droid/recap

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file recap_capture-0.5.0-cp313-cp313-win_amd64.whl.

File metadata

File hashes

Hashes for recap_capture-0.5.0-cp313-cp313-win_amd64.whl
Algorithm Hash digest
SHA256 3f6fac98744d91c9ce003dfb17a67691bdd7be16117e4e87db26141d5cfc4642
MD5 0d6b8d1582fbbccaab18f65285d536e6
BLAKE2b-256 d2bd758667be094fa0e2f6d311cfefd24736b83940504fbb4fc35ab763869a9f

See more details on using hashes here.

Provenance

The following attestation bundles were made for recap_capture-0.5.0-cp313-cp313-win_amd64.whl:

Publisher: release.yml on Lexian-droid/recap

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file recap_capture-0.5.0-cp312-cp312-win_amd64.whl.

File metadata

File hashes

Hashes for recap_capture-0.5.0-cp312-cp312-win_amd64.whl
Algorithm Hash digest
SHA256 0bf161d24938dd03493148997c371fdeeeac0ebaf8bc00a263f5f4b4642b2dbf
MD5 bd87df7bc68c9fed163697d652e8b798
BLAKE2b-256 f086f55c314dbb008871bfcd93633829b096dd116daf8f86a9bda4c0e5d14b8b

See more details on using hashes here.

Provenance

The following attestation bundles were made for recap_capture-0.5.0-cp312-cp312-win_amd64.whl:

Publisher: release.yml on Lexian-droid/recap

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file recap_capture-0.5.0-cp311-cp311-win_amd64.whl.

File metadata

File hashes

Hashes for recap_capture-0.5.0-cp311-cp311-win_amd64.whl
Algorithm Hash digest
SHA256 d7b19cf81d5770c5bbd441c66f04b2f2e369c5094c6c3d48718bcb70fe25d705
MD5 edcdf74f20881dc879d66d400b959c09
BLAKE2b-256 29c2de2db2d27b89271430de6a57a0fe40c9bf86abfc1ac08aca1aae72d838d0

See more details on using hashes here.

Provenance

The following attestation bundles were made for recap_capture-0.5.0-cp311-cp311-win_amd64.whl:

Publisher: release.yml on Lexian-droid/recap

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file recap_capture-0.5.0-cp310-cp310-win_amd64.whl.

File metadata

File hashes

Hashes for recap_capture-0.5.0-cp310-cp310-win_amd64.whl
Algorithm Hash digest
SHA256 313e8b299d8acafccc4574ab0838ddc4a98c834a78bb521267dcf3e15dcf5560
MD5 77a8fea1f60b6047542cbc9bf4cbb342
BLAKE2b-256 7aaceaaf727d939dfd50bf60e149658cd799378c469246964a77b8493c03f70f

See more details on using hashes here.

Provenance

The following attestation bundles were made for recap_capture-0.5.0-cp310-cp310-win_amd64.whl:

Publisher: release.yml on Lexian-droid/recap

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page