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

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.8.0.tar.gz (310.9 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.8.0-py3-none-any.whl (63.9 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for pylonguy-1.8.0.tar.gz
Algorithm Hash digest
SHA256 58f557c1b127e74164eb34a802686fcc709cad95fa1aafdc2a1ba95032b4ffa5
MD5 ae0dc8779503242661a617d7d6bcf31f
BLAKE2b-256 517ab3c912761bd5f2ae7dea3066c4400dc80c86ca53e2d197aaa3638a2d9727

See more details on using hashes here.

Provenance

The following attestation bundles were made for pylonguy-1.8.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.8.0-py3-none-any.whl.

File metadata

  • Download URL: pylonguy-1.8.0-py3-none-any.whl
  • Upload date:
  • Size: 63.9 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.8.0-py3-none-any.whl
Algorithm Hash digest
SHA256 86c4940efa2c7ed13623f4e697996be938cee424da64e0a4903c657fbcbff3de
MD5 c0b09bfd6294501bfe389a7e50debb51
BLAKE2b-256 c23a62cb17e4d6f773a10eaf06dc6e1d6c8f5985c43555da3787288712650a0b

See more details on using hashes here.

Provenance

The following attestation bundles were made for pylonguy-1.8.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