Some links in this post may be affiliate links. We may get paid if you buy something or take an action after clicking one of these, but without addictional costs for you compared to direct buying.
RPI camera time lapse featured image

Time lapse video with rpicamera-still and Raspberry PI camera

4.3
(3)

Last Updated on 19th July 2024 by peppe8o

In this tutorial, I’m going to show you how to create a time-lapse video with a the rpicamera-still, Raspberry PI board, and a Camera. So, we’ll use the rpicamera-apps to get images and the ffmpeg library to create a new time-lapse video.

One of the most common Raspberry PI accessories is the Raspberry PI Camera. Besides common usages (like videoconferencing), RPI gives a lot of advanced functions. One of the most intriguing is getting a time-lapse video from a Raspberry PI camera.

Before digging into technical commands, please find in the following chapter a brief introduction to what a time-lapse video is.

Time Lapse Technique

Looking at a list of images projected on a screen, human eyes can’t distinguish interruptions between an image (frame) and the following one with a switch rate higher than 60 Frames Per Second (fps). On the other side, getting an illusion of continuous motion requires at least 10 fps (even if the optimal fps is supposed to 25). This uses the so-called Persistence of Vision.

Time Lapse technique uses only some still frames, extracting them from a video stream or capturing these frames from a camera with defined intervals. Still images, consolidated in smaller intervals so that they can appear to the human eye as a continuous flow, give the illusion that time is running faster on video.

In the following picture, this process is described with an example, where from 15 fps (frame per second) we take 1 image every 5 and compress extracted images in a new video. Images that would be shown after 5 seconds (from frame 76) will appear in a new video file after 1 second:

time lapse explaination diagram

In this tutorial I will use my old Raspberry PI 3 model B+ for the tests, but this tutorial should work with any Raspberry PI computer board.

What We Need

As usual, I suggest adding from now to your favourite e-commerce shopping cart all the needed hardware, so that at the end you will be able to evaluate overall costs and decide if to continue with the project or remove them from the shopping cart. So, hardware will be only:

raspberry-pi-5-model-b-board

Step-by-Step Procedure

Please connect the camera module to your Raspberry PI in its port before starting. The Raspberry PI provided a complete article about connecting it in their install a raspberry pi camera article.

Prepare Operating System

I will use only the terminal commands, so you can install Raspberry PI OS Lite (for a fast, headless OS) or Raspberry PI OS Desktop (in this case, using its internal terminal).

Once installed, please make your OS up to date. From the terminal, use the following command:

sudo apt update -y && sudo apt upgrade -y

We also need FFmpeg:

sudo apt install ffmpeg

With old Raspberry PI OS releases, you had to enable the camera interface from the raspi-config tool (from the System Options menu). With the last releases the camera module automatically becomes active at the sensor connection.

Capturing Images with rpicamera-still and Raspberry PI

Create a new folder named as you like and enter it. Here we’ll store all the frames and we’ll create the still video:

mkdir timelapse
cd timelapse

With the following command we’ll capture images with defined intervals and save them with increasing naming:

rpicam-still -t 60000 --timelapse 2000 -o image%04d.jpg

In rpicam-still command, the following parameters are used:

  • -t 60000 [or –timeout 60000]: this option will make the command last for a total of 60 seconds (the number is in milliseconds)
  • -timelapse 2000: this option produces a capture (frame) every 2 seconds (the number is in milliseconds)
  • -o image%04d.jpg: every frame captured is saved as jpg file with names like image0001.jpg, image0002.jpg, image0003.jpg and so on. “%04d” indicates to use 4 digits with leading zeroes padding missing digits.

This will generate a list of jpg files inside the current folder as expected:

pi@raspberrypi:~/timelapse $ ls
image0000.jpg  image0001.jpg  image0002.jpg  image0003.jpg  image0004.jpg  image0005.jpg  image0006.jpg  image0007.jpg  image0008.jpg  image0009.jpg  image0010.jpg  image0011.jpg  image0012.jpg  image0013.jpg  image0014.jpg  image0015.jpg  image0016.jpg  image0017.jpg  image0018.jpg  image0019.jpg  image0020.jpg  image0021.jpg  image0022.jpg  image0023.jpg  image0024.jpg  image0025.jpg  image0026.jpg  image0027.jpg  image0028.jpg

Creating Time Lapse Video

Output (time-lapsed) video can be created from jpg images with the following command:

ffmpeg -f image2 -pattern_type glob -i '*.jpg' -s 1280x768 outVideo.mp4

Where:

  • -f image2: This option tells ffmpeg to read from a list of image files specified by a pattern. The syntax and meaning of the pattern is specified by the option pattern_type
  • -pattern_type glob: this option allows you to use wildcard patterns
  • -i ‘*.jpg’: -i option indicates the input media. With the “*” wildcard, we instruct the ffmpeg to collect all the files in the current folder that terminates with “.jpg”
  • -s 1280×768: sets output resolution. Lower resolution allows to use fewer resources to generate the file (it is important for files with a high number of images)
  • outVideo.mp4: sets output file name

After this command you will find a new file named outVideo.mp4 which you can download in your remote computer (for example with SFTP software like Filezilla) and play in your favourite media player (supporting mp4 format, like VLC).

As you can see, we already used -s option to reduce the required computing power and make it compatible with a low hardware board like Raspberry PI. Ffmpeg requires a lot of RAM to run video manipulation. When RAM problems occur, you will receive from the terminal a “killed” notification and the command journalctl -xe | grep ffmpeg will return an Out of Memory error. In these cases, you have a few options:

  • Change the Raspberry PI swap file size
  • reduce computing resources required by reducing output file quality (by tuning output frame rate, resolution, presets)
  • move the concatenation step on computers with higher RAM (higher Raspberry PI, notebook, desktop PC)

Optimizing the Results and Performances with rpicam-still

The following options will let you adjust your jpg files so that you can customize performances and quality

  • –width / –height: these options allow you to get input images with a reduced resolution. If your video will be with specific sizes, these options will help you to reduce the file sizes and improve ffmpeg elaboration
rpicam-still -t 60000 --timelapse 2000 --width 1280 --height 768 -o image%04d.jpg
  • –gain / –awbgains: these options allow you to set the Gain Control and White Balance, disabling the automatic detection, according to the specs of your camera model
rpicam-still -t 8000 --timelapse 2000 --gain 1 --awbgains 2,1 -o image%04d.jpg

Optimizing the Results and Performances with ffmpeg

The following ones are additional options that you can use with ffmpeg:

  • -r: sets the framerate (default value, if not specified “-r 30”). It can be used both for input media as for output media. The following example command uses a -r 10 option that makes the video a bit longer and can give you a
ffmpeg -r 10 -f image2 -pattern_type glob -i '*.jpg' -s 1280x768 outVideo_2.mp4
  • -preset: sets preset (default value, if not specified “-preset medium”). A preset is a collection of options that will provide a certain encoding speed to compression ratio. Available values are [ultrafast, superfast, veryfast, faster, fast, medium, slow, slower, veryslow, placebo]
ffmpeg -f image2 -pattern_type glob -i '*.jpg' -s 1280x768 -preset slow outVideo_3.mp4

A nice final feature for our video is adding a text box on it. After you have generated your time lapse video, use it again as input with ffmpeg add a Text box with the following terminal command:

ffmpeg -i outVideo.mp4 -vf drawtext="text='peppe8o.com': fontcolor=white: fontsize=24: box=1: [email protected]: boxborderw=5: x=(w-text_w)/2: y=(h-text_h)*4/5" -codec:a copy finOUT.mp4

Final Result Example

As final example for results, I’ve prepared a video with a time lapse captured from 45 minutes, with 1 second between each image and restricting width and height to 1280×768 from jpg files:

rpicam-still -t 2700000 --timelapse 2000 --width 1280 --height 768 -o image%04d.jpg

The remaining steps follow the commands provided in this tutorial. The resulting video can be shown in the following:

What’s Next

Want to know more about cool projects to do with Raspberry PI computer boards? In this case, the right resource for you is my Raspberry PI tutorials pages.

Enjoy!

How useful was this post?

Click on a star to rate it anonymously!

Average rating 4.3 / 5. Vote count: 3

No votes so far! Be the first to rate this post.

We are sorry that this post was not useful for you!

Let us improve this post!

Tell us how we can improve this post?

Leave a Comment

Your email address will not be published. Required fields are marked *

I accept the Privacy Policy

Subscribe my newsletter:
×