Skip to main content

Simple Python native access library for Video4Linux camera devices

Project description

Simple Python native access library for Video4Linux camera devices

Warning: Work (slowly) in progress. Currently hardwired to YUV format. This will be fixed soon

This is a simple library that allows one to access camera devices accessible via Video4Linux from Python without using libraries with huge dependency chains that allows easy and fast testing of ideas and algorithms for image processing before implementing them in a proper way in some programming language such as C. It’s built in the most simple way on purpose.

Tested on:

  • Python 3.8:

    • FreeBSD 12 (amd64, aarch64)

    • FreeBSD 13 (amd64, aarch64)

Currently not implemented / not optimal

  • Currently the library does not support anything else than YUV422 captures from the cameras and only outputs RGB888 images as nested Python lists. This will be fixed as soon as possible but will introduce a breaking change.

Installing via PyPi

The package is available as a source distribution via PyPi:

pip install simplepycam-tspspi

Building

Use setup.py in cext:

$ python setup.py build

Example usage

More sophisticated examples can be found in the samples directory.

Using the stream callback interface, the default format and with

import simplepycam

def processFrame(camera, frame):
    if shouldStopProcessing:
        return False
    else:
        return True

with simplepycam.Camera("/dev/video0") as cam:
    cam.frameCallback = [ processFrame ]
    cam.stream()

Using the stream callback interface, the default format and open/close

import simplepycam

def processFrame(camera, frame):
    if shouldStopProcessing:
        return False
    else:
        return True

cam = simplepycam.Camera("/dev/video0")
cam.open()
cam.frameCallback = [ processFrame ]
cam.stream()
cam.close()

Using the polling API, the default format and with

import simplepycam

with simplepycam.Camera("/dev/video0") as cam:
    cam.streamOn()
    for i in range(100):
        frame = cam.nextFrame()
    cam.streamOff()

Using the polling API, the default format and open/close

import simplepycam

cam = simplepycam.Camera("/dev/video0")
cam.open()
cam.streamOn()
for i in range(100):
    frame = cam.nextFrame()
cam.streamOff()
cam.close()

API documentation

UML diagram of Python side

UML diagram of Python side

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

simplepycam-tspspi-0.1.1.tar.gz (10.7 kB view details)

Uploaded Source

File details

Details for the file simplepycam-tspspi-0.1.1.tar.gz.

File metadata

  • Download URL: simplepycam-tspspi-0.1.1.tar.gz
  • Upload date:
  • Size: 10.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.0 CPython/3.8.13

File hashes

Hashes for simplepycam-tspspi-0.1.1.tar.gz
Algorithm Hash digest
SHA256 adb3d92eaf584b6de4bf1180b719f10816a066b8971cd655e3a498a482d6f7bd
MD5 9635c08858035272ea5b180356bb25c1
BLAKE2b-256 8278b294f5ef346d103f0f62f956b8e962781ad9456628c10dafc60ca0b56be8

See more details on using hashes here.

Supported by

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