Skip to main content

Headless screen and audio capture library and CLI for Windows

Project description

recap

Headless screen and audio capture library and CLI for Windows.

Features

  • Record an entire monitor via Windows Graphics Capture (WGC)
  • Record a single window via WGC (real window capture, not desktop crop)
  • Record system audio via WASAPI loopback
  • Video-only, audio-only, or audio+video modes
  • CLI tool (recap) and importable Python library
  • Uses FFmpeg for encoding/muxing only

Installation

pip install -e .

FFmpeg must be available on PATH or specified via --ffmpeg.

Releasing

GitHub Actions will publish the package to PyPI when you push a tag that starts with v, for example v0.1.1.

Before the first release, configure PyPI Trusted Publishing for this repository and approve the pypi environment in GitHub.

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
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()

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.3.0.tar.gz (26.3 kB view details)

Uploaded Source

Built Distribution

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

recap_capture-0.3.0-py3-none-any.whl (28.7 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: recap_capture-0.3.0.tar.gz
  • Upload date:
  • Size: 26.3 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.3.0.tar.gz
Algorithm Hash digest
SHA256 0c124166a5a1f77305aaacda9a30e02c11bde1b8f826075984202840dc0b5f73
MD5 94b6c7ddd881b7da5f9f6b819b81dadc
BLAKE2b-256 aa57b634bb9500b5113644071980dc8ed808c4aa463ee6a71963a176bd74f3d4

See more details on using hashes here.

Provenance

The following attestation bundles were made for recap_capture-0.3.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.3.0-py3-none-any.whl.

File metadata

  • Download URL: recap_capture-0.3.0-py3-none-any.whl
  • Upload date:
  • Size: 28.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for recap_capture-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 6245a3e3bdb49c1524b1cf843a966390ff566169ab0609f16186b6efca5f0614
MD5 7a97c43924325dab169ff401feb011d7
BLAKE2b-256 062ee2ebee8277d8422307d5ea9f79a710d7e1a1e14e59f42e93b2984512e3fc

See more details on using hashes here.

Provenance

The following attestation bundles were made for recap_capture-0.3.0-py3-none-any.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