Skip to main content

PyQt5 wrapper for pypylon SDK for Basler camera manipulation, aimed for microfluidics and slow motion.

Project description

PylonGUY

Your best friend for high-performance camera control for Basler cameras with high-speed recording capabilities and simple GUI.

preview

Features

  • Real-time preview with adaptive grab strategy (lag-free at any FPS)
  • Camera configuration with automatic adjustment to camera capabilities
  • High-speed frame capture to raw frames with FFmpeg post-processing
  • Configurable playback rate for slow-motion video
  • Interactive ROI selection and offset controls
  • Preset configurations (Default, HighSpeed, FullFrame, Microfluidics)
  • Auto-apply presets on camera connection
  • Waterfall mode for line-scan recording

Installation

From PyPI

pip install pylonguy

From source

git clone https://github.com/merv1n34k/pylonguy.git
cd pylonguy
pip install -e .

Requirements

  • Python 3.12+
  • ffmpeg in PATH (for video processing)
  • Basler Pylon SDK (for camera communication)

Installing ffmpeg

# macOS
brew install ffmpeg

# Ubuntu/Debian
sudo apt install ffmpeg

# Windows
# Download from https://ffmpeg.org/download.html and add to PATH

Installing Pylon SDK

Download from Basler website. See pypylon known issues for platform-specific notes.

Usage

# Run the application
pylonguy

# Or with uv
uv run pylonguy

Presets

Camera presets are saved to presets.json in the current working directory. This allows you to maintain different presets for different projects by running the application from each project's folder.

How it works

The application separates capture from video encoding for maximum performance:

  1. Capture Phase: Frames stream from camera → memory buffer → raw files on disk
  2. Processing Phase: After recording stops, FFmpeg assembles raw frames into video

This allows you to specify any desired playback frame rate, e.g.:

  • Camera captures at 1000 fps
  • Video plays back at 24 fps
  • Result: 1 second of capture = 41.7 seconds of slow-motion video

Waterfall Mode

Record single lines instead of full frames for:

  • Maximum frame rates (minimal data transfer)
  • Line-scan camera emulation
  • Monitoring flow in microfluidic channels

Output format: .wtf (waterfall) files, convertible to PNG:

python -m pylonguy.wtf2png recording.wtf

License

Distributed under the MIT License. See LICENSE for more information.

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

pylonguy-1.9.0.tar.gz (934.8 kB view details)

Uploaded Source

Built Distribution

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

pylonguy-1.9.0-py3-none-any.whl (65.1 kB view details)

Uploaded Python 3

File details

Details for the file pylonguy-1.9.0.tar.gz.

File metadata

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

File hashes

Hashes for pylonguy-1.9.0.tar.gz
Algorithm Hash digest
SHA256 cdc0a3cf91a7b9b6cf761274068609149dc0b815590e6d8c20eb2c8c070762a3
MD5 f74ca8220fd71eba79d60884d75bd4dc
BLAKE2b-256 5c6a444f5234a7d9aa857f51c140893c863036b8521649ce103a8a4de7855244

See more details on using hashes here.

Provenance

The following attestation bundles were made for pylonguy-1.9.0.tar.gz:

Publisher: publish.yml on merv1n34k/pylonguy

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

File details

Details for the file pylonguy-1.9.0-py3-none-any.whl.

File metadata

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

File hashes

Hashes for pylonguy-1.9.0-py3-none-any.whl
Algorithm Hash digest
SHA256 9656e9649a19402a7817fe526363048098010175704dcb0966e16bd9a3f4f553
MD5 d23ca3b751ddee6dea7143314af792f3
BLAKE2b-256 94a241e205c54b5827bbe5c2ec55d4b09d93704614dc55a5760fe707d1a47463

See more details on using hashes here.

Provenance

The following attestation bundles were made for pylonguy-1.9.0-py3-none-any.whl:

Publisher: publish.yml on merv1n34k/pylonguy

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