Time Lapse camera support for Duet based 3D printers.
Designed to run on a Raspberry Pi, may be adaptable to other platforms. Supports cameras via USB, Pi (ribbon cable), and Webcam. May support DSLR triggering in the future. Produces a video with H.264 encoding in an MP4 container. Does not, at this time, manage a library of videos, it simply drops the vid in home directory.
Triggers images based on time, layer change, or pause. Works with existing pauses in G-Code, or can force pauses at other trigger events. Optionally moves head to a specified position before capturing paused images.
As of April 2, 2020, ready for Alpha testing. Feedback via issues on Github or at Duet forum https://forum.duet3d.com/
Status of Features. Unchecked features are planned, coming soon:
Cameras:
- USB Cam
- Web Cam
- Pi Cam
- DSLR Cam via USB
- GPIO pin to trigger any kind of camera
Other Features:
- Detect Layer change
- Intervals in seconds
- Detect Pauses
- Force Pauses
- Position Head during Pauses
- Video output in H264 MP4
- Unique names for Videos
- Add a timestamp in one corner of vid. Analog or Digital? Or option.
- Either:
- git clone https://github.com/DanalEstes/DuetLapse
- Right click and "Save as" https://github.com/DanalEstes/DuetLapse/blob/master/DuetLapse.py
- Copy included module https://github.com/DanalEstes/DuetWebAPI/blob/master/DuetWebAPI.py to the same directory, or to anywhere in python's libpath.
- chmod 744 DuetLapse.py
- Python3
- Duet printer must be reachable via network
- ffmpeg
- Depending on camera type, one of
- fswebcam (for USB cameras)
- raspistill (for Pi cam or Ardu cam)
- wget (for Web cameras)
Start the script, usually ./DuetLapse [options], before starting a print. It will connect to the printer and wait for the printer to change status from "Idle" to "Processing" and then begin capturing still images per the flag settings. When the printer then goes "idle" again (i.e. end of print), it will process the still images into a video.
usage: DuetLapse.py -duet DUET
[-camera {usb,pi,web,dslr}]
[-seconds nnn]
[-detect {layer,pause,none}]
[-pause {yes,no}]
[-movehead nnn nnn]
[-weburl http://full-url-to-get-still-from-webcam]
[-h]
The only required flag is -duet to specify the printer to which the script will connect. If not specified, camera defaults to "USB" and detection defaults to "layer". Example:
./DuetLapse.py -duet 192.168.7.101
Many options can be combined. For example, the script can trigger on both "seconds" and "detect layer". It will inform you if you select conflicting options.
Example: Use a webcam that requires a UserId and Password, trigger every 30 seconds, do not detect any other triggers:
./DuetLapse.py -camera web -weburl http://userid:[email protected]/cgi-bin/currentpic.cgi -duet 192.168.7.101 -seconds 20 -detect none
Example: Default to USB camera and detecting layer changes, force pauses (at layer change) and move head to X10 Y10 before taking picture.
./DuetLapse.py -duet 192.168.7.101 -pause yes -movehead 10 10