Giter Site home page Giter Site logo

camera-capture-system's Introduction

camera-capture-system

Description

A system that:

  1. captures USB camera feeds using openCV with platform specific backends
  2. syncronizes the video feeds and adds metadata
  3. sends the resulting frame and metadata over a network connection using ZMQ PubSub

Usage

clone the repo and cd into it

git clone https://github.com/kristina-aino/camera-capture-system.git
cd camera-capture-system

poetry setup, test and build

poetry install
poetry run pytest
poetry build

create the config file for your camera setup

Example

{
  "cam0": {
    "id": 1,
    "width": 1920,
    "height": 1080,
    "fps": 30,
    "name": "A-webcam",
    "position": "center"
  },
  "cam1": {
    "id": 0,
    "width": 1920,
    "height": 1080,
    "fps": 60,
    "name": "Another-webcam",
    "position": "center-right"
  },
}
  • "cam0", "cam1", etc. is considered the uuid and is required to be unique (enforced by json standard)
  • "id" is the OpenCV id the camera runs under
  • "width", "height" and "fps" are camera specification
  • "name" and "position" are human redables with no logical value

Start the capture and publishing on localhost port 10000

poetry run python main.py

Or use it as a module

from camera_capture_system.core import load_all_cameras_from_config, MultiCameraCaptureAndPublish

cameras = load_all_cameras_from_config(path_to_conf)

pccp = MultiCameraCaptureAndPublish(cameras=cameras)
pccp.start()

(if there are problems, feel free to create an issue)

camera-capture-system's People

Contributors

kristina-aino avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.