Skip to content

A python based software for 3D-Printer observation with multiple cameras

Notifications You must be signed in to change notification settings

krabbs/PrinterCam

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

5 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

PrinterCam

A python based software for 3D-Printer observation with multiple cameras

GENERAL INFORMATION: This project is still in a very early phase. The current release is for better collaboration. Current source code is still poor quality, but functional but good.

Current features:

Frontend:

-Two video streams in LowQuality with focus on high FPS and low latency
-Display of HQ photos OnDemand
-FocusView (switching between FPS modes of both streams)
-Start / stop PrusaConnect CameraShare
-Start / stop Timelapse
-Visualization of Service Status
-Automatic Day / Night colors according clients “DarkMode” setting.

Backend:

-Automatic initialisation of cameras by name (UDEV alternative)
-asynchronous client management (allows streaming to multiple clients with Ptython Flask)
-Multi threading (one thread per camera, one thread per client. Camera threads send events to clients as soon as a new frame is available, results in low CPU load)
-Intelligent timelapse (series of images in variable time intervals, but a new image for Timeseries video is stored that most closely resembles the old one. This is to prevent fidgeting on the video. I use SSIM or MSE to compare images and decide which one is the best)
-Send images to PrusaConnect
-Provide a merged image from both cameras (merged vertically)
-Provide individual images in full resolution
-Change camera resolution
-Provide JSON API (output status of services, camera, PrusaConnect, timelapse).
-Auto turn on as soon as somebody connects
-Auto turn off camera if nobody is watching
-(Backend based on FLASK and OPENCV)

Hardware:

-Raspberry Pi zero 2 w
-Two cameras (CSI camera, USB camera)

SETUP:

You need your TOKENS for the PRUSA-CAM from PrusaConnect.
In addition the source for opencv has to be defined. The source path is searched based on the usb camera name. this is necessary without udev because the source path can change when booting the hw. For a CSI camera the name is usually "camera0". They have to be placed in an .env file:
FINGERPRINT=XXXXXXXXXXXXXXXXXXXXXXXXXXX
TOKEN=XXXXXXXXXXXXXXXX
camera1_name=WEBCAM NAME 1
camera2_name=camera0

About

A python based software for 3D-Printer observation with multiple cameras

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published